/* urlataksirehberi.com — ana stil dosyasi */

:root {
  --sari: #f5b400;
  --sari-koyu: #d99e00;
  --koyu: #1c1c1c;
  --gri-metin: #555;
  --gri-acik: #f3f4f6;
  --gri-cizgi: #e3e5e8;
  --whatsapp: #25d366;
  --yesil-koyu: #128c3e;
  --kirmizi: #d23b3b;
  --golge: 0 2px 8px rgba(0, 0, 0, .08);
  --golge-buyuk: 0 6px 20px rgba(0, 0, 0, .12);
  --radius: 12px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--koyu);
  background: #fff;
  line-height: 1.6;
}

a { color: var(--yesil-koyu); }

img { max-width: 100%; height: auto; }

.wrap {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 16px;
}

h1, h2, h3 {
  line-height: 1.2;
  font-family: 'Fraunces', Georgia, 'Times New Roman', serif;
  letter-spacing: -.01em;
}

/* ---- header ---- */
.site-header {
  background: #f3eddf;
  border-bottom: 1px solid #e6dfcd;
  position: sticky;
  top: 0;
  z-index: 500;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 74px;
  flex-wrap: wrap;
  gap: 8px;
}
.logo {
  display: flex;
  align-items: center;
  text-decoration: none;
}
.logo-img {
  height: 64px;
  width: auto;
  display: block;
  border-radius: 10px;
}
.site-nav { display: flex; gap: 4px; flex-wrap: wrap; }
.site-nav a {
  color: var(--koyu);
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: .95rem;
  font-weight: 600;
}
.site-nav a:hover { background: rgba(0, 0, 0, .06); }
.site-nav a.aktif { background: var(--sari); color: var(--koyu); font-weight: 700; }

/* ---- hero ---- */
.hero {
  position: relative;
  overflow: hidden;
  background: #14202a;
  color: #fff;
  padding: 58px 0 104px;
  text-align: center;
}
/* Hero arka plan — yavaş geçişli Urla fotoğrafları */
.hero-fotolar { position: absolute; inset: 0; z-index: 0; }
.hero-foto {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.6s ease;
}
.hero-foto.aktif { opacity: 1; }
/* okunabilirlik için koyu degrade katman */
.hero-fotolar::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(15, 23, 30, .58) 0%,
    rgba(15, 23, 30, .42) 45%,
    rgba(15, 23, 30, .66) 100%
  );
}
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 58px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 58' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,30 C240,58 480,6 720,26 C960,46 1200,10 1440,32 L1440,58 L0,58 Z'/%3E%3C/svg%3E") no-repeat bottom / 100% 100%;
  pointer-events: none;
}
.hero-ic {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero-ust {
  margin: 0 0 8px;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .24em;
  color: rgba(255, 255, 255, .82);
}
.hero h1 {
  margin: 0;
  font-size: 3.1rem;
  font-weight: 700;
  text-shadow: 0 2px 14px rgba(0, 0, 0, .4);
}
.hero-sub {
  margin: 14px 0 0;
  font-size: 1.12rem;
  max-width: 560px;
  color: rgba(255, 255, 255, .92);
  text-shadow: 0 1px 8px rgba(0, 0, 0, .4);
}
.hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 26px;
}
.hero-chip {
  background: rgba(255, 255, 255, .94);
  color: var(--koyu);
  text-decoration: none;
  font-weight: 700;
  font-size: .92rem;
  padding: 9px 17px;
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .14);
  transition: transform .12s ease, box-shadow .12s ease;
}
.hero-chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 5px 14px rgba(0, 0, 0, .2);
}

/* ---- hero arama kutusu ---- */
.hero-arama {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  max-width: 600px;
  margin: 24px auto 0;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .2);
  padding: 6px 6px 6px 15px;
}
.hero-arama-ikon { font-size: 1.05rem; opacity: .6; }
#arama-input {
  flex: 1;
  min-width: 0;
  border: 0;
  outline: none;
  background: none;
  font: inherit;
  font-size: 1rem;
  padding: 11px 4px;
  color: var(--koyu);
}
#arama-konum {
  border: 0;
  background: var(--koyu);
  color: #fff;
  font-weight: 700;
  font-size: .85rem;
  padding: 10px 13px;
  border-radius: 8px;
  cursor: pointer;
  white-space: nowrap;
}
#arama-konum.aktif { background: var(--yesil-koyu); }
.arama-sonuc {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, .28);
  overflow: hidden auto;
  max-height: 380px;
  text-align: left;
  z-index: 600;
}
.arama-sonuc[hidden] { display: none; }
.arama-oge {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
  text-align: left;
  background: none;
  border: 0;
  border-bottom: 1px solid var(--gri-cizgi);
  padding: 10px 15px;
  cursor: pointer;
  font: inherit;
}
.arama-oge:last-child { border-bottom: 0; }
.arama-oge:hover { background: var(--gri-acik); }
.arama-oge-ad { font-weight: 700; color: var(--koyu); }
.arama-oge-alt { font-size: .85rem; color: var(--gri-metin); }
.arama-mesafe { color: var(--yesil-koyu); font-weight: 700; margin-left: 6px; }
.arama-rozet {
  background: var(--sari);
  color: var(--koyu);
  font-size: .68rem;
  font-weight: 800;
  padding: 1px 7px;
  border-radius: 999px;
}
.arama-bos { padding: 14px 15px; color: var(--gri-metin); }
.kart-vurgu { outline: 3px solid var(--sari); outline-offset: 3px; }

/* ---- butonlar ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 18px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1.2;
}
.btn-sm { padding: 8px 12px; font-size: .9rem; }
.btn-ara { background: var(--sari); color: var(--koyu); }
.btn-ara:hover { background: var(--sari-koyu); }
.btn-whatsapp { background: var(--whatsapp); color: #fff; }
.btn-whatsapp:hover { filter: brightness(.93); }
.btn-detay { background: var(--gri-acik); color: var(--koyu); }
.btn-detay:hover { background: var(--gri-cizgi); }
.btn-gonder { background: var(--yesil-koyu); color: #fff; }
.btn-gonder:hover { filter: brightness(1.08); }

/* ---- reklam alani ---- */
.reklam-alani {
  margin: 20px 0;
  border-radius: var(--radius);
}
.reklam-alani:empty {
  min-height: 90px;
  border: 2px dashed var(--gri-cizgi);
  display: flex;
  align-items: center;
  justify-content: center;
}
.reklam-alani:empty::before {
  content: "Reklam Alanı";
  color: #b5b8bd;
  font-size: .85rem;
  letter-spacing: .04em;
}
.reklam-alani--dolu { border: 0; min-height: 0; }
.reklam-banner { text-align: center; }
.reklam-banner + .reklam-banner { margin-top: 10px; }
.reklam-banner img { border-radius: var(--radius); max-width: 100%; height: auto; }

/* ---- harita ---- */
.harita { width: 100%; border-radius: var(--radius); z-index: 1; }
.harita--genel { height: 380px; box-shadow: var(--golge); }
.harita--durak { height: 300px; }
.harita-bolum { margin: 20px 0; }
.harita-not { font-size: .85rem; color: var(--gri-metin); margin: 8px 0 0; }

/* harita marker'lari */
.durak-pin-sar { background: transparent; border: 0; }
.durak-pin {
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.durak-pin--altin {
  width: 38px; height: 38px;
  background: var(--sari);
  border: 3px solid #fff;
  box-shadow: 0 2px 7px rgba(0, 0, 0, .4);
  font-size: 17px;
}
.durak-pin--sade {
  width: 20px; height: 20px;
  background: #8a8d93;
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .35);
}
/* Isletme pini — kategori emojili yuvarlak rozet */
.isletme-pin-sar { background: transparent; border: 0; }
.isletme-pin {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  background: #fff;
  border: 2px solid var(--sari);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .3);
  font-size: 15px; line-height: 1;
}
.durak-etiket-tip {
  background: var(--koyu);
  color: var(--sari);
  border: 0;
  font-weight: 700;
  font-size: .78rem;
  padding: 3px 8px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .3);
}
.durak-etiket-tip::before { border-top-color: var(--koyu); }

/* harita popup (ucretli durak) */
.harita-popup { display: flex; flex-direction: column; gap: 5px; min-width: 170px; }
.harita-popup strong { font-size: 1rem; }
.harita-popup-saat { color: var(--gri-metin); font-size: .82rem; }
.harita-popup-btn {
  display: block;
  text-align: center;
  padding: 7px 10px;
  border-radius: 7px;
  font-weight: 700;
  text-decoration: none;
  font-size: .9rem;
}
.harita-popup-ara { background: var(--sari); color: var(--koyu); }
.harita-popup-wa { background: var(--whatsapp); color: #fff; }
.harita-popup-detay { font-size: .85rem; }
.harita-popup-mesafe {
  font-size: .85rem;
  font-weight: 700;
  color: var(--yesil-koyu);
}
.harita-popup-mesafe-btn {
  font: inherit;
  font-size: .82rem;
  font-weight: 700;
  text-align: left;
  padding: 5px 8px;
  border: 1px dashed var(--sari-koyu);
  border-radius: 7px;
  background: #fffaf0;
  color: var(--sari-koyu);
  cursor: pointer;
}

/* ---- durak listesi ---- */
#duraklar, .isletme-bolum { scroll-margin-top: 74px; }
.duraklar-bolum { margin: 32px 0; }
.duraklar-bolum h2 { font-size: 1.4rem; margin-bottom: 16px; }
.durak-liste {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}
.durak-kart {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #fff;
  border: 1px solid var(--gri-cizgi);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--golge);
}
.durak-kart--one-cikan { border-color: var(--sari); }
.durak-kart--sponsor { border-color: var(--sari); background: #fffdf3; }
.durak-kart-bas {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.durak-kart h3 { margin: 0 0 4px; font-size: 1.15rem; }
.durak-kart h3 a { color: var(--koyu); text-decoration: none; }
.durak-kart h3 a:hover { color: var(--yesil-koyu); }
.durak-kart-meta { margin: 4px 0; color: var(--gri-metin); font-size: .9rem; }
.durak-kart-aciklama { margin: 8px 0 10px; color: var(--gri-metin); font-size: .92rem; }
.durak-kart-harita {
  height: 150px;
  border-radius: 8px;
  margin: 0 0 12px;
  background: var(--gri-acik);
  border: 1px solid var(--gri-cizgi);
  z-index: 1;
}
.durak-kart-aksiyon { display: flex; flex-wrap: wrap; gap: 8px; }

/* ---- rozetler ---- */
.durak-rozetler { display: flex; gap: 4px; flex-wrap: wrap; }
.rozet {
  display: inline-block;
  font-size: .72rem;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 999px;
  white-space: nowrap;
}
.rozet--one-cikan { background: var(--sari); color: var(--koyu); }
.rozet--sponsor { background: var(--koyu); color: var(--sari); }

/* ---- vitrin showcase (öne çıkan duraklar) ---- */
.vitrin-showcase { margin: 28px 0; }
.vitrin-showcase h2 { font-size: 1.4rem; margin: 0 0 14px; }
.vitrin-liste {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 18px;
}
.vitrin-kart {
  display: flex;
  flex-direction: column;
  background: #fffdf3;
  border: 2px solid var(--sari);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--golge-buyuk);
}
.vitrin-kart-sira {
  background: linear-gradient(135deg, var(--sari), var(--sari-koyu));
  color: var(--koyu);
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .06em;
  padding: 7px 14px;
}
.vitrin-kart-govde { padding: 14px; display: flex; flex-direction: column; }
.vitrin-kart-govde h3 { margin: 0 0 4px; font-size: 1.22rem; }
.vitrin-kart-govde h3 a { color: var(--koyu); text-decoration: none; }
.vitrin-kart-govde h3 a:hover { color: var(--yesil-koyu); }
.vitrin-kart-meta { margin: 0 0 10px; color: var(--gri-metin); font-size: .92rem; }
.vitrin-kart-aksiyon { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.vitrin-kart-aksiyon .btn-ara { flex: 1 1 auto; }

/* ---- seo girizgah ---- */
.seo-girizgah {
  margin: 32px 0;
  padding: 20px;
  background: var(--gri-acik);
  border-radius: var(--radius);
}
.seo-girizgah h2 { margin-top: 0; font-size: 1.25rem; }

/* ---- breadcrumb ---- */
.breadcrumb {
  margin: 16px 0;
  font-size: .88rem;
  color: var(--gri-metin);
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.breadcrumb a { color: var(--gri-metin); }

/* ---- durak detay ---- */
.durak-detay { margin-bottom: 40px; }
.durak-detay-bas { margin-bottom: 16px; }
.durak-detay-bas h1 { margin: 6px 0; font-size: 1.7rem; }
.durak-mahalle { margin: 0; color: var(--gri-metin); }
.durak-aksiyon { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0; }
.durak-bilgi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin: 20px 0;
}
.bilgi-kart {
  background: #fff;
  border: 1px solid var(--gri-cizgi);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--golge);
}
.bilgi-kart h2 { margin-top: 0; font-size: 1.2rem; }
.bilgi-kart dl { display: grid; grid-template-columns: auto 1fr; gap: 6px 14px; margin: 0; }
.bilgi-kart dt { font-weight: 700; color: var(--gri-metin); }
.bilgi-kart dd { margin: 0; }
.durak-aciklama { margin-top: 14px; color: var(--gri-metin); }
.harita-yol-tarifi { display: inline-block; margin-top: 10px; font-size: .9rem; }

/* ---- yorumlar ---- */
.yorum-bolum { margin-top: 32px; }
.yorum-bolum h2 { font-size: 1.3rem; }
.yorum-ozet { margin: 10px 0 18px; font-size: 1.05rem; }
.yorum-ozet-puan { font-weight: 800; color: var(--sari-koyu); }
.yildizlar { color: var(--sari); letter-spacing: 2px; }
.yildizlar .bos { color: var(--gri-cizgi); }
.yorum-liste { display: flex; flex-direction: column; gap: 12px; }
.yorum-kart {
  background: #fff;
  border: 1px solid var(--gri-cizgi);
  border-radius: 10px;
  padding: 14px;
}
.yorum-kart-bas {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
.yorum-kart-ad { font-weight: 700; }
.yorum-kart-tarih { color: #999; font-size: .82rem; }
.yorum-kart-metin { margin: 6px 0 0; }
.yorum-yok { color: var(--gri-metin); }

/* ---- yorum formu ---- */
.yorum-form-sar {
  margin-top: 24px;
  padding: 20px;
  background: var(--gri-acik);
  border-radius: var(--radius);
}
.yorum-form-sar h3 { margin-top: 0; }
.yorum-form { display: flex; flex-direction: column; gap: 14px; max-width: 520px; }
.yorum-form label { font-weight: 700; display: flex; flex-direction: column; gap: 5px; }
.yorum-form input[type="text"],
.yorum-form textarea {
  font: inherit;
  padding: 10px;
  border: 1px solid var(--gri-cizgi);
  border-radius: 8px;
  width: 100%;
}
.yorum-form textarea { resize: vertical; }
.puan-secim { border: 0; padding: 0; margin: 0; }
.puan-secim legend { font-weight: 700; padding: 0; margin-bottom: 4px; }
.yildiz-secim { display: inline-flex; flex-direction: row-reverse; }
.yildiz-secim input { position: absolute; opacity: 0; width: 0; }
.yildiz-secim label {
  font-size: 2rem;
  color: var(--gri-cizgi);
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
}
.yildiz-secim input:checked ~ label,
.yildiz-secim label:hover,
.yildiz-secim label:hover ~ label { color: var(--sari); }
.yildiz-secim input:focus-visible ~ label { outline: 2px solid var(--yesil-koyu); }
.yorum-form-not { font-size: .85rem; color: var(--gri-metin); margin: 0; }
.yorum-form-mesaj { margin: 0; font-weight: 700; }
.yorum-form-mesaj.basarili { color: var(--yesil-koyu); }
.yorum-form-mesaj.hata { color: var(--kirmizi); }

/* ---- icerik sayfalari ---- */
.icerik-sayfa { padding-bottom: 40px; }
.icerik-sayfa h1 { font-size: 1.7rem; }
.icerik-sayfa h2 { font-size: 1.3rem; margin-top: 28px; }
.icerik-giris { font-size: 1.05rem; color: var(--gri-metin); }
.durak-link-liste { padding-left: 20px; }
.durak-link-liste li { margin: 6px 0; }
.sss details {
  border: 1px solid var(--gri-cizgi);
  border-radius: 10px;
  padding: 12px 14px;
  margin: 8px 0;
  background: #fff;
}
.sss summary { font-weight: 700; cursor: pointer; }
.sss details p { margin: 8px 0 0; }

/* ---- iletisim ---- */
.iletisim-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin: 20px 0;
}
.iletisim-kart {
  background: #fff;
  border: 1px solid var(--gri-cizgi);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--golge);
  margin-bottom: 20px;
}
.iletisim-kart h2 { margin-top: 0; }
.iletisim-kart--vurgu { border-color: var(--sari); background: #fffdf3; }
.ozellik-liste { padding-left: 20px; }
.ozellik-liste li { margin: 6px 0; }

/* ---- footer ---- */
.site-footer { background: var(--koyu); color: #cfcfcf; margin-top: 40px; }
.footer-inner {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 24px;
  padding: 32px 16px 20px;
}
.footer-col strong { color: #fff; display: block; margin-bottom: 8px; }
.footer-col p { margin: 0; font-size: .9rem; }
.footer-col a { display: block; color: #cfcfcf; text-decoration: none; font-size: .9rem; padding: 3px 0; }
.footer-col a:hover { color: var(--sari); }
.footer-bottom {
  border-top: 1px solid #333;
  padding: 14px 16px;
  font-size: .82rem;
  color: #9a9a9a;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.footer-foto-kredi { font-size: .62rem; color: #565656; }

/* ---- işletmeler (restoran / tur servisi) ---- */
.isletme-bolum { margin: 34px 0; }
.isletme-bolum h2 { font-size: 1.4rem; margin: 0 0 16px; }

/* Duyuru slider — anasayfa guncel Urla duyurulari */
.duyuru-slider { margin: 18px 0 4px; position: relative; }
.duyuru-pencere {
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid #f3d9bf;
}
.duyuru-track { display: flex; transition: transform .45s ease; }
.duyuru-slide {
  flex: 0 0 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 15px 20px;
  background: linear-gradient(100deg, #fff7e8 0%, #fff 62%);
}
.duyuru-ikon { font-size: 1.5rem; flex-shrink: 0; }
.duyuru-govde { flex: 1; min-width: 0; }
.duyuru-baslik { margin: 0; font-weight: 700; font-size: 1.02rem; }
.duyuru-metin {
  margin: 3px 0 0;
  color: var(--gri-metin);
  font-size: .92rem;
}
.duyuru-link {
  flex-shrink: 0;
  font-weight: 700;
  color: var(--sari-koyu);
  text-decoration: none;
  white-space: nowrap;
}
.duyuru-link:hover { text-decoration: underline; }
.duyuru-noktalar {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 9px;
}
.duyuru-nokta {
  width: 8px; height: 8px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #d6d8dc;
  cursor: pointer;
}
.duyuru-nokta.aktif { background: var(--sari-koyu); }

/* Populer bolum — en cok iletisime gecilen isletmeler */
.populer-bolum {
  margin: 28px 0;
  padding: 20px;
  background: linear-gradient(135deg, #fff6ed 0%, #fff 70%);
  border: 1px solid #f3d9bf;
  border-radius: 14px;
  scroll-margin-top: 74px;
}
.populer-bolum h2 { font-size: 1.4rem; margin: 0 0 4px; }
.populer-not { margin: 0 0 16px; color: var(--gri-metin); font-size: .92rem; }
.isletme-liste {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}
.isletme-kart {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--gri-cizgi);
  border-top: 3px solid var(--sari);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--golge);
  transition: transform .12s ease, box-shadow .12s ease;
}
.isletme-kart:hover { transform: translateY(-3px); box-shadow: var(--golge-buyuk); }
.isletme-kart--vitrin { border: 2px solid var(--sari); background: #fffdf3; }
.isletme-kart-foto { aspect-ratio: 16 / 9; background: var(--gri-acik); }
.isletme-kart-foto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.isletme-kart-ic { padding: 14px; display: flex; flex-direction: column; flex: 1; }
.isletme-kart-bas {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.isletme-kart-bas h3 { margin: 0 0 4px; font-size: 1.15rem; }
.isletme-kart-aciklama { margin: 4px 0 8px; color: var(--gri-metin); font-size: .92rem; }
.isletme-kart-adres { margin: 0 0 10px; color: var(--gri-metin); font-size: .85rem; }
.isletme-kart-aksiyon { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.btn-rezervasyon { background: var(--yesil-koyu); color: #fff; }
.btn-rezervasyon:hover { filter: brightness(1.12); }

/* ---- rezervasyon modal ---- */
.rez-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 1000;
}
.rez-modal[hidden] { display: none; }
.rez-modal-ic {
  position: relative;
  background: #fff;
  border-radius: var(--radius);
  padding: 22px;
  width: 100%;
  max-width: 420px;
  max-height: 90vh;
  overflow-y: auto;
}
.rez-modal-ic h3 { margin: 0 0 4px; }
.rez-modal-isletme { margin: 0 0 14px; color: var(--yesil-koyu); font-weight: 700; }
.rez-modal-kapat {
  position: absolute;
  top: 6px;
  right: 12px;
  background: none;
  border: 0;
  font-size: 1.9rem;
  line-height: 1;
  cursor: pointer;
  color: var(--gri-metin);
}
#rez-form { display: flex; flex-direction: column; gap: 12px; }
#rez-form label { font-weight: 700; display: flex; flex-direction: column; gap: 5px; }
#rez-form input,
#rez-form textarea {
  font: inherit;
  padding: 9px 10px;
  border: 1px solid var(--gri-cizgi);
  border-radius: 8px;
}
#rez-form textarea { resize: vertical; }
.rez-form-mesaj { margin: 0; font-weight: 700; }
.rez-form-mesaj.basarili { color: var(--yesil-koyu); }
.rez-form-mesaj.hata { color: var(--kirmizi); }

/* ---- işletme puan butonu + yorum modal ---- */
.isletme-puan {
  align-self: flex-start;
  background: none;
  border: 0;
  padding: 2px 0;
  margin: 2px 0 8px;
  font: inherit;
  color: var(--gri-metin);
  cursor: pointer;
}
.isletme-puan:hover { color: var(--yesil-koyu); }
.isletme-puan-yildiz { color: var(--sari); }
.isletme-puan b { color: var(--koyu); }

.yorum-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 1000;
}
.yorum-modal[hidden] { display: none; }
.yorum-modal-ic {
  position: relative;
  background: #fff;
  border-radius: var(--radius);
  padding: 22px;
  width: 100%;
  max-width: 460px;
  max-height: 90vh;
  overflow-y: auto;
}
.yorum-modal-ic h3 { margin: 0 0 10px; }
.yorum-modal-kapat {
  position: absolute;
  top: 6px;
  right: 12px;
  background: none;
  border: 0;
  font-size: 1.9rem;
  line-height: 1;
  cursor: pointer;
  color: var(--gri-metin);
}
.yorum-modal-ozet { margin-bottom: 12px; font-size: 1.02rem; }
.yorum-modal-liste {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 320px;
  overflow-y: auto;
}
.yorum-yaz {
  margin-top: 14px;
  border-top: 1px solid var(--gri-cizgi);
  padding-top: 12px;
}
.yorum-yaz summary { font-weight: 700; cursor: pointer; color: var(--yesil-koyu); }
#yorum-modal-form { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
#yorum-modal-form label { font-weight: 700; display: flex; flex-direction: column; gap: 5px; }
#yorum-modal-form input[type="text"],
#yorum-modal-form textarea {
  font: inherit;
  padding: 9px 10px;
  border: 1px solid var(--gri-cizgi);
  border-radius: 8px;
}
#yorum-modal-form textarea { resize: vertical; }

/* ---- responsive ---- */
@media (max-width: 720px) {
  .hero { padding: 40px 0 46px; }
  .hero h1 { font-size: 2.1rem; }
  .hero-sub { font-size: 1rem; }
  .durak-bilgi-grid { grid-template-columns: 1fr; }
  .iletisim-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .durak-liste { grid-template-columns: 1fr; }
}

/* ---- telefon (mobil) ---- */
@media (max-width: 600px) {
  .wrap { padding: 0 13px; }
  .header-inner { min-height: 62px; }
  .logo-img { height: 52px; }
  .site-nav { gap: 2px; }
  .site-nav a { padding: 6px 9px; font-size: .88rem; }
  .hero { padding: 32px 0 46px; }
  .hero h1 { font-size: 1.9rem; }
  .hero-sub { font-size: .96rem; }
  .hero-chips { gap: 7px; margin-top: 18px; }
  .hero-chip { font-size: .82rem; padding: 7px 13px; }
  .duraklar-bolum h2, .isletme-bolum h2,
  .vitrin-showcase h2, .populer-bolum h2 { font-size: 1.22rem; }
  .vitrin-liste, .isletme-liste { grid-template-columns: 1fr; }
  .populer-bolum { padding: 14px; }
  .duyuru-slide { padding: 13px 14px; gap: 10px; }
  .duyuru-baslik { font-size: .96rem; }
}
