/* ── Self-host fontlar (latin + latin-ext; Türkçe için ikisi de gerekir, ASCII 'latin' subset'inde).
   Variable woff2 (tek dosya tüm ağırlıkları kapsar), font-display:swap. Google CDN bağımlılığı YOK. ── */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url(../fonts/hanken-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url(../fonts/hanken-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:600 800;font-display:swap;src:url(../fonts/bricolage-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:600 800;font-display:swap;src:url(../fonts/bricolage-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Spline Sans Mono';font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/spline-mono-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Spline Sans Mono';font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/spline-mono-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* Başlık fontu (Bricolage) için metrik-eşli fallback → swap-shift (CLS) azaltır. Override'lar gerçek TTF
   metriklerinden hesaplandı (upm1000, xAvg539, asc930, desc-270, gap0; Arial tabanlı). --font-d'de Bricolage'dan
   hemen sonra gelir; Arial yoksa (ör. Android) face düşer, davranış eskisi gibi (regresyon yok). */
@font-face{font-family:"Bricolage Fallback";src:local("Arial");size-adjust:122.11%;ascent-override:76.16%;descent-override:22.11%;line-gap-override:0.00%}

/* themes/eskisehirapartlar/assets/css/style.css — base (mobil öncelikli; ferah/sıcak beyaz, kırmızı-siyah kimlik).
   ── UI v2 / F1: TEK semantik token katmanı (önceki iki ayrı :root birleştirildi). Eski token ADLARI
   SİLİNMEDİ → geri uyum için yeni semantik değerlere ALIAS'landı (en altta "geri uyum" grubu). Marka kırmızısı
   TEK kaynak (--brand); WhatsApp yeşili (--wa) AYRI ve DOKUNULMAZ; yürüme-mesafe yeşili (--route) ayrı semantik.
   Bu faz YALNIZ token: selector/HTML/scope-remap/bileşen CSS'i DEĞİŞMEDİ. Koyu tema YOK. ──────────────────── */
:root{
  /* Marka (kırmızı-siyah) — TEK kaynak */
  --brand:#a82a23;--brand-deep:#7d1f1a;--brand-tint:#f7e9e7;
  /* Sıcak zemin / yüzey / kenarlık */
  --paper:#f5f4f1;--paper-2:#efece6;--paper-warm:#efe7d9;--card:#fff;--warm-line:#e4dfd7;
  /* Metin / nötr */
  --ink:#1a1a1a;--ink-soft:#6c655d;--coal:#171717;
  /* Yürüme/mesafe yeşili — WhatsApp'tan AYRI semantik */
  --route:#1f6f5c;--route-soft:#e7f1ed;
  /* WhatsApp yeşili — marka yeşili, DOKUNULMAZ */
  --wa:#25d366;--wa-btn:#1faf54;
  /* Cinsiyet + aksesuar semantik */
  --girls:#b8336a;--boys:#2f5d8c;--mixed:#766d62;--amber:#e2902f;
  /* TEK sıcak marka aksanı — ORTAK kaynak: header "Apartlar" + footer wordmark + 19 yıl + hero "tam kendine".
     Gradient/mercan denemeleri toparlandı → tek düz sıcak kırmızı (renk yarışı yok). */
  --accent-warm:#b43a2f;
  /* Durum (infra — değerler mevcut bileşenlerle birebir; bileşenler sonraki fazda adapte edecek) */
  --ok:#1f7a3d;--ok-bg:#e8f6ec;--ok-line:#b7e0c2;--err:#b32b2b;--err-bg:#fdeaea;--err-line:#f3c0c0;
  /* Sıcak gradient (infra — kırmızı→turuncu→sıcak sarı; v2'de yüzeylerde kullanılacak, F1'de UYGULANMIYOR) */
  --grad-warm:linear-gradient(90deg,#a82a23 0%,#d2521f 55%,#e8a13a 100%);
  /* Şekil / derinlik */
  --radius:18px;--radius-sm:12px;--radius-pill:999px;
  --shadow:0 1px 2px rgba(27,25,22,.04),0 8px 24px rgba(27,25,22,.06);
  --shadow-lg:0 8px 18px rgba(27,25,22,.08),0 24px 60px rgba(27,25,22,.12);
  /* Tipografi */
  --font-d:"Bricolage Grotesque","Bricolage Fallback",system-ui,-apple-system,Segoe UI,sans-serif;
  --font-b:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-m:"Spline Sans Mono",ui-monospace,SFMono-Regular,monospace;
  /* ── Geri uyum ALIAS'ları: eski adlar KORUNUR → tek semantik kaynağa bağlı (çift değer/çift kırmızı son buldu) ── */
  --c:var(--brand);        /* eski marka kırmızısı (#c1121f) → tek --brand */
  --c-d:var(--brand-deep); /* eski koyu hover (#8f0d16) → tek --brand-deep */
  --mut:var(--ink-soft);   /* eski muted gri (#6b7280) → warm --ink-soft */
  --line:var(--warm-line); /* eski kenarlık (#e6e8ec) → --warm-line */
  --bg:var(--paper);       /* eski zemin (#f7f7f8) → sıcak --paper */
  --green:var(--route);    /* eski genel yeşil (#2c6e49) → --route (WhatsApp DEĞİL) */
}
/* Global temel tipografi: gövde Hanken, başlıklar Bricolage. Renkler/boyutlar mevcut kurallarda kalır. */
h1,h2,h3{font-family:var(--font-d);letter-spacing:-.01em}
:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px;border-radius:6px}
/* Koyu yüzeylerde (footer/slider/güven bandı/koyu nav paneli) odak halkası beyaz → görünür kalsın. */
.site-foot :focus-visible,.hslider :focus-visible,.trust :focus-visible,.map-box:focus-visible{outline-color:#fff}
/* Hareket azaltma: tüm geçiş/animasyonları kapat (slider autoplay zaten app.js'te kapalı). */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition:none!important;animation:none!important;scroll-behavior:auto!important}}
/* Anasayfa gövde zemini (.home-v2 sarmalayıcı commit 3/4'te eklenir). Kabuk + anasayfa sıcak çizgi/WA tonu. */
.home-v2{background:var(--paper);color:var(--ink)}
/* Scope remap (UI v2 F5 sadeleştirme): --line artık :root'ta zaten --warm-line → tekrar kaldırıldı.
   --wa burada FONKSİYONEL: bu kapsamlarda WhatsApp butonu --wa-btn (yumuşak buton yeşili) kullanır. */
.home-v2,.site-head,.site-foot{--wa:var(--wa-btn)}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font-b);color:var(--ink);background:var(--card);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%}
a{color:var(--c)}
.container{max-width:1160px;margin:0 auto;padding:0 14px}
/* Header — tek satır kabuk (yeni tasarım): aramasız; beyaz "Tüm Apartlar" CTA; alt ince kırmızı aksan
   çizgisi; ≤1180px hamburger (#mainnav.open — app.js mevcut mekanizma). Nav link hedefleri DEĞİŞMEDİ. */
.site-head{position:sticky;top:0;z-index:40;background:var(--card);border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(27,25,22,.02)}
.site-head::after{content:"";display:block;height:3px;background:linear-gradient(90deg,var(--brand),var(--brand-deep))}
.head-row{position:relative;display:flex;align-items:center;gap:12px;min-height:64px}
.brand{display:inline-flex;align-items:baseline;gap:9px;font-family:var(--font-d);font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink);text-decoration:none;white-space:nowrap;flex:0 0 auto}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:9px;background:var(--brand);color:#fff;flex:0 0 auto;align-self:center}
.brand-txt span{color:var(--brand)}
/* Header wordmark "Apartlar" = ORTAK tek sıcak marka rengi (--accent-warm). Gradient denemesi geri alındı.
   "Eskişehir" (.brand-txt) koyu (--ink) kalır; yalnız .site-head scope (logo görseli varsa etkilenmez). */
.site-head .brand-txt span{color:var(--accent-warm)}
.brand-logo{height:42px;width:auto;display:block}
.brand-yr{font-family:var(--font-m);font-size:10px;font-weight:600;color:#fff;background:var(--ink);padding:3px 7px;border-radius:var(--radius-pill);letter-spacing:.04em;align-self:center}
.head-nav{display:flex;align-items:center;gap:1px;margin-left:auto}
.head-nav a{position:relative;padding:9px 11px;font-weight:500;font-size:14px;color:#403b34;text-decoration:none;white-space:nowrap;transition:color .16s}
/* Hover/active: kayan kırmızı alt çizgi (scaleX). reduced-motion'da transition kapalı → anında görünür. */
.head-nav a::after{content:"";position:absolute;left:11px;right:11px;bottom:3px;height:2px;border-radius:2px;background:var(--brand);transform:scaleX(0);transform-origin:left;transition:transform .18s}
.head-nav a:hover,.head-nav a.active{color:var(--ink)}
.head-nav a:hover::after,.head-nav a.active::after{transform:scaleX(1)}
/* "+ Apart Ekle" öncesi ince ayraç (sol kenarlık). */
.head-nav a.nav-add{font-weight:600;color:var(--ink);margin-left:6px;padding-left:17px;border-left:1px solid var(--line)}
.head-nav a.nav-add::after{display:none}
.head-nav .nav-extra{display:none}
.cta-all{display:inline-flex;align-items:center;gap:6px;background:var(--card);color:var(--brand);border:1.5px solid var(--brand);font-weight:700;font-size:14px;padding:9px 14px;border-radius:var(--radius-pill);text-decoration:none;flex:0 0 auto;transition:.18s}
.cta-all:hover{background:var(--brand);color:#fff;box-shadow:var(--shadow)}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:1px solid var(--line);border-radius:11px;background:var(--card);cursor:pointer;flex:0 0 auto;padding:0;margin-left:auto}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:0 auto;border-radius:2px;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* ≤1180: nav → hamburger paneli; cta-all gizlenir, "Tüm Apartlar"/"Soru Sor" panele iner (.nav-extra). */
@media(max-width:1180px){
  .nav-toggle{display:flex}
  .cta-all{display:none}
  .head-nav{display:none;position:absolute;left:0;right:0;top:100%;z-index:50;flex-direction:column;align-items:stretch;gap:0;margin:0;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);padding:6px 0}
  .head-nav.open{display:flex}
  .head-nav a{padding:13px 18px;border-radius:0;font-size:15px;font-weight:600;border-bottom:1px solid var(--line)}
  .head-nav a:last-child{border-bottom:0}
  .head-nav a::after{display:none}
  .head-nav a.nav-add{border-left:0;margin-left:0;padding-left:18px}
  .head-nav .nav-extra{display:block}
  .head-nav a.nav-allcta{color:var(--brand);font-weight:700}
}
@media(max-width:560px){ .brand{font-size:18px} .head-row{min-height:58px} }
/* Footer — koyu, 4 kolon (yeni tasarım). Sosyal/iletişim linkleri header üst bardan buraya taşındı. */
.site-foot{background:var(--ink);color:#cfc8bf;margin-top:46px;padding:46px 0 26px;font-size:14px}
.site-foot a{color:#cfc8bf;text-decoration:none}
.site-foot a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:26px}
.foot-brand .brand{color:#fff}
.foot-logo{height:40px;width:auto;max-width:200px;display:block}
/* Footer/koyu zemin marka aksanı = GÜÇLÜ sıcak mercan (markanın koyu zeminde aydınlık/canlı türevi).
   F5'teki soluk color-mix geri alındı (kullanıcı tercihi); koyu zeminde net + canlı dursun diye doygun ton. */
.foot-brand .brand .brand-txt span{color:var(--accent-warm)}
.foot-brand p{font-size:13.5px;margin:12px 0 0;max-width:26em;color:#cfc8bf;line-height:1.55}
/* Footer güven rozeti "19 yıldır yayında" — sade pill (header 19 YIL rozetinin sakin/açıklayıcı footer karşılığı).
   Koyu zeminde okunur açık yazı + ince kenarlık + küçük warm aksan nokta; kendi satırında, içerik-genişliği
   (mobilde taşmaz, link kolonlarına yaklaşmaz). */
.foot-yr{display:flex;width:max-content;max-width:100%;align-items:center;gap:7px;margin-top:14px;padding:5px 11px;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-pill);background:rgba(255,255,255,.04);font-family:var(--font-m);font-size:11px;font-weight:600;letter-spacing:.02em;color:#cfc8bf}
.foot-yr::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-warm);flex:none}
.foot-col h4{font-family:var(--font-d);color:#fff;font-size:14px;font-weight:600;margin:0 0 12px}
.foot-col a{display:block;font-size:13.5px;padding:5px 0}
.foot-social{display:flex;gap:10px;margin-top:14px}
.foot-social a{display:inline-flex;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);align-items:center;justify-content:center;color:#cfc8bf}
.foot-social a:hover{background:rgba(255,255,255,.16);color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;border-top:1px solid #322e29;margin-top:30px;padding-top:18px;font-size:12.5px;color:#9a948b}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1 / -1}}
/* Mobil footer kompakt: marka tam genişlik, 3 link grubu 2 sütun → dikey uzama azalır. */
@media(max-width:560px){
  .site-foot{margin-top:32px;padding:30px 0 20px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:16px 22px}
  .foot-brand{grid-column:1 / -1}
  .foot-brand p{margin-top:8px;font-size:13px;max-width:none}
  .foot-yr{margin-top:10px}
  .foot-social{margin-top:12px}
  .foot-col h4{margin-bottom:8px}
  .foot-col a{padding:4px 0;font-size:13px}
  .foot-bottom{margin-top:22px;padding-top:14px;flex-direction:column;gap:4px;text-align:center;font-size:12px}
}

/* ── Yukarı çık oku (sayfa başına dön) — mobil öncelikli, tüm sayfalar ── */
.to-top{position:fixed;right:16px;bottom:18px;z-index:45;width:44px;height:44px;display:flex;align-items:center;justify-content:center;padding:0;border:none;border-radius:50%;background:var(--brand);color:#fff;box-shadow:0 4px 14px rgba(27,25,22,.22);cursor:pointer;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s}
.to-top.is-visible{opacity:1;visibility:visible;transform:none}
.to-top:hover{filter:brightness(.94)}
.to-top:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
/* Detay sayfası mobil sticky CTA (Ara/WhatsApp) üstünde dur → çakışma yok. */
@media(max-width:900px){body:has(.ld-sticky) .to-top{bottom:76px}}
@media(prefers-reduced-motion:reduce){.to-top{transition:none}}
/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--brand);color:#fff;padding:11px 18px;border-radius:var(--radius-sm);text-decoration:none;border:0;cursor:pointer;font-size:15px;font-weight:700;transition:background .16s,box-shadow .16s}
.btn:hover{background:var(--brand-deep);box-shadow:var(--shadow)}
.btn.ghost{background:var(--brand-tint);color:var(--brand)}
.btn.ghost:hover{background:var(--brand);color:#fff}
/* Yardımcı renk varyantları: yürüme yeşili / WhatsApp — hover'da marka kırmızısına DÖNMEZ (kendi rengini korur). */
.btn.green{background:var(--route)} .btn.green:hover{background:var(--route)}
.btn.wa{background:var(--wa)} .btn.wa:hover{background:var(--wa)}
/* ───────── HERO (yeni tasarım): sol kopya + sağ slider. .home-v2 kapsamında (paper zemin). ─────────
   NOT (UI v2 F5): eski jenerik .hero/.hero-actions/.hero-search bloğu hiçbir şablonda kullanılmıyordu →
   ölü kod olarak kaldırıldı. Anasayfa .home-hero, landing/liste .lp-hero kullanır (aşağıda/ileride). */
.home-hero{padding:30px 0 32px}
/* Hero bandı (Faz 2): tanımlı bej + alt kenarlık → listeleme grid'inden net ayrım (önceki "paper'a erir"in yerine). .home-v2 scope. */
.home-v2 .home-hero{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--warm-line)}
/* Hedef dizini Tüm Apartlar'da (tam genişlik .listing-wrap) → 4 sütun; anasayfa dar kolonda 2 sütun kalır (bileşen aynı). */
.listing-page .hero-dests .hd-grid{grid-template-columns:repeat(4,1fr)}
@media(max-width:760px){.listing-page .hero-dests .hd-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.listing-page .hero-dests .hd-grid{grid-template-columns:1fr}}
/* Tüm Apartlar: hedef dizini ↔ cinsiyet çipi ↔ grid arasına dikey nefes (sıkışmayı gider; alan statik → CLS=0). */
.listing-page .hero-dests{margin-bottom:26px}
.listing-page .genfilter{margin-bottom:20px}
.home-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:38px;align-items:stretch}
/* Grid çocukları min-content'e genişleyip viewport dışına taşmasın (mobil yatay scroll kökü). */
.home-hero-grid>*{min-width:0}
/* H1: prototiple hizalı (clamp ~44px) + text-wrap:balance → masaüstünde 2 satırda biter (3 satır şişmesi yok). */
.home-hero h1{font-size:clamp(31px,3.6vw,44px);font-weight:800;line-height:1.06;letter-spacing:-.02em;color:var(--ink);text-wrap:balance}
/* Hero vurgu kelimesi "tam kendine" — gradient denemesi geri alındı; ORTAK tek sıcak marka rengi (--accent-warm).
   Diğer başlık kelimeleri koyu (--ink) kalır. Düz renk → okunurluk + marka tutarlılığı. */
.home-hero h1 em{font-style:normal;color:var(--accent-warm)}
.hh-lead{font-size:16.5px;color:var(--ink-soft);max-width:30em;margin:13px 0 18px}
/* Hero hedef kutucukları (hd-grid): 8 yakınlık landing'i. Üniversite=yeşil (.cap), merkez/ulaşım=kırmızı (.ctr). SSR → CLS yok. */
.hero-dests{margin-top:18px}
.hd-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
/* Çift sayıda buton (4): 2+2 dengeli; tek sayıda kalırsa son buton tam satır → defansif (anasayfa hero). */
.home-hero .hd-grid .hd-item:last-child:nth-child(odd){grid-column:1 / -1}
.hd-item{display:flex;align-items:center;gap:11px;min-width:0;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:10px 12px;text-decoration:none;transition:.16s}
.hd-item:hover{border-color:var(--route);transform:translateX(2px);box-shadow:var(--shadow)}
.hd-ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hd-ic.cap{background:var(--route-soft);color:var(--route)}
.hd-ic.ctr{background:var(--brand-tint);color:var(--brand)}
.hd-txt{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.hd-txt b{font-family:var(--font-d);font-weight:600;font-size:13.5px;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hd-txt small{font-size:11px;color:var(--ink-soft)}
.hd-arrow{margin-left:auto;color:var(--line);flex-shrink:0;display:flex}
.hd-item:hover .hd-arrow{color:var(--route)}
/* Mobil: yakınlık/hedef kartları 2 sütun KALIR ama daha okunur — küçük ikon, ok gizli (yer açar),
   başlık tek-satır-ellipsis yerine 2 satır line-clamp (uzun isim kesilmez), kompakt padding/font. */
@media(max-width:560px){
  .hd-grid{gap:8px}
  .hd-item{gap:8px;padding:8px 9px}
  .hd-ic{width:26px;height:26px;border-radius:7px}
  .hd-ic svg{width:14px;height:14px}
  .hd-arrow{display:none}
  .hd-txt b{font-size:12px;white-space:normal;line-height:1.15;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .hd-txt small{font-size:10px}
}
/* Slider: dış sarmalayıcı taşma görünür (dots dışarıda); iç viewport yuvarlatılmış/taşma gizli. */
.hslider{position:relative;min-width:0}
.hs-viewport{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:var(--paper-2)}
.hs-slide{display:none;position:relative;color:#fff;text-decoration:none}
.hs-slide.active{display:block}
.hs-cover{position:relative;aspect-ratio:16/10;background:var(--paper-2);overflow:hidden;display:block} /* sabit oran → CLS yok */
.hs-cover img{width:100%;height:100%;object-fit:cover;display:block}
/* Hafif alt gradient — yalnız metin okunurluğu için (görseli baskılamaz). */
.hs-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(transparent 62%,rgba(15,12,10,.46))}
/* Tek satır: apart adı solda, mesafeler sağda; dar alanda alt alta sarar (kenara yapışmaz, padding korunur). */
.hs-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 16px 15px;display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:7px 14px}
.hs-name{font-family:var(--font-d);font-weight:700;font-size:20px;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.5);min-width:0}
/* Mesafeler büyük buton değil → sade, küçük, yarı-şeffaf bilgi etiketi. */
.hs-info .dist{gap:5px;min-height:0;justify-content:flex-end}
.hs-info .dist .dchip,.hs-info .dist .dist-far{background:rgba(255,255,255,.86);border-color:transparent;padding:2px 8px;font-size:10.5px;border-radius:13px}
.hs-info .dist .dchip svg{width:12px;height:12px}
.hs-info .dist .dchip .to,.hs-info .dist .dchip svg,.hs-info .dist .dist-far{color:var(--ink-soft)}
.hs-info .dist .dchip.near{background:var(--route-soft)}
.hs-info .dist .dchip.near .to,.hs-info .dist .dchip.near svg,.hs-info .dist .dchip.near b{color:var(--route)}
/* Oklar: daha küçük, daha şeffaf, kenarlara yakın; içeriği baskılamaz. */
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.38);border:1px solid rgba(255,255,255,.3);box-shadow:0 1px 3px rgba(20,30,50,.06);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:17px;line-height:1;cursor:pointer;padding:0;transition:.16s}
.hs-arrow:hover{background:rgba(255,255,255,.8);color:var(--ink);border-color:rgba(255,255,255,.6);box-shadow:0 2px 7px rgba(20,30,50,.14)}
.hs-prev{left:6px} .hs-next{right:6px}
/* Slayt göstergesi (dots): görselin ALTINDA, ortalı, sade. Pasif = antrasit tint nokta; aktif = kırmızı pill. */
.hs-dots{display:flex;justify-content:center;align-items:center;gap:7px;padding:12px 0 0}
.hs-dot{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:rgba(26,26,26,.2);cursor:pointer;transition:width .2s,background .2s,border-radius .2s}
.hs-dot:hover{background:rgba(26,26,26,.42)}
.hs-dot.active{width:22px;border-radius:6px;background:var(--brand)}
.hs-dot:focus-visible{outline:2.5px solid var(--brand);outline-offset:3px}
.hs-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;height:100%;color:var(--ink-soft);font-weight:600;font-size:14px}
.hs-ph-ic{font-size:34px;opacity:.65;line-height:1}
.hs-ph-tx{max-width:80%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hero2-fallback{padding:26px 18px;background:var(--card);aspect-ratio:16/10;display:flex;flex-direction:column;justify-content:center}
.hero2-fb-lead{font-family:var(--font-d);font-size:19px;font-weight:700;margin:0 0 6px;color:var(--ink)} .hero2-fb-sub{margin:0 0 14px;color:var(--ink-soft);font-size:14px}
.hs-cta{display:inline-block;align-self:flex-start;background:var(--brand);color:#fff;font-weight:700;font-size:14px;padding:10px 16px;border-radius:var(--radius-sm);text-decoration:none;transition:background .16s,box-shadow .16s}
.hs-cta:hover{background:var(--brand-deep);box-shadow:var(--shadow)}
/* ── Hero görsel alanı reklam slider'ı (.lp-hero-slider) — landing/list hero'sunun SAĞ kutusunda statik
   görsel/harita yerine döner. Aynı .hslider/.hs-* bileşeni; hero banner kutusuyla AYNI 16:10 oran + 13px köşe
   (ayrı bölüm açmaz). Dots viewport altında, hero alanı içinde. CLS yok (aspect-ratio rezerve). */
.lp-hero-slider{min-width:0}
.lp-hero-slider .hs-viewport{border-radius:13px;border:1px solid var(--warm-line)}
/* Cinsiyet rozeti (kart + slider ortak) */
.badge{font-size:11px;font-weight:700;color:#fff;padding:4px 9px;border-radius:30px;letter-spacing:.01em;display:inline-block;line-height:1.3}
.badge.kiz{background:var(--girls)} .badge.erkek{background:var(--boys)} .badge.karma{background:var(--mixed)}
/* Yürüme-mesafesi çipleri (kart + slider ortak) */
.dist{display:flex;flex-wrap:wrap;gap:5px;min-height:24px} /* min-height: çip alanı yer ayırır → CLS yok */
.dchip{display:inline-flex;align-items:center;gap:5px;background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:4px 9px 4px 7px;font-size:11.5px;white-space:nowrap}
.dchip svg{color:var(--ink-soft);flex-shrink:0}
.dchip .to{color:var(--ink-soft)}
.dchip b{font-family:var(--font-m);font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink)}
/* near (en yakın + ≤15 dk) = AÇIK YEŞİL TİNT zemin + koyu yeşil yazı/ikon (#1f6f5c); doygun dolgu DEĞİL
   (WhatsApp yeşiliyle çakışmasın). moderate (diğerleri) = nötr (varsayılan .dchip). Kartta en fazla 1 near. */
.dchip.near{background:var(--route-soft);border-color:#bfe0d5}
.dchip.near svg,.dchip.near .to,.dchip.near b{color:var(--route)}
/* ≤25 hedef yoksa nötr "Şehir merkezine uzak" rozeti (dakikasız). */
.dist-far{display:inline-flex;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:4px 11px;font-size:11.5px;font-weight:600;color:var(--ink-soft)}
@media(max-width:860px){
  .home-hero-grid{grid-template-columns:1fr;gap:26px}
  .hslider{order:-1}
  .home-hero h1{font-size:clamp(30px,8vw,40px)}
}
@media(max-width:640px){.hs-arrow{width:28px;height:28px;font-size:16px}.hs-dots{gap:6px;padding-top:9px}.hs-dot{width:7px;height:7px}.hs-dot.active{width:18px}}
/* Dar ekran: apart adı + mesafeler alt alta, sola hizalı; padding korunur (kenara yapışmaz). */
@media(max-width:560px){.hs-info{flex-direction:column;align-items:flex-start;gap:8px}.hs-info .dist{justify-content:flex-start}}
/* Masaüstü: hero kolonları eşit yükseklik — slider sol kopya kadar uzar (flex-fill). Yükseklik flex'ten gelir
   (görselden DEĞİL) → CLS yok; min-height taban güvence. Mobilde (≤860) slider üstte + aspect-ratio korunur. */
@media(min-width:861px){
  .home-hero .hslider{display:flex;flex-direction:column}
  .home-hero .hs-viewport{flex:1;min-height:360px}
  .home-hero .hs-slide.active{height:100%}
  .home-hero .hs-cover{aspect-ratio:auto;height:100%}
  .home-hero .hero2-fallback{aspect-ratio:auto;height:100%}
}
/* Sections */
.sec{padding:30px 0}
.sec h2{font-size:21px;margin:0 0 4px}
.sec .lead{color:var(--mut);margin:0 0 18px}
/* ───────── Anasayfa vitrin kartı (yeni tasarım, .home-v2): stretched-link + 50/50 footer. ─────────
   Stretched-link kurgusu: .c-link (z1, kart geneli → detay) ve .btn-wa (z3, üstte) KARDEŞ <a> —
   iç içe DEĞİL. Görsel katmanlar pointer-events:none → tıklama c-link'e geçer; yalnız WhatsApp ayrık. */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--brand-tint)}
.c-link{position:absolute;inset:0;z-index:1}
.c-photo{position:relative;aspect-ratio:16/10;overflow:hidden;display:block;background:var(--paper-2)}
.c-photo img{width:100%;height:100%;object-fit:cover;display:block}
.c-photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(transparent 55%,rgba(0,0,0,.45));pointer-events:none}
.c-photo .c-badges{position:absolute;left:12px;top:12px;display:flex;gap:6px;z-index:2;pointer-events:none}
/* Yakınlık landing kartı: en yakın gerçek alt nokta rozeti (sağ üst; cinsiyet rozeti solda → çakışmaz).
   Koyu/siyah pill (kırmızı/siyah kimlik, sade); uzun ad tek satır ellipsis; mobilde taşmaz. */
.c-photo .c-near{position:absolute;right:12px;top:12px;z-index:2;max-width:64%;display:inline-block;background:rgba(23,23,23,.84);color:#fff;font-family:var(--font-m);font-size:11px;font-weight:700;line-height:1;padding:5px 9px;border-radius:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;box-shadow:0 1px 6px rgba(0,0,0,.28)}
.c-photo .ph-name{position:absolute;left:14px;right:14px;bottom:12px;z-index:2;color:#fff;font-family:var(--font-d);font-weight:700;font-size:16px;letter-spacing:-.01em;text-shadow:0 1px 10px rgba(0,0,0,.45);pointer-events:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.c-body{padding:14px 15px 15px;display:flex;flex-direction:column;gap:13px;flex:1}
.c-foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding-top:13px;border-top:1px solid var(--line)}
.c-priceline{flex:1;min-width:0}
.c-price{font-family:var(--font-d);font-weight:700;font-size:16px;line-height:1.1;color:var(--ink);white-space:nowrap}
.c-price small{font-family:var(--font-b);font-weight:500;font-size:12px;color:var(--ink-soft)}
.c-price.ask{color:var(--ink-soft);font-size:14px;font-weight:600;font-family:var(--font-b);display:inline-flex;align-items:center;gap:5px}
.c-tagic{color:var(--ink-soft);flex-shrink:0} /* nötr/muted fiyat-etiketi ikonu (inline; layout shift yok) */
.btn-wa{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--wa);color:#fff;font-weight:700;font-size:14px;padding:11px;border-radius:var(--radius-sm);text-decoration:none;position:relative;z-index:3;transition:filter .16s}
.btn-wa:hover{filter:brightness(.95)}
/* KYK kart altlığı: sol "Devlet yurdu" nötr etiket + sağ "Detay →" (brand-red ince çerçeve, stretched-link hedefi). */
.c-kyk-label{font-size:13.5px;font-weight:600;color:var(--ink-soft)}
.btn-detail{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--card);color:var(--brand);border:1.5px solid var(--brand);font-weight:700;font-size:13.5px;padding:10px;border-radius:var(--radius-sm);text-decoration:none;position:relative;z-index:3;transition:.16s}
.btn-detail:hover{background:var(--brand);color:#fff}
/* Tasarlanmış kapak placeholder (gri "Görsel yok" DEĞİL): gradyan + pencere deseni. Kart + slider ortak. */
.cover-ph{position:absolute;inset:0;display:block}
.cover-ph .windows{position:absolute;inset:0;opacity:.55;background-image:linear-gradient(rgba(255,255,255,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.14) 1px,transparent 1px);background-size:26px 32px;background-position:10px 16px}
/* Cinsiyet hızlı filtre — anasayfada pill grup (prototip). Client-side; URL DEĞİŞMEZ. İç sayfalar etkilenmez. */
/* Anasayfa (.home-v2) cinsiyet filtresi = base .genfilter ile AYNI segmented dil (yalnız alt boşluk farkı). */
.home-v2 .genfilter{display:inline-flex;gap:6px;background:var(--card);border:1px solid var(--line);padding:5px;border-radius:var(--radius-pill);margin:0 0 22px}
.home-v2 .gf-chip{border:0;background:none;color:var(--ink-soft);padding:9px 17px;border-radius:var(--radius-pill);font-weight:600;font-size:14px}
.home-v2 .gf-chip:hover{color:var(--ink);background:var(--paper)}
.home-v2 .gf-chip.active{background:var(--brand);border-color:var(--brand);color:#fff}
@media(max-width:1000px){.cards{grid-template-columns:repeat(2,1fr)}}
/* Mobil: apart kartları TEK değil 2 sütun. Dar ekranda taşmasın → min-width:0, küçük gap/padding,
   footer (fiyat + WhatsApp) dikey istif, fiyat satırı sarabilir. Görsel oranı (aspect-ratio) korunur.
   NOT: Bu kart kuralları ORTAK kart partial'ı (home-card.php) içindir → .home-v2'ye DEĞİL tüm .cards'a
   uygulanır. Böylece anasayfa + /apartlar + landing sayfalarında mobil kart davranışı tutarlı olur
   (eskiden .home-v2 kapsamı yüzünden iç sayfalarda WhatsApp fiyatın üstüne biniyor, çipler alt alta
   düşüyor, uzun başlık tek satır kalıyordu). Kart-içi sınıflar (.c-foot/.c-price/.btn-wa/.ph-name)
   yalnız kartta kullanıldığından de-scope güvenlidir. */
@media(max-width:560px){
  .cards{grid-template-columns:repeat(2,1fr);gap:11px}
  .cards .card{min-width:0}
  .cards .c-body{padding:11px 11px 12px;gap:10px}
  .cards .c-foot{flex-direction:column;align-items:stretch;gap:8px;padding-top:11px}
  .cards .c-price{font-size:14px;white-space:normal}
  .cards .btn-wa{padding:10px;font-size:13px}        /* WhatsApp geniş + okunur kalsın */
  .cards .btn-detail{padding:9px;font-size:12.5px}
  /* Kart başlığı (foto üzeri) en fazla 2 satır → uzun isim taşmasın/kesilmesin. */
  .cards .c-photo .ph-name{font-size:13.5px;white-space:normal;line-height:1.18;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .c-photo .c-near{font-size:10px;padding:4px 8px;max-width:74%} /* mobil 2-col: yaygın etiket+dk sığsın, uzunlar ellipsis */
  /* Mesafe çipleri TEK satır: ikon gizli, kompakt font/padding/gap, container sarmaz (taşarsa kırpılır). */
  .cards .dist{flex-wrap:nowrap;overflow:hidden;gap:4px;min-height:0}
  .cards .dchip{font-size:10px;padding:3px 7px;gap:0}
  .cards .dchip svg{display:none}
  .cards .dchip b{font-size:10px;margin-left:3px}
}
/* Cinsiyet hızlı filtre çipleri (client-side; karışık liste/vitrin — Faz 1) */
/* Cinsiyet hızlı filtre — TEK tasarım dili (anasayfa + listeleme/landing AYNI): segmented pill grubu.
   Sarmalayıcı = sıcak yüzey pill; çipler borderless; aktif = marka dolgu; hover = hafif paper tint.
   flex-wrap korunur (3 kısa çip taşmaz; mobilde güvenli). Tokenlar UI v2 ile uyumlu. */
.genfilter{display:inline-flex;flex-wrap:wrap;gap:6px;background:var(--card);border:1px solid var(--line);padding:5px;border-radius:var(--radius-pill);margin:0 0 16px}
.gf-chip{font:inherit;font-size:14px;font-weight:600;cursor:pointer;border:0;background:none;color:var(--ink-soft);padding:9px 17px;border-radius:var(--radius-pill);transition:background .14s,color .14s}
.gf-chip:hover{color:var(--ink);background:var(--paper)}
.gf-chip.active{background:var(--brand);color:#fff}
/* Category tiles */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.tile{display:flex;flex-direction:column;gap:4px;border:1px solid var(--warm-line);border-radius:var(--radius-sm);padding:18px;text-decoration:none;color:var(--ink);background:var(--paper);transition:border-color .15s,background .15s,box-shadow .15s,transform .15s}
.tile:hover{border-color:var(--brand-tint);background:var(--card);box-shadow:var(--shadow);transform:translateY(-2px)}
.tile .ic{font-size:24px}.tile b{font-size:15px}.tile small{color:var(--mut)}
/* Quick chips */
.qlinks{display:flex;gap:8px;flex-wrap:wrap}
.qlink{display:inline-block;padding:8px 14px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--ink);font-size:14px;background:var(--card)}
.qlink:hover{border-color:var(--c);color:var(--c)}
.qgroup{margin-bottom:14px}.qgroup .lbl{font-size:13px;color:var(--mut);font-weight:600;margin-bottom:6px}
.eyebrow{font-family:var(--font-m);font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--brand)}
/* ── Harita bölümü (ikincil): STATİK görsel önizleme → /harita. Anasayfada üçüncü-parti harita JS YOK. ── */
.mapsec{background:var(--paper-2);border-top:1px solid var(--line)}
.map-box{position:relative;display:block;border-radius:22px;overflow:hidden;min-height:330px;border:1px solid var(--line);background:radial-gradient(80% 60% at 30% 30%,#dfe9e4,transparent),linear-gradient(160deg,#eef1ee,#e4e8e6);box-shadow:var(--shadow);text-decoration:none}
.mapsec-bridge{min-height:300px} /* tam-genişlik /harita köprüsü; min-height alanı rezerve → CLS yok */
.map-box img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block} /* statik harita görseli; min-height alanı rezerve → CLS yok */
.map-box .grid-lines{position:absolute;inset:0;opacity:.6;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px}
.map-box .river{position:absolute;left:-5%;right:-5%;top:55%;height:30px;background:linear-gradient(90deg,transparent,#bcd9e8,#a9d0e3,#bcd9e8,transparent);transform:rotate(-7deg);filter:blur(.5px);border-radius:40px}
/* CSS/SVG sade harita illüstrasyonu (Google embed YOK): yürüme rotası + apart/kampüs pinleri + ara noktalar. */
.map-box .lp-map-svg{position:absolute;inset:0;width:100%;height:100%;z-index:1;overflow:visible}
.map-box .lp-route{stroke:var(--route);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:1 9;opacity:.85}
.map-box .lp-spot{fill:var(--ink-soft);opacity:.35}
.map-box .lp-pin-apart .lp-pin-dot{fill:var(--brand)}
.map-box .lp-pin-apart .lp-pin-ring{fill:none;stroke:var(--brand);stroke-width:2;opacity:.4}
.map-box .lp-pin-dest .lp-pin-mark{fill:var(--route);filter:drop-shadow(0 2px 3px rgba(20,30,50,.18))}
.map-box .lp-pin-dest .lp-pin-hole{fill:#fff}
.map-box .pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center}
.map-box .pin span{background:var(--brand);color:#fff;font-size:11px;font-weight:700;padding:4px 9px;border-radius:20px;white-space:nowrap;box-shadow:var(--shadow)}
.map-box .pin.route span{background:var(--route)}
.map-box .pin i{width:11px;height:11px;border-radius:50%;background:var(--card);border:3px solid var(--brand);margin-top:-1px;display:block}
.map-box .pin.route i{border-color:var(--route)}
.map-box .map-open{position:absolute;right:14px;bottom:14px;z-index:2;background:var(--card);color:var(--ink);font-weight:700;font-size:13px;padding:8px 13px;border-radius:30px;box-shadow:var(--shadow)}
.map-box:hover .map-open{background:var(--brand);color:#fff}
/* Mesafe bul — apart-detay mesafe diliyle uyumlu: sol form/sonuç + sağ GERÇEK Google Embed harita (rota).
   Vanilla JS; finder ID'leri korunur; CLS guard = result min-height + sabit harita yüksekliği. */
.finder{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.finder-left{display:flex;flex-direction:column;gap:14px}
.finder-controls{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.finder label{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft)}
.finder select{width:100%;padding:11px 36px 11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:14.5px;font-weight:600;background-color:var(--card);color:var(--ink);font-family:var(--font-b);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236c655d' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}
.finder-result{display:flex;align-items:center;gap:10px;min-height:54px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 16px}
.finder-walkic{font-size:20px;line-height:1;flex-shrink:0}
.finder-min{font-family:var(--font-m);font-weight:700;font-size:22px;color:var(--route);font-variant-numeric:tabular-nums;line-height:1}
.finder-lbl{font-size:14px;color:var(--ink-soft)}
.finder-none{color:var(--ink-soft)}
.finder-links{display:flex;flex-wrap:wrap;gap:8px 20px;align-items:center}
.finder-detail{color:var(--brand);font-weight:700;font-size:14px;text-decoration:none}
.finder-detail:hover{color:var(--brand-deep);text-decoration:underline}
.finder-maplink{color:var(--ink-soft);font-weight:600;font-size:13.5px;text-decoration:none}
.finder-maplink:hover{color:var(--brand);text-decoration:underline}
/* Sağ kolon GERÇEK harita (Google Embed directions). Sabit yükseklik → CLS yok + yamalı grid değil. */
.finder-mapwrap{min-width:0}
.finder-map{width:100%;height:320px;border:0;border-radius:var(--radius-sm);display:block;background:var(--paper-2)}
.finder-mapfallback{display:flex;align-items:center;justify-content:center;text-align:center;height:320px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper-2);color:var(--brand);font-weight:700;font-size:14px;text-decoration:none;padding:16px}
.finder-mapfallback:hover{background:var(--paper)}
@media(max-width:760px){.finder{grid-template-columns:1fr} .finder-map,.finder-mapfallback{height:280px}}
@media(max-width:560px){.finder-controls{grid-template-columns:1fr}}

/* ── /harita "Rota Haritası" (HEDEF-ÖNCE): masaüstü sol panel + büyük sağ harita (geniş container);
      mobil panel üstte + harita altta. .finder-* sonuç sınıfları (walkic/min/lbl) paylaşılır.
      KENDİ ID'leri (#rmap-*) → app.js'in #finder bloğu etkilenmez (anasayfa Mesafe bul bozulmaz). ── */
.rmap > .container{max-width:1320px} /* /harita masaüstünde daha geniş, dolu görünüm (yalnız bu sayfa) */
.rmap{padding:22px 0 44px}
/* Üst başlık BANDI: grid'den bağımsız, tam container genişliği + alt ayraç → "sayfa başlığı" hissi. */
.rmap-head{width:100%;margin:0 0 24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.rmap-head h1{font-size:clamp(22px,3.1vw,32px);font-weight:800;letter-spacing:-.02em;margin:0 0 8px;color:var(--ink)}
.rmap-lead{color:var(--ink-soft);font-size:15.5px;line-height:1.6;margin:0;max-width:1040px}
/* Panel DOĞAL yükseklikte (liste ezilmez); harita sticky + sabit yükseklik → güçlü kalır ama paneli sıkıştırmaz. */
.rmap-layout{display:grid;grid-template-columns:minmax(360px,420px) 1fr;gap:22px;align-items:start}
.rmap-panel{display:flex;flex-direction:column;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
/* Adım adım yönlendirme — SAKİN: kısa metin + zarif numara rozeti + nötr select (kırmızı yalnız focus). */
.rmap-guide{margin:0;font-size:12.5px;line-height:1.45;color:var(--ink-soft)}
.rmap-guide strong{color:var(--ink);font-weight:700}
.rmap-controls{display:flex;flex-direction:column;gap:13px}
.rmap-controls .rmap-field{display:flex;flex-direction:column;gap:6px}
.rmap-lab{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink-soft)}
.rmap-num{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--brand-tint);color:var(--brand);font-size:10px;font-weight:800;line-height:1;flex:none}
.rmap-controls select{width:100%;padding:11px 36px 11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:14.5px;font-weight:600;font-family:var(--font-b);background-color:var(--card);color:var(--ink);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236c655d' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.rmap-controls select:hover{border-color:var(--ink-soft)}
.rmap-controls select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}
.rmap-result{display:flex;align-items:center;gap:11px;min-height:58px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 16px}
.rmap-result .finder-min{font-family:var(--font-m);font-weight:800;font-size:23px;color:var(--route);line-height:1;flex:none}
.rmap-result .finder-lbl{font-size:13.5px;color:var(--ink-soft);line-height:1.3}
.rmap-result .finder-lbl small{display:block;font-size:11px;color:#9a948c;margin-top:2px;font-weight:600}
.rmap-result .finder-walkic{font-size:20px;line-height:1;flex:none}
.rmap-actions{display:flex;flex-direction:column;gap:8px}
.rmap-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-weight:700;font-size:14px;text-decoration:none;color:var(--ink);background:var(--paper);transition:.15s}
.rmap-btn:hover{border-color:var(--brand);color:var(--brand)}
.rmap-btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.rmap-btn.primary:hover{background:var(--brand-deep);color:#fff}
.rmap-nearest{display:flex;flex-direction:column}
.rmap-nearest h2{font-size:14px;font-weight:700;margin:4px 0 8px;color:var(--ink)}
/* Doğal akış — en fazla 8 satır (finder slice 8); kesilme/scroll yok, hepsi okunur. */
.rmap-near-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.rn-item{display:flex;align-items:stretch;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);overflow:hidden;transition:.15s}
.rn-item:hover{border-color:var(--ink-soft);background:var(--card)} /* sade hover — kırmızı değil */
.rn-item.active{border-color:var(--brand);background:var(--brand-tint);box-shadow:inset 3px 0 0 var(--brand)} /* aktif = tek kırmızı vurgu */
.rn-pick{flex:1;min-width:0;min-height:46px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;border:0;background:transparent;cursor:pointer;font:inherit;text-align:left;color:var(--ink)}
/* Satır içi küçük "İlanı gör →" — ana gövde rota seçer, bu link detay sayfasına gider (sade, sağda ayrık). */
.rn-detail{flex:none;display:flex;align-items:center;padding:0 12px;font-size:11.5px;font-weight:700;color:var(--brand);text-decoration:none;border-left:1px solid var(--line);white-space:nowrap;transition:.15s}
.rn-detail:hover{background:var(--brand);color:#fff}
.rn-item.active .rn-detail{border-left-color:#e6c9c5}
.rn-name{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rn-min{font-family:var(--font-m);font-weight:700;font-size:14px;color:var(--route);flex:none;font-variant-numeric:tabular-nums}
.rn-item.active .rn-name{font-weight:700}
.rn-item.active .rn-min{color:var(--brand)}
.rmap-near-empty{list-style:none;color:var(--ink-soft);font-size:13px;padding:6px 0}
.rmap-near-note{font-size:11.5px;color:var(--ink-soft);margin:8px 0 0}
.rmap-mapwrap{min-width:0;position:sticky;top:14px} /* harita kaydırınca görünür kalır; paneli ezmez */
.rmap-map{width:100%;height:660px;border:1px solid var(--line);border-radius:var(--radius);display:block;background:var(--paper-2)}
.rmap-map-empty{display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ink-soft);padding:18px;min-height:660px}
.rmap-empty{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;color:var(--ink-soft);max-width:560px}
.rmap-empty p{margin:0 0 8px}
@media(max-width:980px){
  /* Mobil/tablet: tek kolon, harita doğal akışta (sticky kapalı), makul sabit yükseklik. */
  .rmap-layout{grid-template-columns:1fr;gap:14px}
  .rmap-mapwrap{position:static}
  .rmap-map,.rmap-map-empty{height:400px;min-height:0}
}
@media(max-width:560px){
  .rmap-map,.rmap-map-empty{height:330px}
  .rmap-btn{padding:13px}
}

/* ── Rehber (guide) kartları + güven bandı ── */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px}
.sec-head h2{font-size:clamp(22px,3vw,28px);font-weight:700;margin:4px 0 0}
.sec-head p{margin:7px 0 0;color:var(--ink-soft);font-size:14.5px;max-width:44em}
/* Mesafe Bul açıklaması: masaüstünde (≥900px) TEK satır (nowrap, taşma yok); altında doğal kırılır. */
.mapsec .sec-head p{max-width:none;font-size:14px}
@media(min-width:900px){.mapsec .sec-head p{white-space:nowrap}}
.sec-link{font-weight:600;font-size:14px;color:var(--brand);white-space:nowrap;text-decoration:none}
.guide-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gcard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--ink);transition:.18s}
.gcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-tint)}
.gthumb{position:relative;display:block;aspect-ratio:16/9;overflow:hidden;background:var(--paper-2)}
.gthumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* Rehber kategori thumbnail gradyanları (kapak görseli yoksa) — TEK açı (135deg) + sakin; ışık-durağı
   paletten: uni=mavi(--boys), mahalle=yürüme yeşili(--route), fiyat=kehribar(--amber). KYK moru paletteki
   bir token'a eşlenemez → sakin mor olarak korundu. Marka kırmızısı thumbnail'lerde aksan olarak REZERVE. */
.gthumb-uni{background:linear-gradient(135deg,var(--boys),#1c3c5a)}
.gthumb-mah{background:linear-gradient(135deg,var(--route),#143f34)}
.gthumb-fiyat{background:linear-gradient(135deg,var(--amber),#8a5f1c)}
.gthumb-kyk{background:linear-gradient(135deg,#6a4c93,#3c2b56)}
.gthumb .gpat{position:absolute;inset:0;opacity:.5;background-image:radial-gradient(rgba(255,255,255,.5) 1.4px,transparent 1.5px);background-size:16px 16px}
.gthumb .gtag{position:absolute;left:12px;top:11px;font-family:var(--font-m);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.28);padding:4px 9px;border-radius:20px}
/* Flex column + flex:1 → kart yüksekliği satırla eşit, içerik alanı dolar; .gmore margin-top:auto ile
   her kartta SAĞ-ALTA sabitlenir (başlık/metin uzunluğu farklı olsa da link aynı hizada). */
.gbody{display:flex;flex-direction:column;flex:1;padding:16px 16px 18px}
.gbody h3{font-size:17px;font-weight:700;margin:0 0 6px}
.gbody p{margin:0;color:var(--ink-soft);font-size:13.5px}
.gmore{display:inline-block;margin-top:auto;align-self:flex-end;padding-top:10px;font-size:13px;font-weight:700;color:var(--brand)}
.gcard:hover .gmore{text-decoration:underline}
/* Anasayfa öğrenci yorumları — 3/2/1 kolon; kart = apart adı + kısa yorum (3 satır) + yazar + İlanı gör */
.home-comments .hc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.home-comments .hc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.home-comments .hc-grid{grid-template-columns:1fr}}
.hc{display:flex;flex-direction:column;gap:8px;background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius);padding:16px;text-decoration:none;color:var(--ink);box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s}
.hc:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-tint)}
.hc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.hc-apt{font-family:var(--font-d);font-weight:700;font-size:14.5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-rating{color:var(--amber);font-size:13px;flex:none}
.hc-body{margin:0;font-size:13.5px;line-height:1.6;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hc-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;font-size:12.5px}
.hc-author{font-weight:700;color:var(--ink)}
.hc-link{font-weight:700;color:var(--brand);white-space:nowrap}
.trust{display:flex;align-items:center;gap:28px;flex-wrap:wrap;background:var(--ink);color:#fff;border-radius:22px;padding:26px 30px;margin-top:34px}
.trust .big{font-family:var(--font-d);font-weight:800;font-size:40px;line-height:1;letter-spacing:-.03em;color:#fff}
.trust .big span{color:var(--accent-warm)}
.trust .t-txt{font-size:14.5px;color:#d8d2ca;max-width:42em;margin:0}
.trust .t-txt b{color:#fff;font-weight:600}
@media(max-width:860px){
  .map-box{min-height:240px}
  .guide-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  /* Rehber kartları mobilde TEK değil 2 sütun; başlık/metin taşarsa line-clamp + küçük padding. */
  .guide-grid{grid-template-columns:repeat(2,1fr);gap:11px}
  .guide-grid .gcard{min-width:0}
  .gbody{padding:11px 11px 13px}
  .gbody h3{font-size:14.5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .gbody p{font-size:12.5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .sec-head{flex-direction:column;align-items:flex-start}
  .trust{flex-direction:column;align-items:flex-start;gap:14px}
}

/* ═══════ Listeleme sayfaları (landing + /apartlar) — yeni kimlik (Faz 2 göçü) ═══════
   Kart = global .card/home-card (ücretli) + .free-list isim-satırı (ücretsiz). Token tabanlı; .apl-* emekli. */
.listing-page{--wa:var(--wa-btn);background:var(--paper);color:var(--ink);min-height:60vh}
.listing-wrap{max-width:1160px;margin:0 auto;padding:26px 14px 12px}
/* Listeleme hero bandı (ortak partial): sıcak bej + alt ayraç; sol kopya + sağ hero görsel (LCP placeholder). */
.lp-hero{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%);border-bottom:1px solid var(--warm-line);border-radius:16px;margin:0 0 16px;padding:22px}
.lp-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}
.lp-hero-copy h1{font-size:clamp(24px,3.4vw,34px);font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0;line-height:1.1}
.lp-stat{display:inline-block;margin:10px 0 0;font-family:var(--font-m);font-size:12.5px;font-weight:600;color:var(--route);background:var(--route-soft);padding:5px 11px;border-radius:var(--radius-pill)}
.lp-stat strong{font-weight:800}
.lp-hero-intro{color:var(--ink-soft);font-size:15px;line-height:1.6;margin:12px 0 0;max-width:54ch}
.lp-hero-intro p{margin:0 0 6px}
/* Hero sağ kolonu = statik harita önizlemesi (.map-box görselliğini paylaşır, hero boyutuna uyarlanır). Alan rezerve → CLS=0. */
.lp-hero-map{aspect-ratio:16/10;min-height:160px;border-radius:13px;box-shadow:none;border:1px solid var(--warm-line)}
/* Landing'e özel hero/banner görseli (harita önizlemesiyle aynı kutu; 16:10, kırpma=cover → taşma yok). */
.lp-hero-banner{aspect-ratio:16/10;min-height:160px;border-radius:13px;overflow:hidden;border:1px solid var(--warm-line)}
.lp-hero-banner img{width:100%;height:100%;object-fit:cover;display:block}
/* Yerinde-filtre kutucukları (KOŞULLU: Kız/Erkek/KYK): üni yeşil / merkez-tren kırmızı. Tıklayınca grid'i süzer (app.js). */
.tfilters{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:0 0 22px}
.tfilter{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:10px 12px;text-decoration:none;color:var(--ink);transition:.16s;cursor:pointer}
.tfilter:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.tfilter .tf-ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tfilter-uni .tf-ic{background:var(--route-soft);color:var(--route)}
.tfilter-ctr .tf-ic{background:var(--brand-tint);color:var(--brand)}
.tfilter .tf-txt{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.tfilter .tf-txt b{font-family:var(--font-d);font-weight:600;font-size:13px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tfilter .tf-txt small{font-size:11px;color:var(--ink-soft)}
.tfilter.on{border-width:2px;padding:9px 11px}
/* 0-sayılı hedef = PASİF gri etiket (<span>, link değil): solgun, etkileşimsiz, hover yok. */
.tfilter.is-empty{background:var(--paper-2);border-color:var(--line);opacity:.7;cursor:default}
.tfilter.is-empty:hover{transform:none;box-shadow:none}
.tfilter.is-empty .tf-ic{background:var(--line)!important;color:var(--ink-soft)!important}
.tfilter.is-empty .tf-txt b,.tfilter.is-empty .tf-txt small{color:var(--ink-soft)}
.tfilter-uni.on{border-color:var(--route)}
.tfilter-ctr.on{border-color:var(--brand)}
@media(max-width:860px){.lp-hero-grid{grid-template-columns:1fr}.tfilters{grid-template-columns:repeat(2,1fr)}}
.lp-head{margin:0 0 18px}
.lp-head h1{font-size:clamp(24px,3.4vw,34px);font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0;line-height:1.1}
.lp-intro{color:var(--ink-soft);font-size:15px;line-height:1.6;margin:10px 0 0;max-width:62ch}
.lp-intro p{margin:0 0 8px}
/* Bottom sarmalı: TAM GENİŞLİK (sola yapışma giderildi); düz makale prozası ~65ch okunabilirlik sınırı,
   .kyk-sub kendi düzenini (2 sütun/akordeon) yönetir. */
.lp-bottom{color:var(--ink-soft);font-size:15px;line-height:1.6;margin-top:30px;border-top:1px solid var(--line);padding-top:22px}
.lp-bottom > h2,.lp-bottom > h3,.lp-bottom > p,.lp-bottom > ul{max-width:65ch}
/* KYK alt içerik 3 bölge düzeni (.lp-bottom tam genişlik içinde). Metin değişmez; yapı/stil. */
.kyk-sub > div + div{margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.kyk-explain{max-width:65ch}
.kyk-sub h2{font-family:var(--font-d);font-size:18px;font-weight:700;color:var(--ink);margin:18px 0 7px;line-height:1.2}
.kyk-explain h2:first-child{margin-top:0}
.kyk-faq h2,.kyk-rel h2{margin:0 0 12px}
.kyk-sub p{margin:0 0 10px}
.kyk-explain ul{margin:0 0 10px;padding-left:18px}
/* Dinamik rehber geçidi (paylaşımlı partial; statik .kyk-rel yerine). */
.rehber-gate{margin-top:30px}
.rehber-gate h2{font-size:18px;font-weight:700;margin:0 0 12px}
.rg-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
.rg-card{display:flex;align-items:flex-start;gap:10px;background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius-sm);padding:12px 13px;text-decoration:none;color:var(--ink);transition:.16s}
.rg-card:hover{border-color:var(--brand-tint);transform:translateY(-2px);box-shadow:var(--shadow)}
.rg-ic{display:flex;color:var(--route);flex-shrink:0;margin-top:1px}
.rg-card:hover .rg-ic{color:var(--brand)}
.rg-txt{display:flex;flex-direction:column;gap:3px;min-width:0}
.rg-txt b{font-family:var(--font-d);font-weight:600;font-size:14px;letter-spacing:-.01em;line-height:1.2}
.rg-txt small{font-size:12px;color:var(--ink-soft);line-height:1.4}
.rg-all{display:inline-block;margin-top:12px;color:var(--brand);font-weight:700;font-size:13.5px;text-decoration:none}
.rg-all:hover{color:var(--brand-deep)}
/* KYK geniş ekran 2 SÜTUN: sol .kyk-sub (açıklama+SSS) | sağ .rehber-gate rayı (gridin sağ yarısı dolar). :has yoksa tek sütun (kabul). */
@media(min-width:860px){
  .lp-bottom:has(.kyk-explain){display:grid;grid-template-columns:1.7fr 1fr;gap:30px;align-items:start}
  .lp-bottom:has(.kyk-explain) .rehber-gate{margin-top:0;position:sticky;top:80px}
  .lp-bottom:has(.kyk-explain) .rehber-gate .rg-cards{grid-template-columns:1fr}
}
/* SSS akordeonu: saf <details>/<summary> (3rd-party JS YOK; cevaplar DOM'da → SEO). Kapalı satır sabit → CLS yok. */
.faq-item{border:1px solid var(--line);border-radius:11px;background:var(--card);margin:0 0 8px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--font-m);font-size:18px;color:var(--ink-soft);flex-shrink:0;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-item summary h3{font-family:var(--font-b);font-size:14.5px;font-weight:600;color:var(--ink);margin:0;line-height:1.3}
.faq-a{padding:0 14px 13px}
.faq-a p{margin:0;color:var(--ink-soft);font-size:14px}
/* İlgili rehberler: link-kart grid (eski <ul> yerine; href korunur). */
.rel-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.rel-card{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius-sm);padding:11px 13px;text-decoration:none;color:var(--ink);font-weight:600;font-size:13px;transition:.16s}
.rel-card:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow)}
.rel-card .rel-ic{display:flex;color:var(--route);flex-shrink:0}
.rel-card:hover .rel-ic{color:var(--brand)}
@media(max-width:560px){.rel-cards{grid-template-columns:1fr}}
.lp-count{display:inline-block;margin-top:12px;font-family:var(--font-m);font-size:12.5px;font-weight:600;color:var(--route);background:var(--route-soft);padding:5px 11px;border-radius:var(--radius-pill)}
.lp-count strong{font-weight:800}
.lp-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.lp-chip{font-size:13px;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--line);padding:7px 13px;border-radius:30px;text-decoration:none;transition:.16s}
.lp-chip:hover{border-color:var(--route);color:var(--route);background:var(--route-soft)}
.lp-chip-map{color:var(--brand);border-color:var(--brand-tint)}
.lp-chip-map:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-tint)}
.lp-empty{padding:34px;text-align:center;color:var(--ink-soft);background:var(--card);border:1px solid var(--line);border-radius:14px}
.lp-empty a{color:var(--brand);font-weight:600}
.free-sec{margin-top:30px}
.free-sec h2{font-size:18px;font-weight:700;margin:0 0 4px}
.free-sub{color:var(--ink-soft);font-size:13.5px;margin:0 0 14px}
.free-list{list-style:none;margin:0;padding:0;columns:2;column-gap:24px}
.free-list li{break-inside:avoid;margin:0 0 1px}
.free-list a{display:block;padding:8px 10px;border-radius:8px;color:var(--ink);text-decoration:none;font-size:14px;border:1px solid transparent;transition:.14s}
.free-list a:hover{background:var(--card);border-color:var(--line);color:var(--route)}
/* "Diğer kayıtlar" çerçeveli dizin (Kız/Erkek): tüm kayıtlar DOM'da; ilk 24 açık, kalanı saf <details> in-page açılır. */
.free-panel{margin-top:30px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}
.free-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 2px}
.free-head h2{font-size:18px;font-weight:700;margin:0}
.free-badge{font-family:var(--font-m);font-size:12px;font-weight:600;color:var(--ink-soft);background:var(--paper-2);padding:5px 11px;border-radius:var(--radius-pill);white-space:nowrap}
.free-more{margin-top:4px}
.free-more summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--brand);font-weight:700;font-size:13.5px;padding:9px 0}
.free-more summary::-webkit-details-marker{display:none}
.free-more > .free-list{margin-top:8px}
/* Standart (ücretsiz) ilan kartı — YALNIZ ad (detay linki); kategori/adres/telefon/görsel YOK (yalnız detayda). */
.free-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:8px;margin-top:8px}
.free-more > .free-cards{margin-top:8px}
.free-card{display:block;background:var(--paper);border:1px solid var(--warm-line);border-radius:var(--radius-sm);padding:9px 13px;font-family:var(--font-d);font-weight:600;font-size:14px;line-height:1.3;color:var(--ink);text-decoration:none;transition:border-color .14s,color .14s}
.free-card:hover{border-color:var(--brand);color:var(--brand)}
@media(max-width:560px){.free-cards{grid-template-columns:1fr 1fr}}
/* Mahallelere göre apartlar — kompakt iç-link çip bloğu (SEO equity); kırmızı/siyah tema. */
.nbh-dir{margin:24px 0 4px}
.nbh-dir-h{font-family:var(--font-d);font-size:16px;font-weight:700;color:var(--ink);margin:0 0 10px}
.nbh-dir-grid{display:flex;flex-wrap:wrap;gap:8px}
.nbh-chip{display:inline-flex;align-items:center;background:var(--card);border:1px solid var(--warm-line);border-radius:var(--radius-pill);padding:7px 14px;font-size:13.5px;font-weight:600;color:var(--ink);text-decoration:none;transition:border-color .14s,color .14s,background .14s}
.nbh-chip:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-tint)}
@media(max-width:560px){.nbh-chip{font-size:13px;padding:6px 12px}}
/* Anasayfa: mahalle dizini "Mesafe Bul" (paper-2) bloğunun DOĞAL DEVAMI — finder altında ince ayraçlı kompakt
   alt-blok (ayrı büyük section gibi şişmez; rehberle zemin paylaşmaz). Yalnız .mapsec içindeki örneği etkiler. */
.mapsec .nbh-dir{margin:22px 0 0;padding-top:18px;border-top:1px solid var(--warm-line)}
/* Anasayfa "Karar vermeden önce" rehber bloğu = kendi ayrı bloğu (üstteki paper-2 Mesafe Bul+mahalle alanından
   ince ayraçla ayrık). Alt boşluk daraltılır → 19 yıl güven bandı footer'a daha yakın durur. Krem/marka dili korunur. */
.home-v2 .home-guide{border-top:1px solid var(--warm-line);padding-bottom:10px}
/* 19 yıl bandı (dark) ile footer (dark) arasındaki ölü beyaz boşluğu YALNIZ anasayfada daralt (progresif :has;
   desteklenmezse footer global 46px'e güvenli düşer → regresyon yok). */
main:has(.home-guide) + .site-foot{margin-top:24px}
.lp-pag{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:26px}
.lp-pag a,.lp-pag span{padding:8px 13px;border-radius:9px;border:1px solid var(--line);text-decoration:none;color:var(--ink);font-size:14px;background:var(--card)}
.lp-pag .cur{background:var(--brand);color:#fff;border-color:var(--brand)}
.lp-cta-group{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 4px}
@media(min-width:900px){.free-list{columns:3}}
@media(max-width:560px){.lp-cta-group .btn{flex:1 1 calc(50% - 6px);text-align:center} .free-list{columns:1}}

/* ════════════════════════════════════════════════════════════════════════════
   Apart/Yurt DETAY (.ld-*) — redesign sistemi (kırmızı-siyah kimlik). ORTAK:
   listing-detail.php (Özel/zengin) + listing-detail-standart.php (Standart/sade).
   Token'lar global (:root). Mesafe = global Listing::walkStatus diliyle (near=yeşil ≤15).
   Kapak/galeri yoksa cover-placeholder.php → gri "Görsel yok" kutusu YOK.
   Layout: kompakt galeri (sol) + sticky iletişim kartı (sağ, en üstte); Konum+mesafe TEK bölüm.
   ──────────────────────────────────────────────────────────────────────────── */
.ld{--wa:var(--wa-btn);background:var(--paper);color:var(--ink);min-height:60vh}
.ld-wrap{max-width:1120px;margin:0 auto;padding:10px 14px 96px}

/* Üst breadcrumb — çok küçük/ince sayfa üst bilgisi (pill DEĞİL, ok YOK). Standart şablon hâlâ .ld-back kullanır. */
.ld-crumb{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft);margin:0 0 9px}
.ld-crumb a{color:var(--ink-soft);text-decoration:none;font-weight:500}
.ld-crumb a:hover{color:var(--brand)}
.ld-crumb .sep{opacity:.4}
.ld-crumb .cur{color:var(--ink-soft);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60vw}
/* Geri linki — pill (standart sade şablonda korunur) */
.ld-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft);background:var(--card);border:1px solid var(--line);border-radius:30px;padding:7px 14px;text-decoration:none;margin:0 0 14px;transition:border-color .15s,color .15s}
.ld-back:hover{border-color:var(--brand);color:var(--brand)}

/* Başlık bandı (yalnız h1; üst boşluk azaltıldı → içerik yukarı taşındı) */
.ld-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px 20px;flex-wrap:wrap;margin:0 0 12px}
.ld-head-main{display:flex;gap:14px;align-items:flex-start;min-width:0}
.ld-logo{width:60px;height:60px;border:1px solid var(--line);border-radius:14px;object-fit:contain;background:var(--card);flex:none}
.ld-head h1{font-family:var(--font-d);font-size:clamp(22px,3vw,29px);font-weight:800;letter-spacing:-.02em;line-height:1.14;margin:0;color:var(--ink)}
.ld-addr{display:flex;align-items:flex-start;gap:6px;color:var(--ink-soft);font-size:14px;margin-top:7px;line-height:1.45}
.ld-tags{display:flex;gap:7px;flex-wrap:wrap;align-items:center;flex:none}
.ld-tag{font-size:12px;font-weight:600;background:var(--paper-2);color:var(--ink-soft);padding:5px 12px;border-radius:30px}

/* İçerik gridi: ana kolon (sol) + sticky iletişim kartı (sağ, üstte başlar) */
.ld-grid{display:grid;grid-template-columns:1fr 330px;gap:22px;align-items:start}
.ld-main{display:flex;flex-direction:column;gap:16px;min-width:0}

/* Galeri (kompakt): ana görsel + thumbnail satırları (sol kolon genişliğinde). Resim ETİKETİ YOK. */
.ld-gal{display:flex;flex-direction:column;gap:8px}
.ld-gal-hero{position:relative;aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;background:var(--paper-2);box-shadow:var(--shadow)}
.ld-gal-hero img{width:100%;height:100%;object-fit:cover;display:block}
.ld-gal-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.ld-gal-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--paper-2);display:block}
.ld-gal-thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* Gerçek foto yokken bile galeri hissi: placeholder thumb (cover-placeholder görsel dili) — tıklanamaz. */
.ld-gal-thumb.ph{cursor:default}

/* Apart detay galeri SLIDER (.lg) — ÖZEL + STANDART ortak partial. img tabanlı (CSS background YOK).
   Hero sabit aspect-ratio → CLS=0; YATAY=cover, DİKEY(.portrait)=contain (oran korunur, kenar boşluğu, upscale yok).
   Geçiş = hafif opacity fade. Thumb alanı EN FAZLA 2 satır (column-major); 16+ görselde ok'larla 16'şar sayfalanır. */
.lg{display:flex;flex-direction:column;gap:10px}
.lg-stage{position:relative;aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;background:var(--paper-2);box-shadow:var(--shadow)}
.lg-hero{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .28s ease;will-change:opacity}
/* Dikey/portre görsel: contain → oran bozulmaz, tam görünür, kenarlarda boşluk (upscale zorlaması yok). */
.lg-stage.portrait .lg-hero{object-fit:contain}
.lg-stage .cover-ph{position:absolute;inset:0}
.lg-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:0;border-radius:50%;background:rgba(20,16,14,.5);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,opacity .15s;opacity:.85}
.lg-nav:hover{background:var(--brand);opacity:1}
.lg-prev{left:10px}.lg-next{right:10px}
.lg-count{position:absolute;right:10px;bottom:10px;background:rgba(20,16,14,.6);color:#fff;font-size:12px;padding:3px 10px;border-radius:20px;font-variant-numeric:tabular-nums}
/* Thumb alanı: ok | viewport | ok. Viewport 2 satır yüksekliğinde sabit; içerik column-major akar (yatay sayfalama). */
.lg-thumbs-wrap{display:flex;align-items:stretch;gap:6px}
.lg-thumbs-vp{flex:1;min-width:0;overflow:hidden}
/* Masaüstü: sayfa şeridi (flex) + her sayfa 8 sütun SATIR-BAZLI grid (16 = 2 satır). Sayfalar translateX ile kayar. */
.lg-thumbs{display:flex;transition:transform .3s ease}
.lg-thumb-page{flex:0 0 100%;display:grid;grid-template-columns:repeat(8,1fr);gap:8px;align-content:start}
.lg-thumb{padding:0;border:2px solid transparent;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;background:var(--paper-2);aspect-ratio:1;transition:border-color .15s}
.lg-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.lg-thumb.active{border-color:var(--brand)}
.lg-thumb:focus-visible{outline:2px solid var(--brand);outline-offset:1px}
.lg-tnav{flex:0 0 30px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);color:var(--ink);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.lg-tnav:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.lg-tnav[disabled]{opacity:.35;cursor:default;pointer-events:none}
@media(max-width:760px){
  /* Mobil: thumb viewport YATAY kaydırma (paging yok); sayfa sarmalayıcı kaldırılır (display:contents) →
     thumb'lar tek grid'e düşer, 2 satır column-major yatay kaydırma; 3. satır AÇILMAZ. */
  .lg-thumbs-vp{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .lg-thumbs{display:grid;grid-template-rows:repeat(2,1fr);grid-auto-flow:column;grid-auto-columns:26%;gap:8px;transform:none!important}
  .lg-thumb-page{display:contents}
  .lg-tnav{display:none}
  .lg-nav{width:34px;height:34px;font-size:20px}
}

/* Bölümler kart yapısında */
.ld-sec{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin:0}
.ld-sec h2{font-family:var(--font-d);font-size:18px;font-weight:700;letter-spacing:-.01em;margin:0 0 14px;color:var(--ink);display:flex;align-items:center;gap:10px}
.ld-sec h2::before{content:"";width:4px;height:18px;border-radius:3px;background:var(--brand);flex:none}
/* İkon-çipli sade başlık (yalnız Temel Bilgiler + Özellikler; 2. görsel sadeliği) — aksan çubuğu yerine ikon */
.ld-sec h2.ld-h2ic{gap:11px}
.ld-sec h2.ld-h2ic::before{display:none}
.ld-h2ic .ic{width:32px;height:32px;border-radius:10px;background:var(--brand-tint);color:var(--brand);display:grid;place-items:center;flex:none}
.ld-lead{font-size:15.5px;line-height:1.6;color:var(--ink);margin:0 0 12px}
.ld-lead:last-child{margin-bottom:0}

/* Açıklama (admin sanitize'lı HTML) */
.ld-prose{font-size:15px;line-height:1.8;color:#3a352f}
.ld-prose p{margin:0 0 14px}
.ld-prose h2,.ld-prose h3{font-family:var(--font-d);margin:18px 0 8px}
.ld-prose ul,.ld-prose ol{margin:0 0 12px;padding-left:20px} .ld-prose li{margin:3px 0}
.ld-prose a{color:var(--brand);text-decoration:underline} .ld-prose img{border-radius:var(--radius-sm);margin:8px 0}

/* Özellikler — TEK temiz tick grid (alt başlık/gruplama YOK; 2. görsel: eşit boşluk, dengeli kolon, yumuşak) */
.ld-amen{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px 24px}
.ld-amen li{display:flex;align-items:center;gap:11px;font-size:14.5px;font-weight:500;color:var(--ink-soft)}
.ld-amen .tick{width:24px;height:24px;border-radius:8px;background:var(--route-soft);color:var(--route);display:grid;place-items:center;flex:none}

/* Sağ kolon — Öne Çıkan Apartlar (platform doluluğu; eski sitedeki reklam/öneri kolonunun modern karşılığı) */
/* Özel apart vitrini — normal akış, sticky karttan ALT katman (üstüne binmez); net boşluk */
.ld-rec{border:1px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);padding:14px 14px 10px;position:relative;z-index:1;margin-top:2px}
.ld-rec h3{font-family:var(--font-d);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin:0 0 12px}
/* Benzer Apartlar — 2'li dikey grid; yalnız görsel/placeholder + ad (2 satır kesme) */
.ld-rec-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ld-rec .rc{display:flex;flex-direction:column;gap:6px;text-decoration:none;color:var(--ink)}
.ld-rec .rc .pic{position:relative;aspect-ratio:4/3;border-radius:var(--radius-sm);overflow:hidden;background:var(--paper-2)}
.ld-rec .rc .pic img{width:100%;height:100%;object-fit:cover;display:block}
.ld-rec .rc .nm{font-family:var(--font-d);font-weight:700;font-size:12.5px;line-height:1.25;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ld-rec .rc:hover .nm{color:var(--brand)}
.ld-rec-all{display:block;text-align:center;font-size:12px;font-weight:600;color:var(--ink-soft);padding:12px 0 4px;text-decoration:none}
.ld-rec-all:hover{color:var(--brand);text-decoration:underline}
/* Boş durum (Yorumlar vb.) — sade */
.ld-empty{color:var(--ink-soft);font-size:14px;line-height:1.6;margin:0}
/* Yorum kartları (detay) — sade; uzun metin 4 satırda kesilir (XSS escape şablonda) */
.ld-comments{display:flex;flex-direction:column;gap:12px}
.lc{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);padding:13px 15px}
.lc-head{display:flex;align-items:center;gap:10px;margin:0 0 6px}
.lc-author{font-family:var(--font-d);font-weight:700;font-size:14px;color:var(--ink)}
.lc-rating{color:var(--amber);font-size:13px;letter-spacing:1px}
.lc-date{margin-left:auto;font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.lc-body{margin:0;font-size:14px;line-height:1.55;color:#3a352f;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
/* Admin cevabı ("Eskişehir Apartlar Cevabı") — yorumun altında, kırmızı vurgulu güven bloğu (clamp YOK). */
.lc-reply{margin:10px 0 0;padding:10px 13px;border-left:3px solid var(--brand);background:var(--brand-tint,#fcf0f1);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.lc-reply-lbl{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-d);font-weight:700;font-size:12.5px;color:var(--brand)}
.lc-reply-lbl::before{content:"✓";font-size:11px;width:15px;height:15px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--brand);color:#fff}
.lc-reply-body{margin:5px 0 0;font-size:13.5px;line-height:1.55;color:#3a352f}
/* Rehber yorum/soru formu üst açıklaması. */
.ld-clead{margin:0 0 12px;font-size:13.5px;line-height:1.5;color:var(--ink-soft)}
/* Ziyaretçi yorum formu (sade, ortalı). Onaylı yorum listesinin altında; her zaman görünür. */
.ld-cform{margin-top:16px;max-width:560px;margin-left:auto;margin-right:auto;text-align:center}
.ld-cmsg{margin:0 0 12px;padding:11px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600}
.ld-cmsg.ok{background:var(--ok-bg);border:1px solid var(--ok-line);color:var(--ok)}
.ld-cmsg.err{background:var(--err-bg);border:1px solid var(--err-line);color:var(--err)}
.ld-cdetails{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);overflow:hidden}
.ld-csum{cursor:pointer;list-style:none;padding:12px 16px;font-family:var(--font-d);font-weight:700;font-size:14px;color:var(--brand);user-select:none}
.ld-csum::-webkit-details-marker{display:none}
.ld-csum::before{content:"＋ ";font-weight:700}
.ld-cdetails[open] .ld-csum::before{content:"− "}
.ld-cdetails[open] .ld-csum{border-bottom:1px solid var(--line)}
.ld-cform-inner{padding:14px 16px 16px;text-align:left}
.ld-clabel{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin:0 0 10px}
.ld-clabel .opt{font-weight:400;color:#9a948c}
.ld-clabel .req{color:var(--brand)}
.ld-cform-inner input[type=text],.ld-cform-inner textarea,.ld-cform-inner select{width:100%;margin-top:5px;padding:9px 11px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;font-size:14px;background:var(--card);color:var(--ink)}
.ld-cform-inner textarea{resize:vertical;min-height:84px}
.ld-cform-inner select{max-width:200px}
.ld-cerr{display:block;color:var(--err);font-size:12.5px;margin:-6px 0 10px}
.ld-cbtn{display:inline-block;margin-top:4px;padding:10px 22px;border:0;border-radius:var(--radius-sm);background:var(--brand);color:#fff;font-family:var(--font-d);font-weight:700;font-size:14px;cursor:pointer;transition:background .15s,box-shadow .15s}
.ld-cbtn:hover{background:var(--brand-deep);box-shadow:var(--shadow)}
.ld-cnote{margin:10px 0 0;font-size:12px;color:#9a948c}
.ld-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* (Hızlı Bilgiler kartı kaldırıldı — kullanıcı talebi.) */

/* Bilgi listesi (oda tipleri / telefon / adres) */
.ld-list{list-style:none;padding:0;margin:0;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--card)}
.ld-list li{padding:11px 14px;display:flex;justify-content:space-between;gap:12px;font-size:14px;border-bottom:1px solid var(--line)}
.ld-list li:last-child{border-bottom:0}
.ld-list li span{color:var(--ink-soft)} .ld-list li b{color:var(--ink);font-weight:600;text-align:right}

/* Tanıtım videosu (embed iframe). NOT: listings'te video kolonu YOK → dormant (veri gelince render).
   3rd-party JS değil; harita gibi embed. */
.ld-video{width:100%;aspect-ratio:16/9;border:0;border-radius:var(--radius);display:block;background:var(--coal)}

/* ── Konum ve Yürüme Mesafeleri (TEK birleşik bölüm: adres + mesafe + harita + yol tarifi) ── */
.ld-addr-full{display:flex;align-items:flex-start;gap:7px;font-size:14.5px;color:var(--ink);margin:0 0 14px;line-height:1.5}
/* Mesafe tile grid — walkStatus görsel dili: near=yeşil ≤15 / nötr; >25 dk nötr BİLGİ
   (yeşil yakınlık iddiası YOK). YALNIZ gerçek ORS walk_min — kuş-uçuşu/distance_m YOK. */
.ld-dist{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:0 0 14px}
.ld-dtile{border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 13px;background:var(--card)}
.ld-dtile .pt{font-size:12.5px;font-weight:600;color:var(--ink-soft);line-height:1.35}
.ld-dtile .min{display:flex;align-items:baseline;gap:4px;margin-top:7px}
.ld-dtile .min .n{font-family:var(--font-m);font-weight:700;font-size:20px;color:var(--ink)}
.ld-dtile .min .u{font-size:11px;color:var(--ink-soft)}
.ld-dtile .mode{font-size:11px;color:var(--ink-soft);margin-top:3px;display:flex;align-items:center;gap:4px}
.ld-dtile.near{border-color:#bfe0d5;background:var(--route-soft)}
.ld-dtile.near .n,.ld-dtile.near .mode{color:var(--route)}
.ld-note{color:var(--ink-soft);font-size:12px;margin:0 0 14px}
.ld-map{width:100%;height:380px;border:0;border-radius:var(--radius-sm);display:block}
@media(max-width:560px){.ld-map{height:320px}}
/* TUR 2 Faz 7: harita tıkla-yükle placeholder — .ld-map boyutunu paylaşır (CLS yok); tramvay yeşili aksan */
.ld-map-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--route-soft);border:1px dashed #bfe0d5;text-align:center;padding:16px;box-sizing:border-box}
.ld-map-ph .ld-map-loc{color:var(--ink-soft);font-size:13px}
.ld-map-ph .ld-map-note{color:var(--ink-soft);font-size:12px}
.ld-map-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--route);border:1px solid var(--route);border-radius:8px;padding:10px 20px;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}
.ld-map-btn:hover{background:var(--route);color:#fff}
.ld-dirlink{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:14px;font-weight:700;color:var(--brand);text-decoration:none}
.ld-dirlink:hover{text-decoration:underline}
/* İki-seçimli mesafe (eski site: Apart Seçimi + Mesafe Seçimi) — mevcut walk_min verisiyle, ORS/API YOK */
.ld-msf{margin:0 0 14px}
.ld-msf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:560px){.ld-msf-row{grid-template-columns:1fr}}
.ld-msf-col label{display:block;font-size:11px;font-weight:700;color:var(--ink-soft);margin:0 0 6px;text-transform:uppercase;letter-spacing:.04em}
.ld-select{width:100%;font-family:var(--font-b);font-size:14px;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 36px 11px 12px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236c655d' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}
.ld-select:disabled{background-color:var(--paper);color:var(--ink);opacity:1;cursor:default}
.ld-msf-out{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;color:var(--ink);line-height:1.4}
.ld-msf-out.near{background:var(--route-soft);border-color:#bfe0d5;color:var(--route)}

/* Yan iletişim kartı (sticky, sağ kolonun en üstünde başlar) */
/* Sağ kolon: normal akar (özel apart vitrini uzar). YALNIZ iletişim kartı sticky (masaüstü/tablet). */
.ld-side{display:flex;flex-direction:column;gap:16px}
.ld-card{border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:var(--card);box-shadow:var(--shadow)}
/* Sticky SADECE iletişim kartında — opak bg + yüksek z-index: vitrine temiz biçimde altından kayar (üst üste binme yok). */
.ld-contact-card{position:sticky;top:76px;z-index:5;background:var(--card)}
/* Hızlı iletişim kartı başlığı = ilan adı + sade alt satır (fiyat kartı değil) */
.ld-card-head{margin:0 0 2px}
.ld-card-title{font-family:var(--font-d);font-size:20px;font-weight:800;letter-spacing:-.015em;line-height:1.18;color:var(--ink);margin:0}
.ld-card-sub{font-size:12px;color:var(--ink-soft);margin:5px 0 0;line-height:1.35;opacity:.85}
.ld-price{font-family:var(--font-d);font-size:22px;font-weight:800;color:var(--brand);margin:0;line-height:1.15}
.ld-price small{font-family:var(--font-b);font-size:13px;font-weight:600;color:var(--ink-soft)}
.ld-price.ask{font-size:16px;color:var(--ink-soft);font-weight:700}
.ld-cta{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.ld-cta a{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--radius-sm);text-decoration:none;font-weight:700;font-size:15px;transition:filter .16s,background .16s,border-color .16s,color .16s,box-shadow .16s}
.ld-call{background:var(--brand);color:#fff} .ld-call:hover{background:var(--brand-deep);box-shadow:var(--shadow)}
.ld-wa{background:var(--wa);color:#fff} .ld-wa:hover{filter:brightness(.95)}
.ld-dir{background:var(--card);color:var(--ink);border:1.5px solid var(--line)} .ld-dir:hover{border-color:var(--brand);color:var(--brand)}

/* Standart (sade) tek satır CTA + alt linki */
.ld-cta-inline{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:12px 22px;border-radius:var(--radius-sm);text-decoration:none;font-weight:700;font-size:15px;background:var(--brand);color:#fff;transition:background .16s,box-shadow .16s}
.ld-cta-inline:hover{background:var(--brand-deep);box-shadow:var(--shadow)}
.ld-alllink{margin-top:18px}
.ld-alllink a{color:var(--brand);text-decoration:none;font-weight:700;font-size:14px}

/* Benzer ilanlar — yoğun responsive grid (5+ kolon) + zengin kart (görsel/placeholder + ad + mahalle/tür) */
.ld-sim{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:13px}
.ld-sim a{text-decoration:none;border:1px solid var(--warm-line);border-radius:var(--radius-sm);overflow:hidden;color:var(--ink);background:var(--card);display:flex;flex-direction:column;transition:box-shadow .2s,border-color .2s,transform .2s}
.ld-sim a:hover{box-shadow:var(--shadow-lg);border-color:var(--brand-tint);transform:translateY(-2px)}
.ld-sim .c{position:relative;aspect-ratio:16/10;background:var(--paper-2)} .ld-sim .c img{width:100%;height:100%;object-fit:cover;display:block}
.ld-sim .c .cb{position:absolute;left:8px;top:8px;z-index:2;font-size:10.5px;font-weight:700;color:#fff;background:rgba(23,23,23,.62);padding:3px 9px;border-radius:30px;backdrop-filter:blur(2px)}
.ld-sim .b{padding:9px 11px;display:flex;flex-direction:column;gap:3px;flex:1}
.ld-sim .t{font-family:var(--font-d);font-size:13.5px;font-weight:700;line-height:1.25;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ld-sim .m{font-size:11.5px;color:var(--ink-soft);line-height:1.3}

/* Mobil sticky CTA */
.ld-sticky{position:fixed;left:0;right:0;bottom:0;display:none;gap:9px;padding:10px 12px;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -2px 14px rgba(27,25,22,.08);z-index:50}
.ld-sticky a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:12px;text-decoration:none;font-weight:700;color:#fff;font-size:15px}

@media(max-width:900px){
  .ld-grid{grid-template-columns:1fr}
  .ld-side{position:static}
  .ld-contact-card{position:static}   /* mobil: kart normal akış (sticky alt bar Ara/WhatsApp'ı taşır) */
  .ld-sticky{display:flex}
}
@media(max-width:520px){
  .ld-gal-thumbs{grid-template-columns:repeat(4,1fr)}
}

/* ── Standart (sade) varyant: dar kolon + bilgilendirme notu ── */
.ld-std .ld-wrap{max-width:720px}
.ld-std-note{margin:20px 0 0;padding:14px 16px;background:var(--brand-tint);border:1px solid #ecd3d0;border-radius:var(--radius-sm);color:#6a4d4a;font-size:13px;line-height:1.55}
