/* === polish.css === */
/* ============================================================
   diyarbakr.com — polish.css
   Mevcut portal temasını KORUYAN ince iyileştirme katmanı.
   Renk paleti, yazı tipleri ve düzen aynen korunur; yalnızca
   mikro etkileşim, tipografi ve erişilebilirlik rötuşları içerir.
   Bundle CSS'inden SONRA yüklenmelidir.
   ============================================================ */

/* ---------- 1. Tipografi rötuşları ---------- */
.portal-root .sec-title,
.portal-root .portal-section-title,
.portal-root .portal-home-hero-headline,
.portal-root .portal-news-hero-headline,
.portal-root .dynamic-page-title {
  text-wrap: balance;
}
.portal-root .portal-home-hero-lead,
.portal-root .ev-desc {
  text-wrap: pretty;
}
.portal-root .portal-stat-value,
.portal-root .portal-today-stat-value,
.portal-root .ev-day {
  font-variant-numeric: tabular-nums;
}

/* ---------- 2. Seçim rengi (tema turuncusu) ---------- */
.portal-root ::selection {
  background: #ffedd5; /* orange-100 */
  color: #7c2d12;      /* orange-900 */
}

/* ---------- 3. İnce, nötr kaydırma çubuğu ---------- */
html {
  scrollbar-width: thin;
  scrollbar-color: #d6d3d1 transparent;
}
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb {
  background: #d6d3d1;
  border-radius: 999px;
  border: 2px solid #f4f4f3;
}
::-webkit-scrollbar-thumb:hover { background: #a8a29e; }
::-webkit-scrollbar-track { background: transparent; }

/* ---------- 4. Sabit header'a cam efekti ---------- */
@supports (backdrop-filter: blur(1px)) {
  .portal-header {
    background-color: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(12px) saturate(1.4);
    -webkit-backdrop-filter: blur(12px) saturate(1.4);
  }
}

/* Sabit header altında çapa hedefleri gizlenmesin */
.portal-root section[id],
.portal-root .sec[id],
.portal-root [id^="bolum"],
.portal-root h2[id] {
  scroll-margin-top: 84px;
}

/* ---------- 5. Kartlarda daha akıcı hover eğrisi ---------- */
.portal-root .sec-place-card,
.portal-root .ev,
.portal-root .hero-post-card,
.portal-root .related-post-card,
.portal-card-hover {
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
  transition-duration: 0.28s;
  will-change: transform;
}
.portal-root .sec-place-card:hover,
.portal-root .ev:hover,
.portal-root .hero-post-card:hover {
  transform: translateY(-3px);
}
.portal-root .sec-place-card__img img {
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
  transition-duration: 0.7s;
}

/* ---------- 6. Katmanlı, yumuşak gölge sistemi ----------
   Hover'da üç katman: yakın temas + orta yayılım + geniş ambient.
   Turuncu tint (#ea580c) çok düşük opaklıkta korunur. */
.portal-root .sec-place-card:hover,
.portal-root .ev:hover,
.portal-root .hero-post-card:hover,
.portal-root .related-post-card:hover {
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.06),
    0 8px 24px rgba(28, 25, 23, 0.10),
    0 20px 48px #ea580c14;
}

/* ---------- 7. Buton ve pill basış geri bildirimi ---------- */
.portal-btn,
.portal-btn-outline,
.portal-root .filter-pill,
.portal-pill,
.portal-root .btn-view-all,
.portal-root .not-found-btn,
.portal-root .section-error-btn {
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-btn:active,
.portal-btn-outline:active,
.portal-root .filter-pill:active,
.portal-pill:active,
.portal-root .btn-view-all:active,
.portal-root .not-found-btn:active {
  transform: scale(0.97);
}

/* Aktif filtre piline turuncu derinlik */
.portal-root .filter-pill.active {
  box-shadow: 0 4px 12px #ea580c30;
}

/* ---------- 8. Tutarlı, erişilebilir odak halkası ---------- */
.portal-root a:focus-visible,
.portal-root button:focus-visible,
.portal-root .filter-pill:focus-visible,
.portal-pill:focus-visible,
.portal-input:focus-visible {
  outline: 2px solid #ea580c;
  outline-offset: 2px;
  border-radius: inherit;
}

/* ---------- 9. Hızlı menü mikro hareketi + turuncu vurgu ----------
   Bundle'daki hover (zemin: stone-50, ikon: stone-900) korunur;
   üzerine ince turuncu alt çizgi ve ikon tonu eklenir. */
.portal-quick-nav-icon {
  transition: transform 0.25s cubic-bezier(0.22, 0.61, 0.36, 1), color 0.2s;
}
.portal-quick-nav-item {
  box-shadow: inset 0 0 0 transparent;
  transition-property: color, background-color, border-color, box-shadow,
    transform, translate, scale, opacity;
}
.portal-quick-nav-item:hover {
  box-shadow: inset 0 -2px 0 #ea580c8c;
}
.portal-quick-nav-item:hover .portal-quick-nav-icon {
  transform: translateY(-2px);
  color: #c2410c;
}
.portal-quick-nav-item:hover .portal-quick-nav-label {
  color: #c2410c;
}

/* ---------- 10. Panel ve dash kartlarına ince gradient zemin ---------- */
.portal-today-panel,
.portal-dash-card {
  background-image: linear-gradient(180deg, #ffffff 0%, #fafaf9 100%);
  transition: border-color 0.25s cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 0.25s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-today-panel:hover,
.portal-dash-card:hover {
  border-color: #d6d3d1; /* stone-300: hafif, nötr vurgu */
}
.portal-dash-card:hover {
  box-shadow: 0 1px 2px #1c191708, 0 8px 24px #1c19170a;
}

/* ---------- 11. Hero sahnesi: çerçeve, oklar, Ken Burns ---------- */
.portal-home-hero-stage,
.portal-news-hero-stage {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08),
              0 18px 44px rgba(28, 25, 23, 0.16);
}
.portal-home-hero-dot,
.portal-news-hero-progress-item {
  cursor: pointer;
}

/* Oklarda hover: büyüme + gölge.
   Konumlandırma 'translate' özelliğiyle yapıldığından 'scale'
   ayrı özellik olarak güvenle kullanılır, transform'a dokunulmaz. */
.portal-home-hero-arrow,
.portal-news-hero-arrow {
  transition-duration: 0.25s;
}
.portal-home-hero-arrow:hover,
.portal-news-hero-arrow:hover {
  scale: 1.08;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
}
.portal-home-hero-arrow:active,
.portal-news-hero-arrow:active {
  scale: 1;
}

/* Ken Burns: aktif slayt 8 sn boyunca 1.02 → 1.06 büyür.
   Bundle'daki geçiş yalnızca opacity üzerinde olduğundan
   transform animasyonu opacity cross-fade'ini ETKİLEMEZ. */
@keyframes polish-ken-burns {
  from { transform: scale(1.02); }
  to   { transform: scale(1.06); }
}
.portal-home-hero-stage-img.is-active {
  animation: polish-ken-burns 8s ease-out forwards;
}

/* ---------- 12. Haber rayında okunabilirlik ---------- */
.portal-news-hero-rail-item {
  transition: background-color 0.2s, border-color 0.2s, padding-left 0.2s;
}
.portal-news-hero-rail-title {
  text-wrap: pretty;
}

/* ---------- 13. Görsel yüklenirken zemin tonu + yumuşak fade-in ---------- */
.portal-root .sec-place-card__img,
.portal-news-hero-featured-media,
.portal-news-hero-rail-thumb {
  background-color: #e7e5e4;
}

/* Kart görselleri ilk boyamada yumuşakça belirir.
   Slider görselleri HARİÇ tutuldu (opacity geçişleri bundle'da). */
@keyframes polish-img-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.portal-root .sec-place-card__img img,
.portal-news-hero-rail-thumb img,
.portal-news-hero-featured-media img,
.portal-root .ev img,
.portal-root .hero-post-card img,
.portal-root .related-post-card img {
  animation: polish-img-fade 0.5s ease-out backwards;
}

/* ---------- 14. Footer linklerinde yumuşak geçiş ---------- */
footer a,
footer button {
  transition: background-color 0.25s cubic-bezier(0.22, 0.61, 0.36, 1),
              color 0.25s,
              border-color 0.25s,
              transform 0.25s cubic-bezier(0.22, 0.61, 0.36, 1);
}
footer a:hover {
  transform: translateY(-1px);
}

/* ---------- 15. Mobil dokunma hedefleri ----------
   Görünümü değiştirmeden tıklanabilir alanı dengeler:
   içerik dikeyde ortalanır, min-height ile alan büyür. */
@media (max-width: 767px) {
  .portal-root .filter-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding-top: 0.4rem;
    padding-bottom: 0.4rem;
  }
  .portal-quick-nav-item {
    min-height: 44px;
    justify-content: center;
  }
  footer a {
    min-height: 44px;
  }
}

/* ---------- 16. Hareket azaltma tercihine saygı (EN SONDA KALMALI) ---------- */
@media (prefers-reduced-motion: reduce) {
  .portal-root *,
  .portal-root *::before,
  .portal-root *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
  .portal-home-hero-stage-img.is-active {
    animation: none !important;
    transform: scale(1.02); /* bundle'daki statik değer korunur */
  }
}

/* ============================================================
   v3 — GÖRÜNÜR PROFESYONEL KATMAN (10 Haziran 2026)
   Tema kimliği (renkler/fontlar/düzen) korunur; dinlenme
   hâlindeki görünümü belirgin şekilde rafine eder.
   ============================================================ */

/* 17. Zemin: üstte hafif sıcak ton, aşağıda mevcut gri */
.portal-root {
  background: linear-gradient(180deg, #faf9f7 0%, #f4f4f3 360px);
}

/* 18. Bölüm başlıkları: marka turuncusu kimliği */
.portal-root .overline,
.portal-overline {
  color: #c2410c;
  letter-spacing: .18em;
}
.portal-root .sec-title-divider {
  width: 3rem;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ea580c, #fdba74);
}

/* 19. Kartlar dinlenme hâlinde daha rafine */
.portal-root .sec-place-card,
.portal-root .ev,
.portal-root .hero-post-card,
.portal-root .related-post-card {
  border-radius: 1.25rem;
  border-color: #eceae7;
  box-shadow: 0 1px 2px rgba(28,25,23,.04), 0 10px 28px -18px rgba(28,25,23,.12);
}
.portal-card,
.portal-dash-card,
.portal-today-panel,
.portal-quick-nav,
.portal-announcement {
  border-radius: 1.1rem;
}

/* 20. Hızlı menü ikonları: yumuşak turuncu rozetler */
.portal-quick-nav-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .55rem;
  border-radius: .85rem;
  background: #fff7ed;
  border: 1px solid #ffedd5;
  color: #c2410c;
  transition: transform .25s cubic-bezier(.22,.61,.36,1), background .2s, color .2s;
}
.portal-quick-nav-item:hover .portal-quick-nav-icon {
  background: #ffedd5;
  color: #9a3412;
  transform: translateY(-2px);
}

/* 21. Birincil butonlar: derinlik + hover kalkışı */
.portal-btn {
  background-image: linear-gradient(180deg, #292524, #1c1917);
  box-shadow: 0 1px 2px rgba(28,25,23,.25), 0 6px 16px -8px rgba(28,25,23,.35);
  transition: transform .22s cubic-bezier(.22,.61,.36,1), box-shadow .22s;
}
.portal-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(28,25,23,.25), 0 10px 24px -8px rgba(28,25,23,.4);
}

/* 22. Aktif filtre: marka turuncusu gradyanı */
.portal-root .filter-pill.active {
  background: linear-gradient(135deg, #f97316, #ea580c);
  border-color: transparent;
}

/* 23. Hero sahnesi: daha cömert köşe yumuşatma */
.portal-home-hero-stage,
.portal-news-hero-stage,
.portal-news-hero-featured {
  border-radius: 1.25rem;
}

/* 24. Bugün paneli ve duyurular: marka vurgu şeridi */
.portal-today-panel {
  border-top: 3px solid #ea580c;
}
.portal-announcement {
  border-left: 3px solid #ea580c;
}

/* 25. Koyu footer'a ince marka şeridi */
.portal-root footer {
  border-top: 2px solid #ea580c;
}
.portal-root footer a {
  transition: color .2s, transform .2s;
}

/* 26. Rozetler: hafif derinlik */
.portal-root .sec-place-card__badge {
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.portal-root .sec-place-card__rating {
  box-shadow: 0 2px 10px rgba(234,88,12,.45);
}

/* ============================================================
   v4 — NAVBAR REDESIGN (10 Haziran 2026)
   Göze çarpan ama zarif: marka şeridi, cam zemin, büyük harfli
   nav linkleri + animasyonlu turuncu alt çizgi. Logo koyu yazılı
   PNG olduğundan zemin AÇIK kalır. Mobil menüde display/position
   değiştirilmez; yalnızca renk/tipografi.
   ============================================================ */

/* 27. Header tepesine 3px turuncu→amber marka şeridi */
.portal-header::before {
  content: "";
  display: block;
  height: 3px;
  background: linear-gradient(90deg, #ea580c, #f59e0b, #fdba74);
}

/* 28. Header zemini: beyaz cam + belirgin ama yumuşak alt gölge */
.portal-header {
  box-shadow: 0 1px 0 #e7e5e4, 0 8px 32px rgba(28, 25, 23, 0.08);
}
@supports (backdrop-filter: blur(1px)) {
  .portal-header {
    background-color: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(16px) saturate(1.5);
    -webkit-backdrop-filter: blur(16px) saturate(1.5);
  }
}

/* 29. Nav linkleri: büyük harf, sıkı tipografi, animasyonlu çizgi.
   Bundle: 13px / weight 500 / stone-600. Link padding-inline .625rem
   olduğundan çizgi içerik genişliğine hizalanır. */
.portal-nav-link {
  position: relative;
  font-size: 12.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #57534e;
}
.portal-nav-link::after {
  content: "";
  position: absolute;
  left: 0.625rem;
  right: auto;
  bottom: 0;
  height: 2px;
  width: 0;
  border-radius: 999px;
  background: #ea580c;
  transition: width 0.25s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-nav-link:hover {
  color: #1c1917;
}
.portal-nav-link:hover::after {
  width: calc(100% - 1.25rem);
}

/* 30. Aktif link: turuncu kimlik + kalıcı çizgi
   (bundle'daki stone-900 ::after çubuğunun üzerine yazar) */
.portal-nav-link-active {
  color: #c2410c;
}
.portal-nav-link-active::after {
  width: calc(100% - 1.25rem);
  left: 0.625rem;
  right: auto;
  height: 2px;
  background: #ea580c;
}
.portal-nav-link-active:hover {
  color: #9a3412;
}

/* 31. Logo bir kademe büyür (bundle: 3rem → 3.25rem@40rem → 3.5rem@64rem;
   bar yüksekliği 4.25rem/4.75rem olduğundan taşma olmaz) */
.portal-header .portal-logo {
  height: 3.25rem;
}
@media (min-width: 40rem) {
  .portal-header .portal-logo { height: 3.5rem; }
}
@media (min-width: 64rem) {
  .portal-header .portal-logo { height: 3.75rem; }
}

/* 32. Arama kutusu: focus'ta turuncu halka (yalnızca renk, layout sabit) */
.portal-input:focus {
  border-color: #fdba74;
  --tw-ring-color: #ea580c33;
}

/* 33. Telefon butonu: turuncu kenarlıklı belirgin pill */
.portal-btn-call {
  border-radius: 999px;
  border-color: #fdba74;
  color: #c2410c;
  font-weight: 700;
}
.portal-btn-call:hover {
  border-color: #fb923c;
  background-color: #fff7ed;
  color: #9a3412;
}

/* ============================================================
   v4 — DOLULUK (10 Haziran 2026)
   Boş reklam alanları kapanır, bölüm ritmi sıkılaşır, quick-nav
   ve footer daha fazla mevcudiyet kazanır.
   ============================================================ */

/* 34. Boş reklam rayları yer kaplamasın (doluysa etkisiz) */
.portal-rail:empty,
.hero-ad:empty,
.portal-mobile-hero-ad:empty {
  display: none;
}

/* 35. Bölüm ritmi: 4rem/5rem → 3.25rem/4rem; sayfa daha dolu akar */
.portal-root .sec {
  padding-block: 3.25rem 4rem;
}

/* 36. Bölüm başlığında nefes */
.portal-root .sec-title {
  margin-bottom: 0.5rem;
}

/* 37. Quick-nav: bir tık daha derin gölge + daha okunur etiket */
.portal-quick-nav {
  box-shadow: 0 2px 8px #1c19170a, 0 20px 56px #1c191718, inset 0 1px #ffffffe6;
}
.portal-quick-nav-label {
  font-weight: 600;
  font-size: 11px;
}

/* 38. Kart gridlerinde görsel ağırlık */
.portal-root .sec-grid {
  gap: 1.1rem;
}

/* 39. Tarih bölümüne çok ince Diyarbakır kemer silüeti
   (yalnızca .timeline içeren tek bölüm; opaklık .05, zemin alt kenarı) */
.portal-root .sec:has(.timeline) {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='64' viewBox='0 0 120 64'%3E%3Cpath d='M8 64 V30 a22 22 0 0 1 44 0 V64 M68 64 V30 a22 22 0 0 1 44 0 V64' fill='none' stroke='%239a3412' stroke-width='2.5' opacity='.05'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: bottom center;
  background-size: 120px 64px;
}

/* 40. Footer: daha cömert dikey alan + linklerde sağa kayma */
.portal-root footer {
  padding-top: 1rem;
  padding-bottom: 0.75rem;
}
.portal-root footer a:hover {
  transform: translateX(2px);
}

/* === redesign-cards.css === */
/* ============================================================================
   diyarbakr.com — KART SİSTEMİ YENİDEN TASARIM (redesign-cards.css)
   ----------------------------------------------------------------------------
   Dergi/editoryal seviyesinde kart dili. polish.css'ten SONRA yüklenir;
   bundle (index--MSd8cSU.css) ve polish.css kurallarını eşit özgüllükle
   (çoğunlukla `.portal-root .x`) kaynak sırasıyla ezer.

   Ortak dil:
   - Vurgu: #ea580c / koyu #c2410c / açık #fff7ed #ffedd5 #fdba74
   - Metin: #1c1917 (koyu), #57534e (orta), #78716c (soluk)
   - Köşe: kart 1.25rem, chip 999px
   - Gölge (dinlenme): 0 1px 2px rgba(28,25,23,.05), 0 12px 32px -16px rgba(28,25,23,.14)
   - Gölge (hover): + 0 24px 56px -20px rgba(234,88,12,.18) ve translateY(-4px)
   - Easing: cubic-bezier(.22,.61,.36,1), süreler .25–.35s
   - Başlık: "Source Serif 4" / Gövde: Plus Jakarta Sans

   Bölümler:
     1. Mekan kartları         (.sec-place-card)
     2. Etkinlik satırları     (.ev / .ev-date / .ev-tag)
     3. Blog kartları          (.hero-post-card / .related-post-card)
     4. Mini mekan kartları    (.portal-place-mini)
     5. Tarih zaman çizelgesi  (.timeline / .tl-*)
     6. Haber rayı             (.portal-news-hero-rail-item)
     7. Filtre pilleri         (.filter-pill — yalnız rafine)
     8. prefers-reduced-motion
   ========================================================================== */


/* ============================================================================
   1. MEKAN KARTLARI — .sec-place-card
   Dergi kapağı yaklaşımı: 4/3 büyük görsel, alttan güçlü scrim, görselin
   üzerine binen beyaz yuvarlatılmış gövde paneli, cam efektli turuncu rozet,
   serif başlık, ikon hizalı tek satır meta.
   ========================================================================== */

.portal-root .sec-place-card {
  position: relative;
  display: block;
  overflow: hidden;
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 1.25rem;
  text-decoration: none;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14);
  transition:
    transform .3s cubic-bezier(.22, .61, .36, 1),
    box-shadow .3s cubic-bezier(.22, .61, .36, 1),
    border-color .3s cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

.portal-root .sec-place-card:hover {
  transform: translateY(-4px);
  border-color: #fdba74;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14),
    0 24px 56px -20px rgba(234, 88, 12, .18);
}

/* Görsel: büyük 4/3 sahne */
.portal-root .sec-place-card__img {
  aspect-ratio: 4 / 3;
  position: relative;
  overflow: hidden;
  background-color: #e7e5e4;
}

.portal-root .sec-place-card__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform .65s cubic-bezier(.22, .61, .36, 1);
}

.portal-root .sec-place-card:hover .sec-place-card__img img {
  transform: scale(1.06);
}

/* Alttan güçlü editoryal scrim — beyaz panel bindirmesinin zemini */
.portal-root .sec-place-card__img:after {
  content: "";
  pointer-events: none;
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(12, 10, 9, 0) 40%,
    rgba(12, 10, 9, .72) 100%
  );
}

/* Kategori rozeti: cam efektli turuncu chip (sol üst) */
.portal-root .sec-place-card__badge {
  position: absolute;
  top: .75rem;
  left: .75rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: .3rem .7rem;
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(234, 88, 12, .55);
  border: 1px solid rgba(255, 255, 255, .35);
  border-radius: 999px;
  -webkit-backdrop-filter: blur(10px) saturate(1.4);
  backdrop-filter: blur(10px) saturate(1.4);
  box-shadow: 0 2px 10px rgba(194, 65, 12, .35);
  text-shadow: 0 1px 2px rgba(0, 0, 0, .18);
}

/* Puan rozeti: kimliği koru, derinliği dengele */
.portal-root .sec-place-card__rating {
  top: .75rem;
  right: .75rem;
  z-index: 2;
  box-shadow: 0 2px 10px rgba(234, 88, 12, .4);
}

/* Gövde: görselin üzerine binen beyaz yuvarlatılmış panel */
.portal-root .sec-place-card__body {
  position: relative;
  z-index: 1;
  margin-top: -1.25rem;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  background: #fff;
  border-radius: 1.25rem 1.25rem 0 0;
  padding: 1.05rem 1.125rem 1.125rem;
}

/* Başlık: serif, dergi tonu */
.portal-root .sec-place-card__title {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: #1c1917;
}

/* Meta: ikon hizalı, tek satır ellipsis, soluk */
.portal-root .sec-place-card__meta {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  font-size: .8125rem;
  line-height: 1.45;
  color: #78716c;
}

.portal-root .sec-place-card__meta > span {
  min-width: 0; /* flex satırında ellipsis için gerekli */
}

.portal-root .sec-place-card__meta .meta-line-1,
.portal-root .sec-place-card__meta .meta-line-2 {
  display: block;
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

/* Mobil kontrol — mekan kartları */
@media (max-width: 640px) {
  .portal-root .sec-place-card__body {
    margin-top: -1rem;
    border-radius: 1rem 1rem 0 0;
    padding: .9rem 1rem 1rem;
  }
  .portal-root .sec-place-card__title {
    font-size: 1.05rem;
  }
  .portal-root .sec-place-card__badge {
    top: .6rem;
    left: .6rem;
  }
  .portal-root .sec-place-card__rating {
    top: .6rem;
    right: .6rem;
  }
}


/* ============================================================================
   2. ETKİNLİK SATIRLARI — .ev
   Tarih kutusu: turuncu gradyan takvim yaprağı (üstte ay bandı, altta beyaz
   rakam). Hover'da sol kenarda 3px turuncu çizgi belirir. .ev-tag chip olur.
   ========================================================================== */

.portal-root .ev {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 1.25rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14);
  transition:
    transform .3s cubic-bezier(.22, .61, .36, 1),
    box-shadow .3s cubic-bezier(.22, .61, .36, 1),
    border-color .3s cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

/* Sol kenar vurgu çizgisi (bundle'daki :before{display:none} ezilir) */
.portal-root .ev:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #f97316, #ea580c 55%, #c2410c);
  opacity: 0;
  transform: scaleY(.4);
  transform-origin: center;
  transition:
    opacity .3s cubic-bezier(.22, .61, .36, 1),
    transform .3s cubic-bezier(.22, .61, .36, 1);
}

.portal-root .ev:hover {
  transform: translateY(-3px);
  border-color: #fdba74;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14),
    0 24px 56px -20px rgba(234, 88, 12, .18);
}

.portal-root .ev:hover:before {
  opacity: 1;
  transform: scaleY(1);
}

/* Takvim yaprağı */
.portal-root .ev-date {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  align-self: center;
  text-align: center;
  padding: 0;
  border-right: 0;
  overflow: hidden;
  background: linear-gradient(160deg, #f97316, #ea580c 55%, #c2410c);
  border-radius: .9rem;
  box-shadow:
    0 8px 18px -8px rgba(234, 88, 12, .55),
    inset 0 1px 0 rgba(255, 255, 255, .28);
}

/* Üstte küçük ay bandı (DOM'da gün önce gelir; order ile üste alınır) */
.portal-root .ev-month {
  order: -1;
  margin-top: 0;
  padding: .3rem .25rem;
  font-size: .59rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(255, 255, 255, .18);
  border-bottom: 1px solid rgba(255, 255, 255, .22);
}

/* Beyaz rakam */
.portal-root .ev-day {
  padding: .45rem .25rem .55rem;
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1;
  color: #fff;
  text-shadow: 0 1px 2px rgba(120, 40, 0, .22);
  font-variant-numeric: tabular-nums;
}

/* Etiket: chip */
.portal-root .ev-tag {
  display: inline-flex;
  align-items: center;
  margin-bottom: .45rem;
  padding: .2rem .6rem;
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #c2410c;
  background: #ffedd5;
  border: 1px solid rgba(234, 88, 12, .16);
  border-radius: 999px;
}

.portal-root .ev-name {
  font-size: 1.0625rem;
  font-weight: 700;
  color: #1c1917;
  line-height: 1.35;
}

/* Mobil kontrol — etkinlik satırları (bundle ≤640px'te grid 4rem 1fr yapar) */
@media (max-width: 640px) {
  .portal-root .ev-date {
    border-radius: .75rem;
  }
  .portal-root .ev-day {
    font-size: 1.35rem;
    padding: .4rem .2rem .5rem;
  }
  .portal-root .ev-month {
    font-size: .55rem;
    letter-spacing: .1em;
  }
  .portal-root .ev-name {
    font-size: 1rem;
  }
}


/* ============================================================================
   3. BLOG KARTLARI — .hero-post-card / .related-post-card
   Üst kenarda ince turuncu gradyan şerit, tarih chip'i, serif başlık,
   "devamını oku" oku hover'da kayar. related-post-* bundle'da stilsizdi;
   burada tam takım tanımlanır.
   ========================================================================== */

.portal-root .hero-post-card,
.portal-root .related-post-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 1.25rem;
  text-decoration: none;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14);
  transition:
    transform .3s cubic-bezier(.22, .61, .36, 1),
    box-shadow .3s cubic-bezier(.22, .61, .36, 1),
    border-color .3s cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

.portal-root .hero-post-card:hover,
.portal-root .related-post-card:hover {
  transform: translateY(-4px);
  border-color: #fdba74;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 12px 32px -16px rgba(28, 25, 23, .14),
    0 24px 56px -20px rgba(234, 88, 12, .18);
}

/* Üst kenarda ince turuncu gradyan şerit
   (bundle'daki .hero-post-card:before{display:none} ezilir) */
.portal-root .hero-post-card:before,
.portal-root .related-post-card:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 2;
  background: linear-gradient(90deg, #fdba74, #ea580c 45%, #c2410c);
}

/* Kapak görselleri */
.portal-root .hero-post-img,
.portal-root .related-post-img {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background-color: #e7e5e4;
}

.portal-root .hero-post-img--placeholder {
  display: none; /* kapaksız yazıda boş blok bırakma */
}

.portal-root .hero-post-img img,
.portal-root .related-post-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform .65s cubic-bezier(.22, .61, .36, 1);
}

.portal-root .hero-post-card:hover .hero-post-img img,
.portal-root .related-post-card:hover .related-post-img img {
  transform: scale(1.05);
}

/* Gövdeler */
.portal-root .hero-post-body {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  padding: 1.2rem 1.35rem 1.35rem;
}

.portal-root .related-post-body {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  padding: 1.05rem 1.2rem 1.2rem;
}

/* Tarih: chip */
.portal-root .hero-post-date,
.portal-root .related-post-date {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: .22rem .65rem;
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #c2410c;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
}

/* Başlıklar: serif */
.portal-root .hero-post-heading {
  margin-top: .25rem;
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: #1c1917;
}

.portal-root .related-post-title {
  margin-top: .2rem;
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.32;
  letter-spacing: -.01em;
  color: #1c1917;
}

.portal-root .hero-post-summary,
.portal-root .related-post-summary {
  font-size: .875rem;
  line-height: 1.6;
  color: #78716c;
}

/* "Devamını oku" — ok hover'da kayar
   (related-post-card içinde de .hero-post-read kullanılır) */
.portal-root .hero-post-read {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: .5rem;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #ea580c;
}

.portal-root .hero-post-read:after {
  content: "→";
  display: inline-block;
  transition: transform .3s cubic-bezier(.22, .61, .36, 1);
}

.portal-root .hero-post-card:hover .hero-post-read:after,
.portal-root .related-post-card:hover .hero-post-read:after {
  transform: translateX(5px);
}

/* Mobil kontrol — blog kartları */
@media (max-width: 640px) {
  .portal-root .hero-post-body {
    padding: 1rem 1.1rem 1.15rem;
  }
  .portal-root .related-post-body {
    padding: .95rem 1.05rem 1.1rem;
  }
  .portal-root .hero-post-heading {
    font-size: 1.15rem;
  }
  .portal-root .related-post-title {
    font-size: 1rem;
  }
}


/* ============================================================================
   4. MİNİ MEKAN KARTLARI — .portal-place-mini
   Bundle'da seçiciler öneksiz; aynı formda yazılır (dosya sırası kazanır).
   Küçük ama rafine: yumuşak köşeli thumb, kategori micro-chip,
   hover'da #fff7ed zemin + görsel nefesi.
   ========================================================================== */

.portal-place-mini {
  position: relative;
  overflow: hidden;
  background-color: #fff;
  border: 1px solid #eceae7;
  border-radius: 1rem;
  box-shadow: 0 1px 2px rgba(28, 25, 23, .05);
  transition:
    transform .28s cubic-bezier(.22, .61, .36, 1),
    box-shadow .28s cubic-bezier(.22, .61, .36, 1),
    border-color .28s cubic-bezier(.22, .61, .36, 1),
    background-color .28s cubic-bezier(.22, .61, .36, 1);
}

.portal-place-mini:hover {
  transform: translateY(-2px);
  border-color: #fdba74;
  background-color: #fff7ed;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, .05),
    0 14px 32px -18px rgba(234, 88, 12, .22);
}

.portal-place-mini img {
  transition: transform .6s cubic-bezier(.22, .61, .36, 1);
}

.portal-place-mini:hover img {
  transform: scale(1.06);
}

.portal-place-mini-body {
  padding: .7rem .8rem .85rem;
  border-top: 1px solid #f5f5f4;
}

.portal-place-mini-title {
  font-size: .875rem;
  font-weight: 700;
  line-height: 1.35;
  color: #1c1917;
}

/* Kategori: micro-chip */
.portal-place-mini-cat {
  display: inline-flex;
  align-items: center;
  margin-top: .45rem;
  padding: .14rem .5rem;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #c2410c;
  background: #ffedd5;
  border-radius: 999px;
}

/* Mobil kontrol — mini kartlar */
@media (max-width: 640px) {
  .portal-place-mini-body {
    padding: .6rem .7rem .75rem;
  }
  .portal-place-mini-title {
    font-size: .8125rem;
  }
}


/* ============================================================================
   5. TARİH ZAMAN ÇİZELGESİ — .timeline / .tl-item / .tl-dot / .tl-era
   Çizgi turuncu gradyan, dot içi beyaz dışı turuncu halka (krem hâle),
   era etiketi chip, başlık serif.
   ========================================================================== */

.portal-root .timeline:before {
  width: 3px;
  left: .32rem;
  background: linear-gradient(
    180deg,
    #fdba74,
    #f97316 35%,
    #ea580c 70%,
    #c2410c
  );
  border-radius: 999px;
  box-shadow: 0 0 12px rgba(234, 88, 12, .22);
}

.portal-root .tl-dot {
  width: .85rem;
  height: .85rem;
  left: -1.5rem;
  top: .3rem;
  background: #fff;
  border: 3px solid #ea580c;
  border-radius: 50%;
  box-shadow:
    0 0 0 5px #ffedd5,
    0 2px 8px rgba(234, 88, 12, .3);
}

/* Era: chip */
.portal-root .tl-era {
  display: inline-flex;
  align-items: center;
  margin-bottom: .55rem;
  padding: .22rem .7rem;
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #c2410c;
  background: #ffedd5;
  border: 1px solid rgba(234, 88, 12, .16);
  border-radius: 999px;
}

/* Başlık: serif */
.portal-root .tl-title {
  margin-bottom: .5rem;
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: #1c1917;
}

.portal-root .tl-body {
  font-size: .9375rem;
  line-height: 1.7;
  color: #57534e;
  max-width: 40rem;
}

/* Mobil kontrol — zaman çizelgesi */
@media (max-width: 640px) {
  .portal-root .tl-item {
    padding-bottom: 2rem;
  }
  .portal-root .tl-title {
    font-size: 1.1rem;
  }
  .portal-root .tl-dot {
    box-shadow:
      0 0 0 4px #ffedd5,
      0 2px 6px rgba(234, 88, 12, .3);
  }
}


/* ============================================================================
   6. HABER RAYI — .portal-news-hero-rail-item
   Kırmızı kimlik (is-active) haber bölümüne ait — DOKUNULMAZ.
   Yalnız rafine: thumb köşeleri + hover'da hafif scale.
   Bundle seçicileri öneksiz; aynı formda yazılır.
   ========================================================================== */

.portal-news-hero-rail-thumb {
  border-radius: .45rem;
}

.portal-news-hero-rail-thumb img {
  transition: transform .35s cubic-bezier(.22, .61, .36, 1);
}

.portal-news-hero-rail-item:hover .portal-news-hero-rail-thumb img {
  transform: scale(1.06);
}

/* Mobil kontrol — haber rayı (dokunmatikte scale gereksiz, kapat) */
@media (max-width: 640px) {
  .portal-news-hero-rail-item:hover .portal-news-hero-rail-thumb img {
    transform: none;
  }
}


/* ============================================================================
   7. FİLTRE PİLLERİ — .filter-pill
   Aktif gradyan polish.css v4'te tanımlı — EZİLMEZ.
   Yalnız boyut/padding dengesi rafine edilir.
   ========================================================================== */

.portal-root .filter-pill {
  padding-inline: 1.05rem;
  line-height: 1;
  letter-spacing: .01em;
  white-space: nowrap;
}

/* Mobil kontrol — pil dizisi nefes payı */
@media (max-width: 640px) {
  .portal-root .filter-pill {
    padding-inline: .9rem;
    font-size: .78125rem;
  }
}


/* ============================================================================
   8. ERİŞİLEBİLİRLİK — prefers-reduced-motion
   Transform animasyonları kapatılır; renk/gölge geçişleri korunur.
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .portal-root .sec-place-card,
  .portal-root .sec-place-card__img img,
  .portal-root .ev,
  .portal-root .ev:before,
  .portal-root .hero-post-card,
  .portal-root .related-post-card,
  .portal-root .hero-post-img img,
  .portal-root .related-post-img img,
  .portal-root .hero-post-read:after,
  .portal-place-mini,
  .portal-place-mini img,
  .portal-news-hero-rail-thumb img {
    transition-property: color, background-color, border-color, box-shadow, opacity;
    will-change: auto;
  }

  .portal-root .sec-place-card:hover,
  .portal-root .ev:hover,
  .portal-root .hero-post-card:hover,
  .portal-root .related-post-card:hover,
  .portal-place-mini:hover {
    transform: none;
  }

  .portal-root .sec-place-card:hover .sec-place-card__img img,
  .portal-root .hero-post-card:hover .hero-post-img img,
  .portal-root .related-post-card:hover .related-post-img img,
  .portal-place-mini:hover img,
  .portal-news-hero-rail-item:hover .portal-news-hero-rail-thumb img,
  .portal-root .hero-post-card:hover .hero-post-read:after,
  .portal-root .related-post-card:hover .hero-post-read:after {
    transform: none;
  }

  .portal-root .ev:hover:before {
    transform: scaleY(1); /* çizgi animasyonsuz, anında görünür */
  }
}

/* === redesign-home.css === */
/* ============================================================
   diyarbakr.com — redesign-home.css
   ANA SAYFA hero-altı dönüşümü (10 Haziran 2026)
   Kapsam: BÖLÜM / KAPSAYICI / DASHBOARD seviyesi.
   Tekil kart içleri (sec-place-card, ev, ...) BAŞKA katmanda.
   polish.css ve bundle CSS'ten SONRA yüklenmelidir; mevcut
   kurallar ezilmez, yalnızca kapsayıcı düzeyinde derinleştirilir.
   Ortak dil: turuncu #ea580c / #c2410c, tonlar #fff7ed/#ffedd5/
   #fdba74; stone #1c1917/#57534e/#78716c; köşe 1.25rem & 999px;
   easing cubic-bezier(.22,.61,.36,1).
   ============================================================ */

/* ------------------------------------------------------------
   1. BOŞ BÖLÜM GİZLEME (kritik)
   İçerik kapsayıcıları (JSX'lerden doğrulandı):
     PlacesSection  → .sec-grid
     EventsSection  → .ev-list
     HistorySection → .timeline
   Geçici durumlar görünür kalır: .section-loading / .section-error
   Yalnızca .section-empty kalan bölümler (örn. Blog bandı,
   data.length === 0) tamamen gizlenir. Üst sarmalayıcı bant
   (div.bg-white / div.bg-stone-50\/60) da birlikte kapanır.
   :has desteklemeyen eski tarayıcılar kuralı yok sayar (güvenli). */
.portal-explore-wrap .sec:not(:has(.sec-grid, .ev-list, .timeline, .section-loading, .section-error)) {
  display: none;
}
.portal-explore-wrap > div:has(> .sec):not(:has(.sec-grid, .ev-list, .timeline, .section-loading, .section-error)) {
  display: none;
}

/* ------------------------------------------------------------
   2. DASHBOARD → ŞEHİR KONTROL PANELİ
   ------------------------------------------------------------ */

/* 2a. Zone: beyazdan sıcak tona inen degrade + üst kenarda geniş,
   yumuşak iç gölge → hero'dan ayrışan "panel" hissi. */
.portal-root .portal-dashboard-zone {
  background-color: #faf8f5;
  background-image: linear-gradient(180deg, #ffffff 0%, #faf8f5 100%);
  box-shadow:
    inset 0 1px 0 rgba(231, 229, 228, 0.9),
    inset 0 26px 40px -32px rgba(28, 25, 23, 0.10);
}

/* 2b. Kartlar: ortak dinlenme gölgesi (tasarım dili) — polish'in
   degrade zemini ve hover'ı korunur, yalnızca derinlik eklenir. */
.portal-root .portal-dash-card {
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}
/* Hover derinleşmesi korunur (polish §10 ile uyumlu, üstüne yazmaz) */
.portal-root .portal-dash-card:hover {
  box-shadow:
    0 2px 4px rgba(28, 25, 23, 0.06),
    0 18px 44px -18px rgba(28, 25, 23, 0.18);
}

/* 2c. Servis başlıkları: kategoriye özel renk şeritleri (emerald/
   amber/orange) yerine TEK marka dili — üst-sol köşede yumuşak
   turuncu rozet + emoji ikon. */
.portal-dash-card .portal-dash-card-title.portal-service-title {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  background: #fff7ed;
  color: #9a3412;
  border: 1px solid #ffedd5;
  border-radius: 0.8rem;
  padding: 0.3rem 0.8rem 0.3rem 0.35rem;
}
.portal-dash-card .portal-service-title--pharmacy,
.portal-dash-card .portal-service-title--taxi,
.portal-dash-card .portal-service-title--bus {
  background: #fff7ed;
  color: #9a3412;
}
.portal-dash-card .portal-dash-card-title.portal-service-title::before {
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  border-radius: 0.625rem;
  background: #ffedd5;
  font-size: 1.05rem;
  line-height: 1;
}
.portal-dash-card .portal-service-title--pharmacy::before { content: "💊"; }
.portal-dash-card .portal-service-title--taxi::before     { content: "🚕"; }
.portal-dash-card .portal-service-title--bus::before      { content: "🚌"; }

/* 2d. Liste satırları: ince ayraçlar + hover zemini. Negatif
   margin ile hover dolgusu kart kenarına doğru nefes alır. */
.portal-dash-card .portal-list-row {
  border-bottom-color: #f5f5f4;
  padding-inline: 0.5rem;
  margin-inline: -0.5rem;
  border-radius: 0.625rem;
  transition: background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-dash-card .portal-list-row:hover {
  background-color: #fafaf9;
}

/* 2e. Telefon / numara değerleri: hizalı rakamlar + marka turuncusu
   (taksi kartında numara .portal-btn-call içinde yazılıdır). */
.portal-dash-card .portal-btn-call {
  font-variant-numeric: tabular-nums;
  color: #c2410c;
}

/* 2f. "Tümünü gör" → turuncu kenarlı pill buton. */
.portal-dash-card .portal-dash-link {
  display: inline-flex;
  align-items: center;
  border: 1px solid #fdba74;
  border-radius: 999px;
  background: #ffffff;
  padding: 0.4rem 0.85rem;
  color: #c2410c;
  font-size: 10.5px;
  line-height: 1;
  transition:
    background-color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-dash-card .portal-dash-link:hover {
  background-color: #fff7ed;
  border-color: #fb923c;
  color: #9a3412;
}

/* ------------------------------------------------------------
   3. KEŞFET BAŞLIK ALANI — ortalanmış, büyütülmüş giriş
   ------------------------------------------------------------ */
.portal-explore-wrap .portal-explore-head {
  text-align: center;
  padding-block: 4.25rem 3.5rem;
}
.portal-explore-wrap .portal-explore-head .portal-overline {
  font-size: 0.75rem;
}
.portal-explore-wrap .portal-explore-head .portal-section-title {
  font-size: clamp(2rem, 1.4rem + 2vw, 2.75rem);
  line-height: 1.12;
}
/* Başlığın altında turuncu gradyan divider */
.portal-explore-wrap .portal-explore-head .portal-section-title::after {
  content: "";
  display: block;
  width: 4rem;
  height: 3px;
  margin: 1.1rem auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #ea580c, #fdba74);
}
/* Açıklama metni: ortalanmış, sınırlı genişlik */
.portal-explore-wrap .portal-explore-head p {
  margin-inline: auto;
}

/* ------------------------------------------------------------
   4. BÖLÜM BANTLARI RİTMİ
   ------------------------------------------------------------ */

/* 4a. Gri bantlar: sıcak ton + üst/alt ince iç çizgilerle
   "bant" hissi (CSS escape: bg-stone-50\/60). */
.portal-explore-wrap > .bg-stone-50\/60 {
  background-color: #faf8f5;
  box-shadow:
    inset 0 1px 0 rgba(231, 229, 228, 0.85),
    inset 0 -1px 0 rgba(231, 229, 228, 0.85);
}

/* 4b. "Tümünü Gör" → belirgin turuncu kenarlı pill
   (polish'teki kalkış/gölge hover'ı aynen korunur). */
.portal-explore-wrap .btn-view-all {
  border-color: #fdba74;
  color: #c2410c;
  background: #ffffff;
}
.portal-explore-wrap .btn-view-all:hover {
  border-color: #fb923c;
  background: #fff7ed;
  color: #9a3412;
}

/* ------------------------------------------------------------
   5. .SEC-GRID YOĞUNLUĞU + GENİŞ EKRAN
   ------------------------------------------------------------ */
.portal-root .portal-explore-wrap .sec-grid {
  gap: 1.25rem;
}
/* ≥1536px: keşfet bölümleri 80rem → 88rem; başlık bandı da
   aynı genişliğe taşınır ki alt çizgisi gridlerle hizalansın. */
@media (min-width: 1536px) {
  .portal-explore-wrap .sec,
  .portal-explore-wrap .portal-explore-head {
    max-width: 88rem;
  }
}

/* ------------------------------------------------------------
   6. QUICK-NAV — kart-tile hissi (polish v4 üzerine bir kademe)
   Transform (translateY) polish'ten gelir; burada yalnızca
   zemin ve ikon dolgusu derinleştirilir.
   ------------------------------------------------------------ */
.portal-quick-nav .portal-quick-nav-item:hover {
  background-color: #fff7ed;
}
.portal-quick-nav .portal-quick-nav-item:hover .portal-quick-nav-icon {
  background: #ea580c;
  border-color: #ea580c;
  color: #ffffff;
}
.portal-quick-nav .portal-quick-nav-item:hover .portal-quick-nav-label {
  color: #9a3412;
}

/* ------------------------------------------------------------
   7. MOBİL DENGE (≤640px)
   Dashboard zaten tek kolon — düzene dokunulmaz; yalnızca
   başlık alanının dikey ritmi sıkılaştırılır.
   ------------------------------------------------------------ */
@media (max-width: 640px) {
  .portal-explore-wrap .portal-explore-head {
    padding-block: 3rem 2.5rem;
  }
  .portal-dash-card .portal-list-row {
    padding-inline: 0.375rem;
    margin-inline: -0.375rem;
  }
}

/* ------------------------------------------------------------
   8. HAREKET AZALTMA (EN SONDA)
   ------------------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
  .portal-dash-card .portal-list-row,
  .portal-dash-card .portal-dash-link,
  .portal-explore-wrap .btn-view-all,
  .portal-quick-nav .portal-quick-nav-item,
  .portal-quick-nav .portal-quick-nav-icon {
    transition-duration: 0.01ms !important;
  }
}

/* === redesign-pages.css === */
/* ==========================================================================
   diyarbakr.com — redesign-pages.css
   İç sayfa iskeletleri + sayfaya özgü bileşenler (şehir hizmetleri & içerik)
   Kapsam: /nobetci-eczaneler, /otobus-saatleri(+/:slug), /taksi-duraklari,
           /harita, /iletisim, /mekan/:slug, /blog/:slug, /tarih, /ara,
           404, dynamic-page-prose (+ :slug içerik sayfaları)
   Tasarım dili: turuncu #ea580c / #c2410c, tonlar #fff7ed/#ffedd5/#fdba74,
   stone #1c1917/#57534e/#78716c, zemin #f4f4f3, köşe 1.25rem / chip 999px,
   başlık "Source Serif 4", easing cubic-bezier(.22,.61,.36,1).
   NOT: liste kartlarının iç tasarımı (sec-place-card, ev, blog kartları)
   başka dosyanın işi — burada sayfa iskeletleri var.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1) HİZMET SAYFASI KABUĞU — breadcrumb / overline / servis başlığı /
      filtre pilleri / meta bar  (nöbetçi eczane, taksi, otobüs)
   -------------------------------------------------------------------------- */

.portal-root .portal-breadcrumb {
  font-size: 0.8125rem;
  gap: 0.55rem;
  margin-bottom: 1.6rem;
}
.portal-root .portal-breadcrumb a {
  color: #57534e;
  transition: color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .portal-breadcrumb a:hover {
  color: #c2410c;
}
.portal-root .portal-breadcrumb span {
  color: #d6d3d1;
}
.portal-root .portal-breadcrumb span.text-slate-700 {
  color: #44403c;
  font-weight: 600;
}

.portal-root .portal-overline {
  color: #c2410c;
  letter-spacing: 0.16em;
}

/* Servis başlığı blokları — kimlik rengi korunur, marka diline rafine edilir */
.portal-root .portal-service-title {
  border-radius: 0.9rem;
  padding-inline: 1rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}
.portal-root .portal-service-title--pharmacy {
  background: linear-gradient(135deg, #10b981, #047857);
  box-shadow: 0 10px 24px -12px rgba(5, 150, 105, 0.55);
}
.portal-root .portal-service-title--taxi {
  background: linear-gradient(135deg, #fcd34d, #f59e0b);
  color: #451a03;
  box-shadow: 0 10px 24px -12px rgba(217, 119, 6, 0.5);
}
.portal-root .portal-service-title--bus {
  background: linear-gradient(135deg, #f97316, #c2410c);
  box-shadow: 0 10px 24px -12px rgba(234, 88, 12, 0.55);
}

/* İlçe filtre pilleri — aktif durum marka turuncusu */
.portal-root .portal-pill {
  border-radius: 999px;
  transition:
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .portal-pill:hover {
  border-color: #fdba74;
  background-color: #fff7ed;
  color: #9a3412;
}
.portal-root .portal-pill-active,
.portal-root .portal-pill-active:hover {
  background: linear-gradient(135deg, #f97316, #ea580c);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 12px rgba(234, 88, 12, 0.19);
}

/* İlçe grup başlıkları → chip-başlık (servis sayfalarında) */
.portal-root .portal-container:has(.portal-service-title--pharmacy) section h2.portal-section-title,
.portal-root .portal-container:has(.portal-service-title--taxi) section h2.portal-section-title,
.portal-root .portal-container:has(.portal-service-title--bus) section h2.portal-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #44403c;
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 999px;
  padding: 0.45rem 1.1rem 0.45rem 0.85rem;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
}
.portal-root .portal-container:has(.portal-service-title--pharmacy) section h2.portal-section-title::before,
.portal-root .portal-container:has(.portal-service-title--taxi) section h2.portal-section-title::before,
.portal-root .portal-container:has(.portal-service-title--bus) section h2.portal-section-title::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  flex: none;
  background: #ea580c;
}
.portal-root .portal-container:has(.portal-service-title--pharmacy) section h2.portal-section-title::before {
  background: #10b981;
}
.portal-root .portal-container:has(.portal-service-title--taxi) section h2.portal-section-title::before {
  background: #f59e0b;
}

/* Kaynak / güncelleme meta barı — chip'li görünüm */
.portal-root .portal-meta-bar {
  margin-top: 2.5rem;
  background: #fff;
  border-color: #eceae7;
  border-radius: 1rem;
  padding: 0.85rem 1.1rem;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
}
.portal-root .portal-meta-bar > div:first-child > span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: #fafaf9;
  border: 1px solid #e7e5e4;
  border-radius: 999px;
  padding: 0.32rem 0.8rem;
  color: #57534e;
  font-variant-numeric: tabular-nums;
}
.portal-root .portal-meta-bar a {
  color: #c2410c;
}
.portal-root .portal-meta-bar a:hover {
  color: #9a3412;
}
.portal-root .portal-meta-bar button {
  border: 1px solid #e7e5e4;
  border-radius: 999px;
  padding: 0.32rem 0.85rem;
  background: #fff;
  transition:
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .portal-meta-bar button:hover {
  border-color: #fdba74;
  background: #fff7ed;
  color: #9a3412;
}

/* İlçe rozetleri (kart içi) */
.portal-root .portal-badge {
  border-radius: 999px;
  padding-inline: 0.6rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #57534e;
}

/* --------------------------------------------------------------------------
   2) NÖBETÇİ ECZANELER + TAKSİ DURAKLARI — kayıt kartları
      (article.portal-card: solda ikon rozeti, ad koyu, ilçe chip, tel turuncu)
   -------------------------------------------------------------------------- */

.portal-root article.portal-card {
  position: relative;
  border-radius: 1.25rem;
  border-color: #eceae7;
  padding: 1.05rem 1.2rem;
  justify-content: flex-start;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
  transition:
    border-color 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root article.portal-card:hover {
  border-color: #fdba74;
  transform: translateY(-2px);
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.06),
    0 16px 40px -18px rgba(28, 25, 23, 0.2),
    0 20px 48px rgba(234, 88, 12, 0.08);
}
.portal-root article.portal-card h2 {
  color: #1c1917;
  font-size: 1.0625rem;
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin-top: 0.45rem;
}
.portal-root article.portal-card p {
  color: #78716c;
  line-height: 1.55;
}

/* Sol ikon rozeti — sayfaya göre eczane / taksi */
.portal-root .portal-container:has(.portal-service-title--pharmacy) article.portal-card::before,
.portal-root .portal-container:has(.portal-service-title--taxi) article.portal-card::before {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  flex: none;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 1rem;
  font-size: 1.25rem;
  line-height: 1;
}
.portal-root .portal-container:has(.portal-service-title--pharmacy) article.portal-card::before {
  content: "💊";
  background: linear-gradient(135deg, #ecfdf5, #d1fae5);
  border: 1px solid #a7f3d0;
}
.portal-root .portal-container:has(.portal-service-title--taxi) article.portal-card::before {
  content: "🚕";
  background: linear-gradient(135deg, #fffbeb, #fef3c7);
  border: 1px solid #fde68a;
}
.portal-root .portal-container:has(.portal-service-title--pharmacy) article.portal-card .portal-badge {
  border-color: #a7f3d0;
  background: #ecfdf5;
  color: #047857;
}
.portal-root .portal-container:has(.portal-service-title--taxi) article.portal-card .portal-badge {
  border-color: #fde68a;
  background: #fffbeb;
  color: #92400e;
}

/* Telefon — turuncu, tıklanabilir his, tabular-nums */
.portal-root .portal-btn-call {
  margin-left: auto;
  border-radius: 999px;
  border-color: #fed7aa;
  background: #fff7ed;
  color: #c2410c;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  padding: 0.55rem 1.05rem;
  transition:
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .portal-btn-call:hover {
  background: #ffedd5;
  border-color: #fdba74;
  color: #9a3412;
  box-shadow: 0 6px 16px -8px rgba(234, 88, 12, 0.45);
}
.portal-root .portal-btn-call:active {
  transform: scale(0.97);
}

/* --------------------------------------------------------------------------
   3) OTOBÜS SAATLERİ — hat kartları, hat numarası rozeti, saat chip'leri
   -------------------------------------------------------------------------- */

.portal-root a.portal-card {
  border-radius: 1.25rem;
  border-color: #eceae7;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}
.portal-root a.portal-card.portal-card-hover:hover {
  border-color: #fdba74;
  transform: translateY(-3px);
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.06),
    0 8px 24px rgba(28, 25, 23, 0.1),
    0 20px 48px rgba(234, 88, 12, 0.08);
}
.portal-root a.portal-card h2 {
  color: #1c1917;
  letter-spacing: -0.01em;
}
.portal-root a.portal-card p {
  color: #78716c;
}

/* Hat kodu rozeti — turuncu degrade, tabular */
.portal-root a.portal-card .bg-orange-600 {
  background-image: linear-gradient(135deg, #f97316, #c2410c);
  border-radius: 0.8rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
  box-shadow: 0 6px 14px -6px rgba(234, 88, 12, 0.55);
}

/* Hat detayı — durak ve sefer kartları */
.portal-root div.portal-card {
  border-radius: 1.25rem;
  border-color: #eceae7;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}
.portal-root div.portal-card h3 {
  letter-spacing: 0.02em;
}
.portal-root div.portal-card p {
  line-height: 1.7;
}

/* Saat chip'leri — tabular, eşit genişlik, hover */
.portal-root .portal-card .bg-orange-50 {
  display: inline-flex;
  justify-content: center;
  min-width: 3.5rem;
  border-radius: 0.65rem;
  font-variant-numeric: tabular-nums;
  transition:
    background-color 0.15s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.15s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .portal-card .bg-orange-50:hover {
  background-color: #ffedd5;
  box-shadow: 0 3px 8px -3px rgba(234, 88, 12, 0.35);
}

/* --------------------------------------------------------------------------
   4) HARİTA — iframe/leaflet çerçevesi + harita listesi satırları
   -------------------------------------------------------------------------- */

.portal-root .map-wrap {
  border-radius: 1.25rem;
  border-color: #eceae7;
  background: #fff;
  padding: 0.45rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}
.portal-root .map-wrap .map-container {
  border-radius: 0.9rem;
}

.portal-root .map-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.portal-root .map-list-item {
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 1rem;
  padding: 0.85rem 1.15rem;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
  transition:
    border-color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .map-list-item:hover {
  border-color: #fdba74;
  transform: translateY(-1px);
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.18);
}
.portal-root .map-list-map-link {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 0.35rem 0.8rem;
  transition:
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .map-list-map-link:hover {
  background: #ffedd5;
  border-color: #fdba74;
}

/* --------------------------------------------------------------------------
   5) İLETİŞİM — etiket/link bloklarının kartlaştırılması
   -------------------------------------------------------------------------- */

.portal-root .contact-block {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-width: 28rem;
  background: #fff;
  border: 1px solid #eceae7;
  border-radius: 1.25rem;
  padding: 1.4rem 1.6rem 1.4rem 4.9rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
  transition:
    border-color 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.22s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .contact-block::before {
  content: "✉";
  position: absolute;
  left: 1.35rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 0.9rem;
  font-size: 1.2rem;
  line-height: 1;
  color: #c2410c;
  background: linear-gradient(135deg, #fff7ed, #ffedd5);
  border: 1px solid #fed7aa;
}
.portal-root .contact-block:hover {
  border-color: #fdba74;
  transform: translateY(-2px);
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.06),
    0 16px 40px -18px rgba(28, 25, 23, 0.2),
    0 20px 48px rgba(234, 88, 12, 0.08);
}
.portal-root .contact-label {
  letter-spacing: 0.14em;
}
.portal-root .contact-link {
  transition: color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* --------------------------------------------------------------------------
   6) DETAY SAYFALARI (mekan/:slug, blog/:slug, :slug içerik) —
      koyu kart kabuğunun marka diline (açık zemin) dönüştürülmesi
   -------------------------------------------------------------------------- */

/* Geri dön pili (kartın üstünde) */
.portal-root .sec a.rounded-full.bg-white\/5 {
  background: #fff;
  border-color: #e7e5e4;
  color: #57534e;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
  transition:
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .sec a.rounded-full.bg-white\/5:hover {
  background: #fff7ed;
  border-color: #fdba74;
  color: #c2410c;
}

/* Kart kabuğu: koyu → beyaz kart */
.portal-root .bg-\[\#141414\] {
  background-color: #fff;
  border-color: #eceae7;
  border-radius: 1.25rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
}

/* Başlık: büyük serif, koyu */
.portal-root .bg-\[\#141414\] h1 {
  font-family: "Source Serif 4", Georgia, serif;
  color: #1c1917;
  letter-spacing: -0.02em;
  font-size: clamp(1.65rem, 3.4vw, 2.5rem);
  line-height: 1.15;
}

/* İç paneller / chip zeminleri */
.portal-root .bg-\[\#141414\] .bg-white\/5 {
  background-color: #fafaf9;
}
.portal-root .bg-\[\#141414\] .border-white\/10 {
  border-color: #eceae7;
}
.portal-root .bg-\[\#141414\] .border-white\/\[\.06\] {
  border-color: #f0efed;
}

/* Metin tonları: beyaz → stone */
.portal-root .bg-\[\#141414\] .text-white\/85 {
  color: #44403c;
}
.portal-root .bg-\[\#141414\] .text-white\/70 {
  color: #57534e;
}
.portal-root .bg-\[\#141414\] .text-white\/55 {
  color: #57534e;
}
.portal-root .bg-\[\#141414\] .text-white\/40 {
  color: #78716c;
}
.portal-root .bg-\[\#141414\] .text-white\/30,
.portal-root .bg-\[\#141414\] .text-white\/25 {
  color: #a8a29e;
}

/* Amber vurgular → marka turuncusu */
.portal-root .bg-\[\#141414\] .bg-amber-500\/10 {
  background-color: #fff7ed;
}
.portal-root .bg-\[\#141414\] .border-amber-500\/25,
.portal-root .bg-\[\#141414\] .border-amber-500\/20 {
  border-color: #fed7aa;
}
.portal-root .bg-\[\#141414\] .text-amber-200 {
  color: #9a3412;
}
.portal-root .bg-\[\#141414\] .text-amber-400 {
  color: #c2410c;
}
.portal-root .bg-\[\#141414\] .text-amber-400\/60 {
  color: #b45309;
}
.portal-root .bg-\[\#141414\] .text-amber-500\/80 {
  color: #ea580c;
}
.portal-root .bg-\[\#141414\] .hover\:text-amber-400:hover {
  color: #9a3412;
}
.portal-root .bg-\[\#141414\] .hover\:bg-amber-500\/15:hover {
  background-color: #ffedd5;
}

/* :slug içerik sayfası başlık şeridi: koyu degrade → krem degrade */
.portal-root .bg-\[\#141414\] .via-\[\#1a1a1a\] {
  background-image: linear-gradient(150deg, #fff7ed 0%, #fffdfa 55%, #ffffff 100%);
}

/* Görsel yoksa kapak placeholder'ı: koyu → turuncu tonlar */
.portal-root .bg-\[\#141414\] .from-\[\#2a2a2a\] {
  background-image: linear-gradient(135deg, #ffedd5, #fdba74);
}

/* GALERİ (mekan detayı) — 2/3 kolon, yumuşak köşe, hover zoom korunur */
.portal-root .bg-\[\#141414\] h2.text-white\/80 {
  color: #9a3412;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.portal-root .bg-\[\#141414\] .grid-cols-2 > a {
  background: #f5f5f4;
  border-color: #eceae7;
  border-radius: 1rem;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
  transition:
    border-color 0.25s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.25s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.25s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .bg-\[\#141414\] .grid-cols-2 > a:hover {
  border-color: #fdba74;
  transform: translateY(-2px);
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.06),
    0 14px 36px -16px rgba(28, 25, 23, 0.24);
}
.portal-root .bg-\[\#141414\] .grid-cols-2 > a img {
  height: 11rem;
}
@media (min-width: 768px) {
  .portal-root .bg-\[\#141414\] .grid-cols-2.md\:grid-cols-4 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* --------------------------------------------------------------------------
   7) /TARİH — zaman çizelgesi sayfa iskeleti
      (timeline iç kart tasarımı başka dosyada; burada zemin/genişlik)
   -------------------------------------------------------------------------- */

.portal-root .sec#tarih .filter-pills {
  margin-bottom: 2.25rem;
}
.portal-root .sec#tarih .timeline {
  max-width: 48rem;
}
.portal-root .sec#tarih .section-empty {
  background: #fff;
  border: 1px dashed #e7e5e4;
  border-radius: 1.25rem;
}

/* --------------------------------------------------------------------------
   8) /ARA — sonuç sayacı + sonuç grupları düzeni
   -------------------------------------------------------------------------- */

.portal-root .search-result-count {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #9a3412;
  border-radius: 999px;
  padding: 0.4rem 1rem;
  font-size: 0.8125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  margin: 0.75rem 0 0.25rem;
}
.portal-root .search-result-count::before {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: #ea580c;
  flex: none;
}
.portal-root .search-result-group {
  border-top: 1px dashed #e7e5e4;
  padding-top: 1.75rem;
}
.portal-root .search-result-group .places-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.1rem;
  align-items: stretch;
}

/* --------------------------------------------------------------------------
   9) 404 — degrade kod, marka pill butonları
   -------------------------------------------------------------------------- */

.portal-root .not-found-code {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(5rem, 16vw, 7.5rem);
  letter-spacing: -0.04em;
  color: #ea580c; /* fallback */
  background: linear-gradient(135deg, #fdba74 0%, #ea580c 45%, #c2410c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.portal-root .not-found-title {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.75rem;
  letter-spacing: -0.02em;
}
.portal-root .not-found-desc {
  max-width: 34rem;
}
.portal-root .not-found-btn {
  border-radius: 999px;
  padding: 0.8rem 1.7rem;
  background: linear-gradient(135deg, #f97316, #ea580c);
  border-color: transparent;
  box-shadow: 0 10px 24px -10px rgba(234, 88, 12, 0.6);
  transition:
    transform 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    background-color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .not-found-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px -10px rgba(234, 88, 12, 0.7);
}
.portal-root .not-found-btn--outline {
  background: #fff;
  border-color: #e7e5e4;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
}
.portal-root .not-found-btn--outline:hover {
  border-color: #fdba74;
  background: #fff7ed;
  color: #c2410c;
  box-shadow: 0 10px 24px -12px rgba(234, 88, 12, 0.35);
}

/* --------------------------------------------------------------------------
   10) DYNAMIC-PAGE-PROSE — içerik tipografisi (Kafeler vb. sayfalar)
       blockquote stili bundle'da korunur, burada dokunulmaz
   -------------------------------------------------------------------------- */

.portal-root .dynamic-page-prose {
  max-width: 65ch;
  line-height: 1.85;
}
.portal-root .dynamic-page-prose h2 {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.3;
  position: relative;
  padding-bottom: 0.55rem;
  margin-top: 2.4rem;
}
.portal-root .dynamic-page-prose h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 3rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ea580c, #fdba74);
}
.portal-root .dynamic-page-prose h3 {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
}
.portal-root .dynamic-page-prose p {
  margin: 0 0 1.15rem;
}
.portal-root .dynamic-page-prose a {
  color: #c2410c;
  font-weight: 600;
  text-decoration-color: #fdba74;
  transition: color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .dynamic-page-prose a:hover {
  color: #9a3412;
}
.portal-root .dynamic-page-prose ul {
  list-style: disc;
  padding-left: 1.4rem;
  margin: 0 0 1.25rem;
}
.portal-root .dynamic-page-prose ol {
  list-style: decimal;
  padding-left: 1.4rem;
  margin: 0 0 1.25rem;
}
.portal-root .dynamic-page-prose li {
  margin: 0.4rem 0;
}
.portal-root .dynamic-page-prose li::marker {
  color: #ea580c;
}
.portal-root .dynamic-page-prose img {
  border-radius: 1rem;
  margin: 1.4rem 0;
}
.portal-root .dynamic-page-prose hr {
  border: 0;
  border-top: 1px solid #e7e5e4;
  margin: 2rem 0;
}
.portal-root .dynamic-page-prose table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  margin: 1.4rem 0;
}
.portal-root .dynamic-page-prose th {
  text-align: left;
  font-weight: 700;
  color: #1c1917;
  background: #fff7ed;
  border-bottom: 2px solid #fdba74;
  padding: 0.6rem 0.85rem;
}
.portal-root .dynamic-page-prose td {
  padding: 0.6rem 0.85rem;
  border-bottom: 1px solid #f0efed;
}
.portal-root .dynamic-page-prose tr:nth-child(2n) td {
  background: #fafaf9;
}

/* Dinamik sayfa hata/geri dönüş bağlantısı */
.portal-root .dynamic-page-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: linear-gradient(135deg, #f97316, #ea580c);
  color: #fff;
  border-radius: 999px;
  padding: 0.7rem 1.5rem;
  font-size: 0.8125rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 10px 24px -10px rgba(234, 88, 12, 0.6);
  transition: transform 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .dynamic-page-back-link:hover {
  transform: translateY(-2px);
}

/* --------------------------------------------------------------------------
   11) MOBİL KONTROL
   -------------------------------------------------------------------------- */

@media (max-width: 640px) {
  .portal-root .portal-service-title {
    font-size: 1.25rem;
    padding-inline: 0.8rem;
  }
  .portal-root article.portal-card {
    padding: 0.95rem 1rem;
  }
  .portal-root .portal-container:has(.portal-service-title--pharmacy) article.portal-card::before,
  .portal-root .portal-container:has(.portal-service-title--taxi) article.portal-card::before {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.8rem;
    font-size: 1.05rem;
  }
  /* Tam genislik yalnizca servis sayfasi kartlarinda (eczane/taksi listeleri);
     ana sayfa paneli (.portal-dash-card) ve diger satirlar kompakt kalir */
  .portal-root article.portal-card .portal-btn-call {
    margin-left: 0;
    width: 100%;
    justify-content: center;
    display: inline-flex;
    text-align: center;
  }
  .portal-root .portal-dash-card .portal-btn-call {
    width: auto;
    margin-left: auto;
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .portal-root .map-wrap {
    padding: 0.3rem;
    border-radius: 1rem;
  }
  .portal-root .map-list-item {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .portal-root .contact-block {
    padding: 1.2rem 1.25rem 1.2rem 4.35rem;
  }
  .portal-root .contact-block::before {
    left: 1.05rem;
    width: 2.35rem;
    height: 2.35rem;
  }
  .portal-root .bg-\[\#141414\] .grid-cols-2 > a img {
    height: 8.5rem;
  }
  .portal-root .search-result-group .places-grid {
    grid-template-columns: 1fr;
  }
  .portal-root .portal-meta-bar {
    padding: 0.75rem 0.9rem;
  }
  .portal-root .portal-meta-bar button {
    margin-left: 0;
  }
}

/* --------------------------------------------------------------------------
   12) HAREKET AZALTMA
   -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .portal-root .portal-pill,
  .portal-root .portal-btn-call,
  .portal-root .portal-meta-bar button,
  .portal-root article.portal-card,
  .portal-root a.portal-card,
  .portal-root .portal-card .bg-orange-50,
  .portal-root .map-list-item,
  .portal-root .map-list-map-link,
  .portal-root .contact-block,
  .portal-root .sec a.rounded-full.bg-white\/5,
  .portal-root .bg-\[\#141414\] .grid-cols-2 > a,
  .portal-root .not-found-btn,
  .portal-root .dynamic-page-back-link,
  .portal-root .dynamic-page-prose a,
  .portal-root .contact-link {
    transition: none !important;
  }
  .portal-root article.portal-card:hover,
  .portal-root a.portal-card.portal-card-hover:hover,
  .portal-root .map-list-item:hover,
  .portal-root .contact-block:hover,
  .portal-root .bg-\[\#141414\] .grid-cols-2 > a:hover,
  .portal-root .not-found-btn:hover,
  .portal-root .dynamic-page-back-link:hover {
    transform: none !important;
  }
  .portal-root .portal-btn-call:active {
    transform: none !important;
  }
}

/* === redesign-nav-density.css === */
/* redesign-nav-density.css — 11 ogeli masaustu navbar icin boyut/yogunluk ayari.
 * polish.css v4 nav gorselini (uppercase, ::after cizgi, renkler) EZMEZ;
 * yalnizca olcu kisar ve tasma durumunda yatay kaydirma saglar.
 * Bundle taban degerleri (assets/index-D3If5UAG.js + es bundle CSS):
 *   .portal-nav-link: font-size 13px, padding-inline calc(var(--spacing)*2.5) = .625rem
 *   nav kapsayici: <nav class="ml-auto hidden shrink-0 items-center lg:flex"> (.portal-header-bar icinde)
 * Secimler ".portal-header-bar nav" ile kapsandigindan hem yuksek ozgulluk
 * (yukleme sirasindan bagimsiz polish.css'i gecer) hem de mobil panel etkilenmez. */

@media (min-width: 1024px) {
  /* 1. Tasma sigortasi: bundle'daki shrink-0'i esnetip kapsayiciyi
     yatay kaydirilabilir yap (modern scrollable-nav deseni), scrollbar gizli. */
  .portal-header-bar nav {
    flex-shrink: 1;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;        /* Firefox */
    -ms-overflow-style: none;     /* eski Edge/IE */
  }
  .portal-header-bar nav::-webkit-scrollbar {
    display: none;                /* WebKit/Blink */
    width: 0;
    height: 0;
  }
  /* Kaydirma sirasinda ogeler ezilmesin/sarmasin. */
  .portal-header-bar nav > * {
    flex: 0 0 auto;
  }

  /* 2. Link yogunlugu: 13px -> 11.5px; padding-inline .625rem -> .469rem (~%25 kisa);
     letter-spacing .07em (polish) -> .05em. Renk/uppercase/cizgi polish'te kalir. */
  .portal-header-bar nav .portal-nav-link {
    font-size: 11.5px;
    letter-spacing: 0.05em;
    padding-inline: calc(var(--spacing, 0.25rem) * 1.875); /* .469rem */
    white-space: nowrap;
  }

  /* 3. polish.css ::after cizgisi eski padding'e (.625rem) hizaliydi;
     ayni gorsel dilde, yeni icerik hizasina tasi (tasarim degisikligi degil). */
  .portal-header-bar nav .portal-nav-link::after {
    left: calc(var(--spacing, 0.25rem) * 1.875);
  }
  .portal-header-bar nav .portal-nav-link:hover::after,
  .portal-header-bar nav .portal-nav-link-active::after {
    width: calc(100% - var(--spacing, 0.25rem) * 3.75);
  }
}

/* 4. 1024-1280px arasi: daha da kompakt (dar masaustu/landscape tablet). */
@media (min-width: 1024px) and (max-width: 1280px) {
  .portal-header-bar nav .portal-nav-link {
    font-size: 11px;
    letter-spacing: 0.04em;
    padding-inline: calc(var(--spacing, 0.25rem) * 1.5); /* .375rem */
  }
  .portal-header-bar nav .portal-nav-link::after {
    left: calc(var(--spacing, 0.25rem) * 1.5);
  }
  .portal-header-bar nav .portal-nav-link:hover::after,
  .portal-header-bar nav .portal-nav-link-active::after {
    width: calc(100% - var(--spacing, 0.25rem) * 3);
  }
}

/* === redesign-blog.css === */
/* ==========================================================================
   diyarbakr.com — redesign-blog.css
   Blog listesi (/blog) + makale sayfası (/blog/:slug) editoryal katmanı
   Tasarım dili: turuncu #ea580c / #c2410c, tonlar #fff7ed/#ffedd5/#fdba74,
   stone #1c1917/#57534e/#78716c, kart köşe 1.25rem, başlık "Source Serif 4",
   gölge 0 1px 2px rgba(28,25,23,.05) + 0 12px 32px -16px rgba(28,25,23,.14),
   easing cubic-bezier(.22,.61,.36,1).

   KATMAN NOTLARI (çakışma yönetimi):
   - redesign-cards.css .hero-post-card / .related-post-card'ı tasarladı →
     bu iki sınıfın özellikleri burada YENİDEN TANIMLANMAZ; yalnızca
     .related-posts-sec / .related-posts-grid düzenine dokunulur.
   - redesign-pages.css koyu kabuğu (.bg-[#141414]) açık temaya çevirdi ve
     .dynamic-page-prose'u stiledi → burada SADECE makaleye özel iyileştirme;
     makale kapsayıcısı `article.bg-[#141414]:has(a[href="/blog"])` ile
     diğer detay sayfalarından (mekan/:slug div kabuğu, :slug içerik
     sayfaları) ayrıştırılır.
   - ::selection turuncu tonu polish.css §2'de site geneli tanımlı →
     burada tekrarlanmaz.
   - Bundle DOM (index-D3If5UAG.js):
     * /blog (p1): section.sec > span.overline + h2.sec-title +
       .sec-title-divider + div.grid(.md:grid-cols-2.lg:grid-cols-3.gap-8)
       > div.card-reveal > a[href^="/blog/"] (koyu Tailwind kart:
       bg-[rgba(38,30,24,0.9)], border-amber-500/25, text-white...).
     * /blog/:slug (m1): .max-w-3xl > article.bg-[#141414] (kapak,
       chip satırı, h1, özet p.text-white/55, h-px divider,
       .dynamic-page-prose, alt bar: a[href="/blog"] + #etiket chip'leri)
       + .related-posts-sec > h2.sec-title(inline stil) +
       .related-posts-grid > a.related-post-card.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1) BLOG LİSTESİ — sayfa başlığı: editoryal kicker + büyük serif başlık
   -------------------------------------------------------------------------- */

.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .overline {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.5rem;
  padding: 0.34rem 0.95rem 0.34rem 0.75rem;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  color: #c2410c;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  margin-bottom: 1rem;
}
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .overline::before {
  content: "";
  flex: none;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: #ea580c;
}

.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .sec-title {
  font-size: clamp(1.875rem, 4vw, 2.75rem);
  letter-spacing: -0.025em;
  line-height: 1.08;
}

.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .sec-title-divider {
  margin-bottom: 2.5rem;
}

/* Kart grid'i: marka ritmine uygun boşluk (gap-8'in 2rem'i fazla geniş) */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid {
  gap: 1.5rem;
}

/* --------------------------------------------------------------------------
   2) BLOG LİSTESİ KARTLARI — koyu Tailwind kabuk → beyaz premium kart
      (hero-post-card / related-post-card ile aynı kimlik: üst turuncu şerit,
      tarih chip'i, serif başlık, turuncu "devamını oku")
   -------------------------------------------------------------------------- */

.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a {
  position: relative;
  background: #fff;
  border-color: #eceae7;
  border-radius: 1.25rem;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14);
  transition:
    translate 0.3s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.3s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: translate;
}
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a:hover {
  translate: 0 -4px;
  border-color: #fdba74;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 12px 32px -16px rgba(28, 25, 23, 0.14),
    0 24px 56px -20px rgba(234, 88, 12, 0.18);
}

/* Üst kenarda ince turuncu gradyan şerit — blog kart kimliği */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 2;
  background: linear-gradient(90deg, #fdba74, #ea580c 45%, #c2410c);
}

/* Kapaksız yazı placeholder'ı: koyu degrade → krem-turuncu */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .bg-gradient-to-br {
  background-image: linear-gradient(135deg, #fff7ed, #fdba74);
}

/* Görsel üstü karartma: açık temada yumuşatılır */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .bg-gradient-to-t {
  background-image: linear-gradient(
    to top,
    rgba(28, 25, 23, 0.3),
    rgba(28, 25, 23, 0.04) 55%,
    transparent
  );
}

/* "Öne çıkan" rozeti: amber → marka turuncu degradesi */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .from-amber-600 {
  background-image: linear-gradient(135deg, #f97316, #ea580c);
  box-shadow: 0 6px 14px -6px rgba(234, 88, 12, 0.55);
}

/* Köşedeki etiket rozeti: koyu cam → beyaz chip */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .right-3.top-3 {
  background: rgba(255, 255, 255, 0.92);
  border-color: #fed7aa;
  color: #9a3412;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.08);
}

/* Kart gövdesi boşlukları (p-6 → kart ailesiyle aynı ritim) */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a > .p-6 {
  padding: 1.2rem 1.35rem 1.35rem;
  gap: 0.5rem;
}

/* Tarih: hero-post-date ile aynı chip dili */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .text-white\/35 {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 0.22rem 0.65rem;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #c2410c;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
}

/* Başlık: beyaz sans → koyu serif */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a h2 {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: #1c1917;
  transition: color 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a:hover h2 {
  color: #c2410c;
}

/* Özet: soluk beyaz → stone */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .p-6 p {
  color: #78716c;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.62;
}

/* "Devamını oku" — hero-post-read ile aynı ses */
.portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .text-amber-500 {
  color: #ea580c;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* --------------------------------------------------------------------------
   3) ÖNE ÇIKAN İLK KART — grid'de 2 kolon kaplar, dergi kapağı hissi
      (bundle'da featured için ayrı render yok; ilk kart liderdir)
   -------------------------------------------------------------------------- */

@media (min-width: 768px) {
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal:first-child {
    grid-column: span 2;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal:first-child > a .h-52 {
    height: 17.5rem;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal:first-child > a h2 {
    font-size: 1.55rem;
    line-height: 1.22;
    letter-spacing: -0.015em;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal:first-child > a .p-6 p {
    font-size: 0.9375rem;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal:first-child > a > .p-6 {
    padding: 1.4rem 1.6rem 1.6rem;
  }
}

/* --------------------------------------------------------------------------
   4) MAKALE BAŞLIK BLOĞU — büyük serif başlık, chip satırı, lead, divider
      (kabuk → beyaz dönüşümü redesign-pages.css §6'da; burada makale-özel)
   -------------------------------------------------------------------------- */

/* Başlık: pages.css'in genel clamp'i makale için büyütülür */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) h1 {
  font-size: clamp(1.875rem, 4vw, 2.75rem);
  line-height: 1.12;
}

/* Kategori (etiket) chip'leri: pages.css renkleri verdi; biçim rafine edilir */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .mb-5 {
  gap: 0.6rem;
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .mb-5 .bg-amber-500\/10 {
  padding: 0.3rem 0.85rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

/* Tarih / okunma meta'sı */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .mb-5 .text-white\/30,
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .mb-5 .text-white\/25 {
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

/* Özet (lead) paragrafı */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) p.text-white\/55 {
  font-size: 1.125rem;
  line-height: 1.75;
  color: #57534e;
  max-width: 42rem;
  text-wrap: pretty;
}

/* İnce turuncu divider */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .h-px.bg-gradient-to-r {
  height: 2px;
  border-radius: 999px;
  background-image: linear-gradient(90deg, #ea580c, #fdba74 45%, transparent);
}

/* Kapak görseli karartması: açık kart üzerinde yumuşak */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .from-black\/70 {
  background-image: linear-gradient(
    to top,
    rgba(28, 25, 23, 0.42),
    rgba(28, 25, 23, 0.06) 50%,
    transparent
  );
}

/* --------------------------------------------------------------------------
   5) MAKALE GÖVDE TİPOGRAFİSİ — dergi ölçüsü
      (pages.css §10 temel prose'u verdi; makalede ölçü/ritim derinleştirilir)
   -------------------------------------------------------------------------- */

.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose {
  max-width: 42rem;
  margin-inline: auto;
  font-size: 1.0625rem;
  line-height: 1.85;
}
@media (min-width: 768px) {
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose {
    font-size: 1.125rem;
  }
}

.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose p {
  margin: 0 0 1.3rem;
}

/* GİRİŞ PARAGRAFI — büyük ve soluk, dergi girişi */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose > p:first-of-type {
  font-size: 1.25rem;
  line-height: 1.72;
  color: #57534e;
  margin-bottom: 1.7rem;
}

/* DROP-CAP — Source Serif 4, turuncu; güvenli marjlar, mobilde kapatılır */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose > p:first-of-type::first-letter {
  float: left;
  font-family: "Source Serif 4", Georgia, serif;
  font-weight: 700;
  font-size: 3.2em;
  line-height: 0.82;
  color: #ea580c;
  padding: 0.06em 0.14em 0.02em 0;
}

/* Ara başlıklar — pages.css'in serif + turuncu alt çizgisini tamamlar */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose h2 {
  font-size: 1.5625rem;
  margin-top: 2.6rem;
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose h3 {
  font-size: 1.25rem;
  margin-top: 2.1rem;
}

/* Linkler — pages.css rengine ek okuma konforu */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose a {
  text-underline-offset: 4px;
  text-decoration-thickness: 1.5px;
}

/* İçerik içi görseller: yuvarlatılmış + marka gölgesi */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose img {
  display: block;
  width: 100%;
  border-radius: 1rem;
  box-shadow:
    0 1px 2px rgba(28, 25, 23, 0.05),
    0 16px 40px -18px rgba(28, 25, 23, 0.22);
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose figure {
  margin: 1.7rem 0;
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose figure img {
  margin: 0;
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose figcaption {
  margin-top: 0.65rem;
  text-align: center;
  font-size: 0.8125rem;
  font-style: italic;
  color: #a8a29e;
}
/* blockquote krem zemin (bundle) ve tablo zebrası (pages.css) korunur */

/* --------------------------------------------------------------------------
   6) MAKALE ALT BARI — geri pili + etiket bulutu
   -------------------------------------------------------------------------- */

/* "← Tüm yazılar" — marka pill'i */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) a[href="/blog"] {
  padding: 0.55rem 1.2rem;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  color: #c2410c;
  box-shadow: 0 1px 2px rgba(28, 25, 23, 0.05);
  transition:
    background-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    color 0.18s cubic-bezier(0.22, 0.61, 0.36, 1),
    translate 0.18s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) a[href="/blog"]:hover {
  background: #ffedd5;
  border-color: #fdba74;
  color: #9a3412;
  translate: 0 -1px;
}

/* #etiket chip bulutu — krem zemin */
.portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) span.bg-white\/5 {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 0.3rem 0.8rem;
  color: #9a3412;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* --------------------------------------------------------------------------
   7) İLGİLİ YAZILAR — bölüm ayracı + başlık aksanı + grid ritmi
      (kart içi tasarım redesign-cards.css'te; ona dokunulmaz)
   -------------------------------------------------------------------------- */

.portal-root .related-posts-sec {
  margin-top: 2.75rem;
  border-top: 1px dashed #e7e5e4;
}
.portal-root .related-posts-sec .sec-title {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  letter-spacing: -0.01em;
}
.portal-root .related-posts-sec .sec-title::before {
  content: "";
  flex: none;
  width: 1.75rem;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ea580c, #fdba74);
}
.portal-root .related-posts-grid {
  gap: 1.1rem;
}

/* --------------------------------------------------------------------------
   8) MOBİL KONTROL
   -------------------------------------------------------------------------- */

@media (max-width: 640px) {
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid {
    gap: 1.1rem;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .sec-title-divider {
    margin-bottom: 1.75rem;
  }

  /* Makale iç boşlukları daraltılır (px-8'in 2rem'i mobilde geniş) */
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) > .px-8 {
    padding-left: 1.4rem;
    padding-right: 1.4rem;
  }

  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) p.text-white\/55 {
    font-size: 1.0625rem;
  }
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose {
    font-size: 1.0625rem;
  }
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose > p:first-of-type {
    font-size: 1.125rem;
  }

  /* Drop-cap mobilde kapatılır */
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) .dynamic-page-prose > p:first-of-type::first-letter {
    float: none;
    font-family: inherit;
    font-weight: inherit;
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    padding: 0;
  }
}

/* --------------------------------------------------------------------------
   9) HAREKET AZALTMA
   -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a,
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a img,
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a h2,
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a .text-amber-500 span,
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) a[href="/blog"] {
    transition: none;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a:hover {
    translate: none;
  }
  .portal-root .sec:has(> .grid > .card-reveal > a[href^="/blog/"]) > .grid > .card-reveal > a:hover img {
    scale: none;
    translate: none;
  }
  .portal-root article.bg-\[\#141414\]:has(a[href="/blog"]) a[href="/blog"]:hover {
    translate: none;
  }
}

/* === redesign-responsive.css === */
/* ============================================================================
   diyarbakr.com — redesign-responsive.css
   SİSTEMATİK RESPONSIVE DENETİM KATMANI (10 Haziran 2026)
   ----------------------------------------------------------------------------
   En SON yüklenir; bundle (index--MSd8cSU.css) + polish.css + redesign-*.css
   kurallarını aynı özgüllükle kaynak sırası üzerinden ezer. !important YOK.
   TÜM kurallar media query içindedir — masaüstü (≥1280px) görünümüne, hover
   yeteneği olan fare kullanıcılarına ve mevcut tasarım diline DOKUNULMAZ.

   Bundle taban verileri (denetimden):
   - .sec-grid: ≤640px 1 kolon / 641–1024px 2 kolon / ≥1025px 4 kolon
   - .ev: ≤768px "4rem 1fr" grid; .sec: padding-inline 1rem (taban)
   - .portal-grid-dashboard: taban 1 kolon, ≥64rem 2, ≥80rem 12 (xl:col-span 7/5/4/4/4)
   - .portal-home-hero-grid: ≥64rem "1.15fr + minmax(280px,360px)" (stage + bugün paneli)
   - .portal-home-hero-stage-media: 260px / ≥40rem 300px / ≥64rem 370px
   - hamburger: h-9 w-9 (36px); hero okları 36px; hero dot 20×4px
   - Chat FAB: inline-style fixed bottom:24 right:24 60×60 (CSS ile taşınamaz —
     yer ayırma stratejisi uygulanır); #db-search-dock başka ajanda, üstte konumlanır.
   ========================================================================== */


/* ============================================================================
   1) 360–480px — KÜÇÜK TELEFON
   ========================================================================== */
@media (max-width: 480px) {

  /* Sorun: 1rem yatay dolgu dar ekranda içerik genişliğini gereksiz yiyor. */
  .portal-root .sec {
    padding-inline: 0.875rem;
  }

  /* Sorun: uzun slayt başlığı 260px'lik sahnede kicker+lead ile taşabiliyor —
     3 satırda kibarca kırpılır (bundle'da clamp yoktu). */
  .portal-home-hero-headline {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
  }

  /* Sorun: uzun bitişik kelimeler (kurum/mekan adları) dar kolonda yatay
     taşma üretebiliyor — başlıklar kelime içinden kırılabilsin. */
  .portal-root .sec-title,
  .portal-hero-title,
  .portal-home-hero-headline {
    overflow-wrap: break-word;
  }

  /* Sorun: redesign-cards'ın -1rem panel bindirmesi küçük ekranda görselden
     fazla alan çalıyor — bindirme -0.75rem'e yumuşatılır. */
  .portal-root .sec-place-card__body {
    margin-top: -0.75rem;
  }

  /* Sorun: .ev'in sabit 4rem tarih kolonu + 1.25/1.5rem dolgu 360px'te metne
     yer bırakmıyor — kolon içerikle oranlı küçülür, dolgu sıkılaşır. */
  .portal-root .ev {
    grid-template-columns: minmax(3rem, 4rem) 1fr;
    gap: 0.875rem;
    padding: 1rem 1.05rem;
  }

  /* Sorun: dashboard kartlarının 1.25rem dolgusu dar ekranda satırları
     sıkıştırıyor — 1rem yeterli nefes bırakır. */
  .portal-dash-card {
    padding: 1rem;
  }

  /* Sorun: çok sayıda filtre pili wrap olunca 3-4 satır yer kaplıyordu —
     tek satır, yatay kaydırılabilir, scrollbar gizli, snap'li şerit.
     Negatif margin pilleri .sec dolgu kenarına taşırır (tam-genişlik hissi);
     .sec'in overflow-x:hidden'ı dışarı sızmayı zaten engeller. */
  .portal-root .filter-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    margin-inline: -0.875rem;
    padding-inline: 0.875rem;
    padding-bottom: 0.375rem; /* odak halkası + gölge kırpılmasın */
    scroll-snap-type: x proximity;
    scroll-padding-inline: 0.875rem;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  /* Sorun: WebKit'te kayan pil şeridinin altında scrollbar çıkıyor — gizle. */
  .portal-root .filter-pills::-webkit-scrollbar {
    display: none;
  }
  /* Sorun: nowrap şeritte piller ezilmesin; kaydırınca kenara hizalansın. */
  .portal-root .filter-pill {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }
}


/* ============================================================================
   2) 481–767px — BÜYÜK TELEFON
   (.sec-grid bundle'da 40rem'de zaten 2 kolona geçiyor — DOKUNULMADI)
   ========================================================================== */
@media (min-width: 481px) and (max-width: 767px) {

  /* Sorun: bugün paneli 481–639px bandında 1rem dolguda kalıyor (bundle
     1.25rem'i 640'ta açıyor) — geniş telefonda erken eşitlenir. */
  .portal-today-panel {
    padding: 1.25rem;
  }
}

@media (max-width: 767px) {

  /* Sorun: 640–767px bandında 6 kolonlu quick-nav'da 10px etiketler
     sıkışıyordu — 3 kolon dengesi telefon sonuna kadar korunur. */
  .portal-quick-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  /* Sorun: 3 kolonlu iki satırlık dizilimde satırlar arası ayraç yoktu
     (bundle yalnız dikey divide-x veriyor) — 2. satıra ince üst çizgi. */
  .portal-quick-nav-item:nth-child(n+4) {
    border-top: 1px solid #f5f5f4;
  }

  /* Sorun: dynamic-page-prose içindeki geniş tablolar mobilde sayfayı yatay
     kaydırıyordu (gerçek taşma kaynağı) — tablo kendi içinde kaydırılır. */
  .portal-root .dynamic-page-prose table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Sorun: prose içindeki uzun URL/bitişik kelimeler kolonu taşırıyor. */
  .portal-root .dynamic-page-prose {
    overflow-wrap: break-word;
  }
}


/* ============================================================================
   3) 768–1024px — TABLET (en ihmal edilen aralık)
   NOT: nav yoğunluğu redesign-nav-density.css'in işi — NAV'A DOKUNULMADI.
   ========================================================================== */

/* Sorun: 768–1024'te 2 kolon (dev kartlar) ve 1025–1279'da 4 kolon (ezik
   kartlar) iki uçta da kötüydü — tüm bant için dengeli 3 kolon: 1→2→3→4
   kademeli akış tamamlanır. (≥1280 bundle'ın 4 kolonu aynen sürer.) */
@media (min-width: 768px) and (max-width: 1279.98px) {
  .portal-root .sec-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 48rem) and (max-width: 63.98rem) {

  /* Sorun: dashboard tablette tek kolona düşüp metre metre uzuyordu
     (bundle 2 kolonu 64rem'de açıyor) — 2 kolon erken başlar. */
  .portal-grid-dashboard {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Sorun: 5 kartlı 2 kolon dizilimde sonuncusu öksüz kalıyordu —
     tek kalan son kart tam satıra yayılır. */
  .portal-grid-dashboard > :last-child:nth-child(odd) {
    grid-column: 1 / -1;
  }

  /* Sorun: 300px sabit sahne ~720–990px genişlikte aşırı yassı kalıyordu
     (oran 2.4–3.3) — tablete özel 340px ile sinematik oran korunur. */
  .portal-home-hero-stage-media {
    height: 340px;
  }
}


/* ============================================================================
   4) 1024–1279px — DAR MASAÜSTÜ
   (.sec-grid 3 kolonu yukarıdaki 768–1279.98 bloğunda)
   ========================================================================== */
@media (min-width: 64rem) and (max-width: 79.98rem) {

  /* Sorun: 360px'e kadar açılan sağ ray dar masaüstünde sahneyi 584px'e
     sıkıştırıyordu — ray 316px ile sınırlanır, sahne nefes alır. */
  .portal-home-hero-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(264px, 316px);
  }
}


/* ============================================================================
   5) ≤1023px — DOKUNMA ERGONOMİSİ + TAŞMA GÜVENLİK AĞI + FAB/TOPBAR
   ========================================================================== */
@media (max-width: 1023.98px) {

  /* Sorun: filtre pilleri ~36-40px'ti (polish 40px'e çekmişti) — WCAG/iOS
     44px dokunma hedefi; görünüm sabit, alan min-height ile büyür. */
  .portal-root .filter-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
  }

  /* Sorun: ilçe/menü pilleri (.portal-pill) ~36px dokunma alanındaydı. */
  .portal-root .portal-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
  }

  /* Sorun: hamburger menü düğmesi 36×36px'ti — 44×44px'e büyütülür
     (h-9/w-9 height/width verir; min-* çakışmadan kazanır). */
  .portal-header button.lg\:hidden {
    min-width: 2.75rem;
    min-height: 2.75rem;
  }

  /* Sorun: hero slider okları 36px'ti — dokunmada 44px hedef. */
  .portal-home-hero-arrow,
  .portal-news-hero-arrow {
    width: 2.75rem;
    height: 2.75rem;
  }

  /* Sorun: 20×4px slider noktaları dokunulamayacak kadar küçüktü — görsel
     4px çubuk korunur (background-clip), dikey vuruş alanı dolgu ile büyür. */
  .portal-home-hero-dot {
    box-sizing: content-box;
    padding-block: 0.5rem;
    background-clip: content-box;
  }

  /* Sorun: dashboard "Tümünü gör" pili ~29px yüksekliğindeydi. */
  .portal-dash-card .portal-dash-link {
    min-height: 2.75rem;
    padding-inline: 1rem;
  }

  /* Sorun: telefon (tel:) butonu ~37px'ti — aramaya giden en kritik hedef. */
  .portal-root .portal-btn-call {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
  }

  /* Sorun: meta bardaki yenile butonu ~30px'ti. */
  .portal-root .portal-meta-bar button {
    min-height: 2.75rem;
  }

  /* Sorun: bugün paneli arama girişi/butonu ~36px'ti. */
  .portal-today-search-input,
  .portal-today-search-btn {
    min-height: 2.75rem;
  }

  /* Sorun: footer linkleri inline olduğundan polish'in min-height'ı hiç
     uygulanmıyordu — inline-flex ile 44px hedef gerçekten etkinleşir. */
  .portal-root footer a {
    display: inline-flex;
    align-items: center;
    min-height: 2.75rem;
  }

  /* Sorun: 16px altı input fontu iOS Safari'de odaklanınca sayfayı
     zorla yakınlaştırıyor — tüm form öğeleri min 16px. */
  .portal-root input,
  .portal-root select,
  .portal-root textarea {
    font-size: max(16px, 1em);
  }

  /* Sorun: sabit chat FAB'ı (60px + 24px offset, inline-style olduğundan
     taşınamaz) sayfa sonunda footer içeriğini örtüyordu — footer altına
     FAB yüksekliği kadar güvenli alan ayrılır. */
  .portal-root footer {
    padding-bottom: 5.5rem;
  }

  /* Sorun: çentikli/home-bar'lı cihazlarda FAB payı sistem çubuğuyla
     çakışıyordu — safe-area desteği olan tarayıcıda pay üstüne eklenir. */
  @supports (padding: env(safe-area-inset-bottom)) {
    .portal-root footer {
      padding-bottom: calc(5.5rem + env(safe-area-inset-bottom));
    }
  }

  /* Sorun: enhance.js topbar'ı kayıyor ama iOS momentum ve komşu dikey
     scroll zincirlenmesi tanımsızdı — kaydırma davranışı güçlendirilir.
     (Dolguya dokunulmaz: enhance.js'in enjekte stili daha sonra geldiğinden
     padding üzerinde son söz onundur.) */
  #db-topbar {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
  }
  #db-topbar .db-tb-item {
    scroll-snap-align: start;
  }

  /* GÜVENLİK AĞI (kaynağı düzeltilen taşmalardan sonra son sigorta):
     clip kullanılır — hidden gibi scroll container oluşturmaz, böylece
     .portal-header'ın sticky davranışı bozulmaz. */
  .portal-root {
    overflow-x: clip;
  }
}


/* ============================================================================
   6) DOKUNMATİK CİHAZ — yapışkan :hover transform'larının nötrlenmesi
   Bundle kendi hover'larını @media(hover:hover) ile sarmıştı; polish ve
   redesign katmanlarının transform'lu hover'ları ise dokunmada "yapışıp"
   kartları zıplatıyordu. Renk/gölge geçişleri bilinçli olarak korunur,
   :active basış geri bildirimi (polish §7) aynen çalışır.
   ========================================================================== */
@media (hover: none) {

  /* Sorun: tek dokunuşta kartlar kalkık pozisyonda asılı kalıyordu. */
  .portal-root .sec-place-card:hover,
  .portal-root .ev:hover,
  .portal-root .hero-post-card:hover,
  .portal-root .related-post-card:hover,
  .portal-place-mini:hover,
  .portal-root article.portal-card:hover,
  .portal-root a.portal-card.portal-card-hover:hover,
  .portal-root .map-list-item:hover,
  .portal-root .contact-block:hover,
  .portal-root .not-found-btn:hover,
  .portal-root .dynamic-page-back-link:hover,
  .portal-root .btn-view-all:hover,
  .portal-btn:hover,
  .portal-mobile-hero-ad:hover,
  footer a:hover {
    transform: none;
  }

  /* Sorun: dokunuşta görsel zoom'u takılı kalıyordu (kart içi img scale). */
  .portal-root .sec-place-card:hover .sec-place-card__img img,
  .portal-root .hero-post-card:hover .hero-post-img img,
  .portal-root .related-post-card:hover .related-post-img img,
  .portal-place-mini:hover img,
  .portal-news-hero-rail-item:hover .portal-news-hero-rail-thumb img,
  .portal-root .bg-\[\#141414\] .grid-cols-2 > a:hover {
    transform: none;
  }

  /* Sorun: quick-nav ikonu dokunuşta havada kalıyordu. */
  .portal-quick-nav-item:hover .portal-quick-nav-icon {
    transform: none;
  }

  /* Sorun: slider oku dokunuşta büyümüş (scale 1.08) kalıyordu. */
  .portal-home-hero-arrow:hover,
  .portal-news-hero-arrow:hover {
    scale: 1;
  }

  /* Sorun: "devamını oku" oku dokunuşta kaymış pozisyonda kalıyordu. */
  .portal-root .hero-post-card:hover .hero-post-read:after,
  .portal-root .related-post-card:hover .hero-post-read:after {
    transform: none;
  }
}


/* ============================================================================
   7) YAZDIRMA — topbar/FAB/nav gizli, kartlar kenarlıklı düz, mürekkep dostu
   ========================================================================== */
@media print {

  /* Sorun: bilgi şeridi, reklam rayları, slider kontrolleri ve arama formu
     kağıtta anlamsız — tamamen gizlenir. */
  #db-topbar,
  #glow-cursor,
  .portal-rail,
  .portal-ad-link,
  .portal-mobile-hero-ad,
  .portal-home-hero-arrow,
  .portal-home-hero-dots,
  .portal-news-hero-arrow,
  .portal-today-search,
  .portal-header nav,
  .portal-header form,
  .portal-header button {
    display: none;
  }

  /* Sorun: chat FAB'ı inline display:flex taşıdığından display:none'ı
     !important'sız yener — inline'da OLMAYAN visibility ile gizlenir. */
  button[aria-label="Yapay Zeka Rehber"] {
    visibility: hidden;
  }

  /* Sorun: sticky header her yazdırılan sayfada tekrarlanıyordu. */
  .portal-header {
    position: static;
    box-shadow: none;
  }

  /* Sorun: polish'in 3px turuncu marka şeridi kağıtta bant bırakıyordu. */
  .portal-header::before {
    display: none;
  }

  /* Sorun: degrade/krem zeminler mürekkep harcıyordu — beyaza döner. */
  .portal-root {
    background: #fff;
  }
  .portal-dashboard-zone,
  .portal-explore-wrap > .bg-stone-50\/60 {
    background: #fff;
    box-shadow: none;
  }

  /* Sorun: tarih bölümünün kemer silüeti deseni kağıtta gölge yapıyordu. */
  .portal-root .sec:has(.timeline) {
    background-image: none;
  }

  /* Sorun: gölgeli/kalkık kartlar kağıtta bulanık basılıyordu —
     düz, ince kenarlıklı kutular; sayfa sonunda kart bölünmez. */
  .portal-root .sec-place-card,
  .portal-root .ev,
  .portal-root .hero-post-card,
  .portal-root .related-post-card,
  .portal-place-mini,
  .portal-root article.portal-card,
  .portal-root a.portal-card,
  .portal-root div.portal-card,
  .portal-dash-card,
  .portal-today-panel,
  .portal-quick-nav {
    box-shadow: none;
    border: 1px solid #d6d3d1;
    transform: none;
    break-inside: avoid;
  }

  /* Sorun: kart görseli üzerindeki karartma degradeleri baskıda griye
     boğuyordu — scrim'ler kaldırılır. */
  .portal-root .sec-place-card__img:after,
  .portal-home-hero-stage-overlay {
    display: none;
  }

  /* Sorun: koyu (stone-950) footer tam sayfa siyah blok basıyordu —
     beyaz zemin, koyu metin, ince üst çizgi; FAB payı da gereksiz. */
  .portal-root footer {
    background: #fff;
    color: #57534e;
    border-top: 1px solid #d6d3d1;
    padding-bottom: 1rem;
  }
  .portal-root footer a,
  .portal-root footer h4,
  .portal-root footer .text-white {
    color: #1c1917;
  }
}

/* ============================================================
   HOTFIX (10 Haz 2026, canli olcumle tespit): grid cocuklarinda
   min-width:auto tuzagi — nowrap icerikler (adres/telefon/rozet)
   kolon rayini sisirip mobilde icerigin saga tasip kesilmesine
   yol aciyordu (dash karti 636px, sec-grid rayi 606px olculdu).
   min-width:0 her genislikte guvenlidir, media query disinda. */
.portal-root .sec-grid > *,
.portal-root .portal-grid-dashboard > *,
.portal-root .related-posts-grid > * {
  min-width: 0;
}
.portal-root .portal-dash-card,
.portal-root .sec-place-card {
  min-width: 0;
}
.portal-root .portal-list-row > * {
  min-width: 0;
}

