/* ===================================================================
   Eyüboğlu Gayrimenkul — Tema (Espresso + Altın)
   Tek font: Inter. Tüm ölçüler px. Bootstrap 5 üzerine bindirme.
   =================================================================== */

:root {
  /* Renk */
  --brand:      #1c1714;   /* espresso */
  --brand-700:  #120e0c;
  --brand-soft: #2a221d;
  --ink:        #2a2622;   /* gövde metni */
  --muted:      #6b625a;
  --gold:       #c9962f;
  --gold-600:   #8a6914;
  --gold-050:   #f6efe1;
  --gold-grad:  linear-gradient(135deg, #b57d2e 0%, #fbdc8f 100%);
  --line:       #eae3d8;
  --bg-soft:    #faf8f4;   /* krem */
  --bg-soft-2:  #f1ece3;
  --white:      #ffffff;

  /* Gölge & yarıçap (px) */
  --shadow-sm:  0 2px 12px rgba(28, 23, 20, 0.05);
  --shadow:     0 14px 38px rgba(28, 23, 20, 0.10);
  --shadow-lg:  0 28px 64px rgba(28, 23, 20, 0.16);
  --radius-sm:  12px;
  --radius:     16px;
  --radius-lg:  20px;

  /* Sabit üst alan yüksekliği — hero "tam ekran" hesabında düşülür (mobil: yalnız navbar) */
  --header-h:   72px;

  /* Tek font */
  --ff: "Inter", -apple-system, "Segoe UI", Roboto, sans-serif;

  /* Tip ölçeği (px) */
  --fs-body:    16px;
  --fs-sm:      14px;
  --fs-lead:    18px;
  --fs-eyebrow: 13px;
  --fs-h1:      40px;
  --fs-h2:      30px;
  --fs-h3:      22px;
  --fs-h4:      19px;
  --fs-h5:      17px;
}

/* ---------- Base ---------- */
* { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
html { overflow-x: clip; }
body {
  font-family: var(--ff);
  color: var(--ink);
  background: var(--white);
  font-size: var(--fs-body);
  line-height: 1.6;
  overflow-x: clip;
  max-width: 100%;
}
h1, h2, h3, h4, h5, h6, .navbar-brand, .brand {
  font-family: var(--ff);
  color: var(--brand);
  font-weight: 800;
  line-height: 1.2;
}
h1 { font-size: var(--fs-h1); letter-spacing: -1px; }
h2 { font-size: var(--fs-h2); letter-spacing: -0.6px; }
h3 { font-size: var(--fs-h3); letter-spacing: -0.4px; }
h4 { font-size: var(--fs-h4); }
h5 { font-size: var(--fs-h5); font-weight: 700; }
.card-title { font-size: var(--fs-h5); font-weight: 700; letter-spacing: -0.01em; }
p  { margin: 0 0 16px; }
a  { color: var(--gold-600); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--brand); }
.lead-muted { color: var(--muted); font-size: var(--fs-lead); line-height: 1.65; }
.text-gold  { color: var(--gold-600) !important; }
.text-brand { color: var(--brand) !important; }
.bg-brand   { background: var(--brand) !important; }
.bg-soft    { background: var(--bg-soft) !important; }
.small, small { font-size: var(--fs-sm); }
section { scroll-margin-top: 90px; }
::selection { background: var(--gold); color: #1a1410; }

/* Altın gradient metin */
.gold-text {
  background: var(--gold-grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* ---------- Buttons ---------- */
.btn { border-radius: 999px; font-weight: 600; font-size: 15px; padding: 11px 24px; transition: transform .15s ease, box-shadow .2s ease, background .2s ease; }
.btn:active { transform: translateY(1px); }
.btn-sm { font-size: 14px; padding: 7px 14px; }
.btn-lg { font-size: 16px; padding: 14px 30px; }
.btn-brand { background: var(--brand); color: #fff; }
.btn-brand:hover { background: var(--brand-700); color: #fff; box-shadow: var(--shadow-sm); }
.btn-gold { background: var(--gold-grad); color: #2a1c08; border: 0; }
.btn-gold:hover { color: #2a1c08; box-shadow: 0 10px 24px rgba(181, 125, 46, .35); transform: translateY(-2px); }
.btn-outline-brand { border: 1.5px solid var(--brand); color: var(--brand); }
.btn-outline-brand:hover { background: var(--brand); color: #fff; }
.btn-whatsapp { background: #0e7d3d; color: #fff; border: 0; }
.btn-whatsapp:hover { background: #0a5f2e; color: #fff; }
.btn-youtube { background: #cc0000; color: #fff; border: 0; }
.btn-youtube:hover { background: #a30000; color: #fff; }
.btn-outline-light-2 { border: 1.5px solid rgba(255,255,255,.55); color: #fff; }
.btn-outline-light-2:hover { background: #fff; color: var(--brand); }

/* ---------- Top bar ---------- */
.topbar { background: var(--brand-700); color: rgba(255,255,255,.78); font-size: 13px; }
.topbar a { color: rgba(255,255,255,.78); }
.topbar a:hover { color: var(--gold); }

/* ---------- Navbar ---------- */
.site-nav { background: rgba(255,255,255,.9); backdrop-filter: saturate(140%) blur(10px); transition: box-shadow .25s ease; }
.site-nav.scrolled { box-shadow: 0 1px 0 rgba(28,23,20,.16), 0 3px 8px rgba(28,23,20,.07); background: #fff; }
.navbar-brand { display: inline-flex; align-items: center; }
.navbar-brand img { height: 34px; width: auto; display: block; }
.site-nav .nav-link { color: var(--ink); font-weight: 600; font-size: 15px; padding: 8px 14px !important; position: relative; }
.site-nav .nav-link::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 4px; height: 2px; background: var(--gold-grad); transform: scaleX(0); transform-origin: left; transition: transform .25s ease; border-radius: 2px; }
.site-nav .nav-link:hover, .site-nav .nav-link.active { color: var(--brand); }
.site-nav .nav-link:hover::after, .site-nav .nav-link.active::after { transform: scaleX(1); }

/* ---------- Hero Slider ---------- */
.hero-slider { position: relative; }
/* Tüm slaytlar aynı grid hücresinde üst üste → slider yüksekliği en uzun slayta eşitlenir (geçişte zıplama yok).
   Satır en az 100svh (tam ekran, crawl-güvenli birim — adres çubuğuyla uzamaz), içerik uzunsa büyür (kesilmez). */
.hero-slider .carousel-inner { display: grid; grid-template-rows: minmax(calc(100svh - var(--header-h)), auto); }
.hero-slider .carousel-item { transition: opacity .9s ease; display: block; grid-area: 1 / 1 / 2 / 2; }
.hero-slide {
  position: relative; min-height: 600px; height: 100%; display: flex; align-items: center;
  background-color: #1c1714; background-position: center; background-size: cover; background-repeat: no-repeat;
  color: #fff;
}
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(700px 360px at 88% 0%, rgba(251,220,143,.16), transparent 60%),
    linear-gradient(90deg, rgba(18,14,12,.92) 0%, rgba(18,14,12,.72) 60%, rgba(18,14,12,.58) 100%);
}
/* İçerik Bootstrap .container ile limitlenir; metin okunurluğu için iç genişlik sınırı */
.hero-content { position: relative; z-index: 2; padding-top: 40px; padding-bottom: 40px; }
.hero-content .hero-title { font-size: var(--fs-h1); font-weight: 800; line-height: 1.2; color: #fff; letter-spacing: -1.4px; max-width: 640px; margin-top: 0; }
.hero-content .subtitle { color: #fff; font-size: var(--fs-lead); max-width: 600px; }

/* İndikatörler — çizgi stili */
.hero-indicators { margin-bottom: 24px; gap: 8px; }
.hero-indicators [data-bs-target] { width: 28px; height: 4px; border-radius: 4px; border: 0; background: rgba(255,255,255,.45); opacity: 1; transition: background .25s ease, width .25s ease; }
.hero-indicators [data-bs-target].active { width: 44px; background: var(--gold-grad); }

/* Prev/Next kontrolleri */
.hero-control { width: 56px; color: #fff; opacity: 1; }
.hero-control i { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); font-size: 16px; transition: background .25s ease, color .25s ease; }
.hero-control:hover i { background: var(--gold-grad); color: #2a1c08; border-color: transparent; }

/* Hero kicker (slayt üstü etiket) */
.hero-badge { display: inline-block; font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); }

/* ---------- Section ---------- */
.section { padding: 80px 0; }
.section-head { margin-bottom: 44px; }
.section-head .eyebrow { color: var(--gold-600); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; font-size: var(--fs-eyebrow); display: inline-block; margin-bottom: 10px; }
.eyebrow { color: var(--gold-600); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; font-size: var(--fs-eyebrow); display: inline-block; margin-bottom: 10px; }
.divider-gold { width: 60px; height: 3px; background: var(--gold-grad); border: 0; opacity: 1; border-radius: 2px; }

/* ---------- Eşit kart düzeni (uniform grid) ---------- */
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; }
.card-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 991px) { .card-grid, .card-grid.cols-2 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .card-grid, .card-grid.cols-2 { grid-template-columns: 1fr; } }

/* Tek tip kart — section içindeki tüm kartlar birebir aynı */
.feature-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 30px; box-shadow: var(--shadow-sm); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; height: 100%; display: flex; flex-direction: column; }
.feature-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: #e0d3bf; }
.feature-card h4, .feature-card h5 { margin-bottom: 8px; }
.feature-card h3 { margin-bottom: 10px; }
.feature-card .lead-muted { font-size: 15px; }

/* Hizmet kapsam listesi (badge değil, sade) */
.service-points { list-style: none; margin: 20px 0 0; padding: 18px 0 0; border-top: 1px solid var(--line); display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 24px; row-gap: 8px; }
.service-points::before { grid-column: 1 / -1; content: "Kapsam"; font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
@media (max-width: 480px) { .service-points { grid-template-columns: 1fr; } }
.service-points li { position: relative; padding-left: 26px; font-size: 15px; color: var(--ink); }
.service-points li i { position: absolute; left: 0; top: 4px; color: var(--gold-600); font-size: 13px; }

/* ---------- Cards (Bootstrap .card bindirme) ---------- */
.card { border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-sm); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; background: #fff; }
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: #e0d3bf; }

/* ---------- Görsel placeholder ---------- */
.media-ph { position: relative; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #3a2f25, #1c1714); color: rgba(251,220,143,.45); overflow: hidden; }
.media-ph::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 72% 22%, rgba(201,150,47,.30), transparent 58%); z-index: 1; }
.media-ph i { font-size: 36px; position: relative; z-index: 1; transition: transform .35s ease; }
/* Örnek görsel (placehold.co) */
.media-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 2; -webkit-user-drag: none; user-select: none; }
[data-scroll-x], [data-drag-track] { user-select: none; }
.media-ph.rounded-circle .media-img { border-radius: 50%; }
.card:hover .media-img { transform: scale(1.04); transition: transform .35s ease; }
.play-badge { position: absolute; inset: 0; display: grid; place-items: center; z-index: 3; }
.play-badge i { width: 64px; height: 64px; border-radius: 50%; background: var(--gold-grad); color: #2a1c08; display: grid; place-items: center; font-size: 24px; transition: transform .2s ease; }
.video-cover { cursor: pointer; }
.video-cover:hover .play-badge i { transform: scale(1.1); }
.media-ph.tone-2 { background: linear-gradient(135deg, #4a3a22, #241a0c); }
.media-ph.tone-3 { background: linear-gradient(135deg, #5b4326, #2c1f12); }
.media-ph.ratio-43 { aspect-ratio: 4/3; }
.media-ph.ratio-169 { aspect-ratio: 16/9; }
.card:hover .media-ph i { transform: scale(1.12); }

/* ---------- İlan kartı ---------- */
.listing-card { overflow: hidden; }
.listing-card .media-ph { margin: 16px 16px 0; border-radius: 12px; }
.listing-card .price { color: var(--brand); font-weight: 800; font-size: 20px; letter-spacing: -0.4px; }
.listing-card .meta { color: var(--muted); font-size: 14px; }
/* İlan / kategori etiketleri — pill/badge değil, sade metin */
.listing-tags { display: flex; gap: 12px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; }
.t-type { color: var(--gold-600); }
.post-cat { display: inline-block; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--gold-600); }

/* ---------- İkon kapsülü ---------- */
.icon-chip { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: var(--gold-050); color: var(--gold-600); font-size: 22px; margin-bottom: 16px; transition: background .25s ease, color .25s ease, transform .25s ease; }
.feature-card:hover .icon-chip { background: var(--gold-grad); color: #2a1c08; }

/* ---------- Hizmet / iştirak / yorum / temsilci ---------- */
.review-card { padding: 30px; height: 100%; }
.review-card:hover { transform: none; box-shadow: var(--shadow-sm); border-color: var(--line); }
.review-card .stars { color: var(--gold); }
.review-card .gsource { color: var(--muted); font-size: 13px; }

/* Ortak sürüklenebilir snap şerit (buton yok, otomatik) — yorumlar + Instagram */
[data-drag-track] { display: flex; align-items: stretch; gap: 24px; overflow-x: auto; scroll-snap-type: x proximity; scroll-padding-left: 40px; scroll-behavior: smooth; cursor: grab; padding: 4px 40px 12px; scrollbar-width: none; -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 40px, #000 calc(100% - 40px), transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, #000 40px, #000 calc(100% - 40px), transparent 100%); }
[data-drag-track]::-webkit-scrollbar { display: none; }
[data-drag-track].dragging { cursor: grabbing; scroll-behavior: auto; scroll-snap-type: none; }
[data-drag-track].dragging a { pointer-events: none; }
[data-drag-track] > * { scroll-snap-align: start; user-select: none; }
/* Yorum kartı öğeleri */
.reviews-track > .review-card { flex: 0 0 360px; height: auto; align-self: stretch; display: flex; flex-direction: column; }
.reviews-track > .review-card p { flex: 1 1 auto; }
@media (max-width: 575px) { .reviews-track > .review-card { flex-basis: 300px; } }
/* Instagram öğeleri */
.ig-track > .ig-card { flex: 0 0 260px; align-self: start; }
@media (max-width: 575px) { .ig-track > .ig-card { flex-basis: 200px; } }
/* Blog kart görseli — iç padding + 4 köşe yuvarlatma (yalnız blog kartları) */
.card:has(.post-cat) .media-ph { margin: 16px 16px 0; border-radius: 12px; }
/* Temsilci öğeleri */
.agent-track { justify-content: safe center; }
.agent-track > .card { flex: 0 0 300px; align-self: stretch; }
.agent-track > .card:hover { transform: none; box-shadow: var(--shadow-sm); border-color: var(--line); }
@media (max-width: 575px) { .agent-track > .card { flex-basis: 250px; } }
/* İlan öğeleri */
.listings-track > .card { flex: 0 0 340px; align-self: stretch; display: flex; flex-direction: column; }
.listings-track > .card .card-body { flex: 1 1 auto; }
.listings-track > .card:hover { transform: none; box-shadow: var(--shadow-sm); border-color: var(--line); }
.listings-track > .card:hover .media-img { transform: none; }
@media (max-width: 575px) { .listings-track > .card { flex-basis: 300px; } }
/* Blog öğeleri */
.blog-track > .card { flex: 0 0 360px; align-self: stretch; display: flex; flex-direction: column; overflow: hidden; }
.blog-track > .card .card-body { flex: 1 1 auto; display: flex; flex-direction: column; }
.blog-track .card-body p { font-size: 14px; }
.read-more { display: inline-block; margin-top: auto; padding-top: 16px; font-weight: 600; font-size: 14px; color: var(--gold-600); }
.read-more:hover { color: var(--brand); }
/* İlan kartında fiyat satırının mt-auto'suyla boşluğu bölmesin */
.listing-card .read-more { margin-top: 10px; padding-top: 0; }
.blog-track > .card:hover { transform: none; box-shadow: var(--shadow-sm); border-color: var(--line); }
.blog-track > .card:hover .media-img { transform: none; }
@media (max-width: 575px) { .blog-track > .card { flex-basis: 300px; } }

/* ---------- Blog kategori filtresi (sekme stili) ---------- */
.blog-filter { display: flex; flex-wrap: nowrap; justify-content: safe center; gap: 28px; margin-bottom: 40px; border-bottom: 1px solid var(--line); overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%); }
.blog-filter::-webkit-scrollbar { display: none; }
.blog-filter[data-scroll-x] { cursor: grab; }
.blog-filter.dragging { cursor: grabbing; }
.blog-filter button { position: relative; flex: 0 0 auto; background: none; border: 0; padding: 10px 2px; font-weight: 600; font-size: 15px; color: var(--muted); cursor: pointer; white-space: nowrap; }
.blog-filter button::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--gold-grad); border-radius: 2px; transform: scaleX(0); transition: transform .2s ease; }
.blog-filter button:hover { color: var(--brand); }
.blog-filter button.active { color: var(--brand); }
.blog-filter button.active::after { transform: scaleX(1); }

/* ---------- Blog grid (kategori filtreli) ---------- */
.blog-grid .card { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
.blog-grid .card .card-body { flex: 1 1 auto; display: flex; flex-direction: column; }
.blog-grid .card-body p { font-size: 14px; }
.blog-grid .card:hover .media-img { transform: none; }
.agent-card { text-align: center; padding: 32px 20px; }
.agent-photo { width: 120px; height: 120px; border-radius: 50%; overflow: hidden; margin: 0 auto 16px; border: 3px solid var(--gold-050); }
.agent-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.agent-card .role { color: var(--gold-600); font-weight: 600; font-size: 14px; }

/* ---------- İstatistik ---------- */

/* İstatistik kartları (ikonlu) */
.stat-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 28px 20px; text-align: center; box-shadow: var(--shadow-sm); height: 100%; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.stat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #e0d3bf; }
.stat-ico { width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto 14px; background: var(--gold-050); color: var(--gold-600); font-size: 22px; }
.stat-card .num { display: block; font-size: 28px; font-weight: 800; letter-spacing: -0.5px; color: var(--brand); line-height: 1; }
.stat-card .lbl { display: block; margin-top: 6px; color: var(--muted); font-size: 14px; }

/* ---------- Hakkımızda (index) ---------- */
.about-figure { position: relative; }
.about-figure .media-ph { border-radius: var(--radius-lg); aspect-ratio: 4/3.4; }
.about-badge { position: absolute; right: -8px; bottom: -18px; z-index: 3; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px 20px; text-align: center; }
.about-badge .num { font-size: 34px; font-weight: 800; letter-spacing: -0.6px; line-height: 1; }
.about-badge .lbl { color: var(--brand); font-size: 13px; font-weight: 700; }
#hakkimizda .lead-muted, #hikayemiz .lead-muted { font-size: 15px; line-height: 1.75; }

/* ---------- İç sayfa başlık bandı ---------- */
.page-hero { position: relative; padding: 56px 0; color: #fff; background: linear-gradient(90deg, #1c1714 0%, #2a221d 100%); }
.page-hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(620px 320px at 88% 0%, rgba(251,220,143,.14), transparent 60%); pointer-events: none; }
.page-hero .container { position: relative; z-index: 1; }
.page-hero h1 { color: #fff; margin: 10px 0 12px; letter-spacing: -1px; }
.page-hero p { color: rgba(255,255,255,.82); font-size: var(--fs-lead); margin: 0; }
.breadcrumb-nav { font-size: 14px; color: var(--muted); }
.breadcrumb-nav a { color: var(--muted); }
.breadcrumb-nav a:hover { color: var(--gold-600); }
.breadcrumb-nav .sep { margin: 0 8px; font-size: 11px; opacity: .6; }
.breadcrumb-nav .current { color: var(--brand); font-weight: 600; }
.page-hero .breadcrumb-nav, .page-hero .breadcrumb-nav a { color: rgba(255,255,255,.7); }
.page-hero .breadcrumb-nav a:hover { color: var(--gold); }
.page-hero .breadcrumb-nav .current { color: #fff; }

/* ---------- Hizmet hub listesi (geniş yatay kartlar) ---------- */
.svc-grid .svc-card { position: relative; display: flex; flex-direction: column; height: 100%; background: #fff; border: 1px solid var(--line); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.svc-grid .svc-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #e0d3bf; }
.svc-card .media-img { transition: transform .35s ease; }
.svc-card:hover .media-img { transform: scale(1.04); }
.svc-card .svc-card-body { display: flex; flex-direction: column; flex: 1 1 auto; padding: 24px 26px 26px; }
.svc-card .svc-card-head { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.svc-card .icon-chip { margin-bottom: 0; flex-shrink: 0; }
.svc-card:hover .icon-chip { background: var(--gold-grad); color: #2a1c08; }
.svc-card h3 { font-size: 19px; margin: 0; }
.svc-card p { color: var(--muted); font-size: 15px; line-height: 1.65; margin: 0 0 14px; }
.svc-card .read-more { margin-top: auto; padding-top: 0; }
@media (max-width: 480px) { .svc-card .svc-card-body { padding: 20px; } }

/* ---------- İlan filtre paneli ---------- */
.listing-filter { background: #fff; border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--shadow-sm); padding: 20px 22px; margin-bottom: 36px; }
.listing-filter .form-label { font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 6px; }
.listing-filter .form-select, .listing-filter .form-control { border-color: var(--line); font-size: 15px; }
.listing-filter .form-select:focus, .listing-filter .form-control:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,150,47,.18); }

/* ---------- İlan grid (filtrelenebilir) ---------- */
.listings-grid .listing-card { display: flex; flex-direction: column; height: 100%; }
.listings-grid .listing-card .card-body { flex: 1 1 auto; display: flex; flex-direction: column; }
.listings-grid .listing-card .card-body > .d-flex { margin-top: auto; }
.t-cat { color: var(--muted); }
.listing-empty i { font-size: 40px; color: var(--line); }

/* ---------- Süreç adımları ---------- */
.process-step { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 28px 24px; box-shadow: var(--shadow-sm); height: 100%; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.process-step:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: #e0d3bf; }
.process-step .step-no { display: inline-grid; place-items: center; width: 44px; height: 44px; border-radius: 12px; background: var(--gold-grad); color: #2a1c08; font-weight: 800; font-size: 18px; margin-bottom: 16px; }
.process-step h3 { font-size: 18px; margin-bottom: 8px; }
.process-step p { color: var(--muted); font-size: 15px; line-height: 1.65; margin: 0; }

/* ---------- Hizmet detay: makale gövdesi ---------- */
.article-body { max-width: 820px; margin: 0 auto; }
.article-body > .media-ph { border-radius: var(--radius-lg); margin-bottom: 28px; }
.article-body .lead-muted { font-size: 16px; line-height: 1.8; }
.article-body h3 { font-size: 21px; margin: 34px 0 12px; }

/* Detaylı kapsam panelleri (2 sütun, ikon + açıklama) */
.scope-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.scope-card { display: flex; gap: 18px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 16px; padding: 24px 26px; transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease; }
.scope-card:hover { border-color: #e0d3bf; box-shadow: var(--shadow-sm); transform: translateY(-3px); }
.scope-card .scope-ico { flex-shrink: 0; width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--gold-grad); color: #2a1c08; font-size: 18px; }
.scope-card h3 { font-size: 17px; margin: 2px 0 6px; }
.scope-card p { color: var(--muted); font-size: 15px; line-height: 1.65; margin: 0; }
@media (max-width: 767px) { .scope-grid { grid-template-columns: 1fr; } }

/* ---------- Blog yazı (detay) ---------- */
.article-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 14px; margin-top: 14px; font-size: 14px; font-weight: 600; color: rgba(255,255,255,.82); }
.article-meta .cat { color: var(--gold); }
.article-meta .dot { opacity: .45; }
.article-body p { color: var(--ink); font-size: 16px; line-height: 1.8; margin: 0 0 18px; }
.article-body p.mb-0 { margin-bottom: 0; }
.article-body h2 { font-size: 25px; margin: 38px 0 14px; }
.article-body h2:first-of-type { margin-top: 8px; }
.article-body ul, .article-body ol { color: var(--ink); font-size: 16px; line-height: 1.8; padding-left: 22px; margin: 0 0 20px; }
.article-body li { margin-bottom: 8px; }
.article-body blockquote { margin: 26px 0; padding: 16px 22px; border-left: 3px solid var(--gold); background: var(--bg-soft); border-radius: 0 12px 12px 0; color: var(--ink); font-size: 17px; line-height: 1.7; }
.article-callout { background: var(--bg-soft); border: 1px solid var(--line); border-left: 4px solid var(--gold); border-radius: 0 14px 14px 0; padding: 22px 26px; margin: 30px 0; }
.article-callout h3 { font-size: 18px; margin: 0 0 12px; }
.article-callout ul { margin-bottom: 0; }
/* Blog detayda başlık bloğu görselin altında (page-hero yok) */
.article-body > .breadcrumb-nav { font-size: 14px; color: var(--muted); margin: 22px 0 12px; }
.article-body > .breadcrumb-nav a { color: var(--muted); }
.article-body > .breadcrumb-nav a:hover { color: var(--gold-600); }
.article-body > .breadcrumb-nav .current { color: var(--brand); font-weight: 600; }
.article-body > h1 { font-size: var(--fs-h1); font-weight: 800; line-height: 1.25; letter-spacing: -1px; color: var(--brand); margin: 0 0 12px; }
.article-body > .article-meta { color: var(--muted); margin: 0 0 6px; }
.article-body > .article-meta .cat { color: var(--gold-600); }

/* ---------- İlan detay ---------- */
.listing-head .loc { color: var(--muted); font-size: 16px; }
.listing-price { display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px 14px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line); }
.listing-price .price-lg { font-size: 30px; font-weight: 800; color: var(--brand); letter-spacing: -1px; line-height: 1; }
.listing-price .price-sub { color: var(--muted); font-size: 15px; }
.listing-head { margin-bottom: 24px; }
.gallery { margin: 0 0 30px; }
.gallery-main { border-radius: var(--radius-lg); margin-bottom: 12px; }
.gmain-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; width: 52px; height: 52px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25); background: rgba(255,255,255,.12); color: #fff; font-size: 18px; cursor: pointer; display: grid; place-items: center; transition: background .2s ease, color .2s ease, border-color .2s ease; }
.gmain-nav:hover { background: var(--gold-grad); color: #2a1c08; border-color: transparent; }
.gmain-nav i { font-size: inherit; position: static; z-index: auto; transition: none; }
.gmain-prev { left: 18px; }
.gmain-next { right: 18px; }
@media (max-width: 575px) { .gmain-nav { width: 42px; height: 42px; font-size: 16px; } .gmain-prev { left: 8px; } .gmain-next { right: 8px; } }
.gallery-thumbs { display: flex; flex-wrap: nowrap; gap: 12px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%); }
.gallery-thumbs::-webkit-scrollbar { display: none; }
.gallery-thumbs[data-scroll-x] { cursor: grab; }
.gallery-thumbs.dragging { cursor: grabbing; }
.gallery-thumbs .media-ph { flex: 0 0 150px; border-radius: 12px; cursor: pointer; opacity: .72; transition: opacity .2s ease, box-shadow .2s ease; }
.gallery-thumbs .media-ph:hover { opacity: 1; }
.gallery-thumbs .media-ph.is-active { opacity: 1; box-shadow: 0 0 0 3px var(--gold); }
@media (max-width: 575px) { .gallery-thumbs .media-ph { flex-basis: 120px; } }
.spec-list { list-style: none; margin: 0 0 10px; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 36px; }
.spec-list li { display: flex; justify-content: space-between; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line); font-size: 15px; }
.spec-list .s-k { color: var(--muted); }
.spec-list .s-v { color: var(--brand); font-weight: 600; text-align: right; }
@media (max-width: 575px) { .spec-list { grid-template-columns: 1fr; } }
.tapu-cta { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; background: var(--bg-soft); border: 1px solid var(--line); border-left: 4px solid var(--gold); border-radius: 0; padding: 20px 24px; }
.tapu-cta-text { display: flex; align-items: center; gap: 14px; }
.tapu-cta-text > i { font-size: 24px; color: var(--gold-600); flex-shrink: 0; }
.tapu-cta-text strong { display: block; color: var(--brand); font-size: 16px; margin-bottom: 2px; }
.tapu-cta-text span { font-size: 14px; color: var(--muted); line-height: 1.5; }
.tapu-cta .btn { flex-shrink: 0; }
@media (max-width: 575px) { .tapu-cta { flex-direction: column; align-items: stretch; } .tapu-cta .btn { align-self: center; } }
.listing-aside { position: sticky; top: 96px; display: grid; gap: 20px; }
.aside-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow-sm); padding: 26px; }
.aside-card .price-lg { font-size: 28px; font-weight: 800; color: var(--brand); letter-spacing: -.5px; }
.aside-card .meta { color: var(--muted); font-size: 14px; margin-bottom: 18px; }
.aside-agent { text-align: center; }
.aside-agent .agent-photo { width: 88px; height: 88px; margin: 0 auto 14px; }
/* Mobil sabit alt çubuk */
.listing-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 1030; display: flex; align-items: center; gap: 12px; padding: 10px 16px; background: #fff; border-top: 1px solid var(--line); box-shadow: 0 -4px 18px rgba(28,23,20,.10); }
.listing-bar .lb-bar-amount { display: block; font-size: 18px; font-weight: 800; color: var(--brand); line-height: 1.1; letter-spacing: -.4px; }
.listing-bar .lb-bar-sub { display: block; font-size: 12px; color: var(--muted); }
.listing-bar .lb-bar-actions { margin-left: auto; display: flex; gap: 8px; }
@media (max-width: 991px) { body:has(.listing-bar) { padding-bottom: 76px; } }
.gallery-main { cursor: zoom-in; }
/* Tam ekran görsel lightbox (oklarla gezinme) */
.lightbox { position: fixed; inset: 0; z-index: 1080; display: none; align-items: center; justify-content: center; background: rgba(10,8,6,.93); padding: 40px 16px; }
.lightbox.open { display: flex; }
.lb-figure { margin: 0; max-width: 1100px; width: 100%; text-align: center; }
.lb-img { max-width: 100%; max-height: 84svh; border-radius: 8px; display: block; margin: 0 auto; -webkit-user-drag: none; user-select: none; }
.lb-caption { color: rgba(255,255,255,.85); font-size: 14px; margin-top: 14px; }
.lb-counter { position: absolute; top: 22px; left: 24px; color: rgba(255,255,255,.72); font-size: 14px; font-weight: 600; }
.lb-close { position: absolute; top: 16px; right: 18px; width: 44px; height: 44px; border-radius: 50%; border: 0; background: rgba(255,255,255,.12); color: #fff; font-size: 18px; cursor: pointer; display: grid; place-items: center; }
.lb-close:hover { background: var(--gold-grad); color: #2a1c08; }
.lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25); background: rgba(255,255,255,.12); color: #fff; font-size: 18px; cursor: pointer; display: grid; place-items: center; transition: background .2s ease, color .2s ease, border-color .2s ease; }
.lb-nav:hover { background: var(--gold-grad); color: #2a1c08; border-color: transparent; }
.lb-prev { left: 18px; }
.lb-next { right: 18px; }
@media (max-width: 575px) { .lb-nav { width: 42px; height: 42px; font-size: 16px; } .lb-prev { left: 8px; } .lb-next { right: 8px; } }

/* ---------- İletişim ---------- */
.contact-info { list-style: none; margin: 0; padding: 0; }
.contact-info li { display: flex; gap: 14px; align-items: center; margin-bottom: 20px; }
.contact-info .ci-ico { flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: var(--gold-050); color: var(--gold-600); font-size: 17px; }
.contact-info .ci-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); margin-bottom: 2px; }
.contact-info .ci-val { color: var(--ink); font-size: 15px; line-height: 1.55; display: block; }
.contact-info a.ci-val:hover { color: var(--gold-600); }
.contact-social { display: flex; gap: 12px; }
.contact-social a { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; background: var(--bg-soft); color: var(--brand); border: 1px solid var(--line); font-size: 16px; transition: background .25s ease, color .25s ease, border-color .25s ease; }
.contact-social a:hover { background: var(--gold-grad); color: #2a1c08; border-color: transparent; }
.contact-panel { background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow-sm); padding: 32px; }
/* Honeypot alanı — ekran dışına taşınır (display:none bazı botlarca atlandığı için kullanılmaz) */
.hp-field { position: absolute; left: -9999px; top: -9999px; height: 1px; width: 1px; opacity: 0; pointer-events: none; }
/* Form sonuç popup'ı — ekran ortasında, karartmalı backdrop (Bootstrap modal) */
.form-result { border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow-lg); padding: 36px 32px; text-align: center; }
.form-result-icon { width: 68px; height: 68px; border-radius: 50%; display: grid; place-items: center; font-size: 30px; margin: 0 auto 18px; }
.form-result-icon.success { background: #f3f7ee; color: #5d8040; }
.form-result-icon.error { background: #fbf1ee; color: #b04f3b; }
.form-result-title { font-size: 22px; font-weight: 800; color: var(--brand); margin-bottom: 8px; }
.form-result-text { color: var(--muted); font-size: 15px; line-height: 1.6; margin-bottom: 24px; }
.map-embed { border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.map-embed iframe { display: block; width: 100%; height: 440px; border: 0; }
@media (max-width: 768px) { .contact-panel { padding: 24px; } .map-embed iframe { height: 320px; } }

/* ---------- SSS akordeon ---------- */
.faq-accordion { max-width: 820px; margin: 0 auto; }
.faq-accordion .accordion-item { border: 1px solid var(--line); border-radius: 14px; margin-bottom: 12px; overflow: hidden; background: #fff; }
.faq-accordion .accordion-button { font-weight: 600; font-size: 16px; color: var(--brand); padding: 18px 20px; }
.faq-accordion .accordion-button:focus { box-shadow: none; }
.faq-accordion .accordion-button::after { background-size: 16px; }
.faq-accordion .accordion-body { color: var(--muted); font-size: 15px; line-height: 1.7; padding-top: 0; }

/* ---------- Alt çağrı (CTA) şeridi ---------- */
.cta-band { position: relative; padding: 64px 0; text-align: center; color: #fff; background: linear-gradient(90deg, #1c1714 0%, #2a221d 100%); }
.cta-band::after { content: ""; position: absolute; inset: 0; background: radial-gradient(640px 300px at 50% 0%, rgba(251,220,143,.14), transparent 62%); pointer-events: none; }
.cta-band .container { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; margin-bottom: 12px; }
.cta-band p { color: rgba(255,255,255,.82); font-size: var(--fs-lead); max-width: 600px; margin: 0 auto 24px; }

/* ---------- Süreç adımı ---------- */

/* ---------- İletişim ikon kutusu ---------- */

/* ---------- Sosyal satır / CTA alt ---------- */
.social-row { font-size: 20px; }

/* ---------- Instagram ---------- */
.ig-card { display: block; background: linear-gradient(45deg, #feda75, #fa7e1e, #d62976, #962fbf, #4f5bd5); border: 0; border-radius: 14px; padding: 4px; box-shadow: none; }
.ig-thumb { position: relative; aspect-ratio: 1/1; border-radius: 10px; overflow: hidden; }
.ig-thumb .badge-ig { position: absolute; top: 8px; right: 10px; color: #fff; font-size: 16px; z-index: 2; }

/* ---------- İlan detay ---------- */

/* ---------- CTA bandı ---------- */

/* ---------- Footer ---------- */
.site-footer { background: var(--brand-700); color: rgba(255,255,255,.66); font-size: 15px; }
.site-footer h3 { color: #fff; letter-spacing: .8px; text-transform: uppercase; font-size: 13px; font-weight: 700; margin-bottom: 16px; }
.site-footer a { color: rgba(255,255,255,.66); }
.site-footer a:hover { color: var(--gold); }
.site-footer .brand img { height: 38px; width: auto; }
.footer-bottom { background: #0c0907; color: rgba(255,255,255,.5); font-size: 14px; }

/* ---------- Sabit mobil aksiyon ---------- */
.floating-actions { position: fixed; right: 16px; bottom: 16px; z-index: 1040; display: none; flex-direction: column; gap: 10px; }
.floating-actions a { width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-size: 20px; box-shadow: var(--shadow); transition: transform .15s ease; }
.floating-actions a:hover { transform: scale(1.08); color: #fff; }
.fab-whatsapp { background: #25d366; }
.fab-call { background: var(--gold-grad); color: #2a1c08; }
.fab-call:hover { color: #2a1c08; }
@media (min-width: 992px) {
  .floating-actions { display: none; }
  /* Bu kırılımda topbar (d-lg-block) da görünür → hero hesabında topbar + navbar düşülür */
  :root { --header-h: 108px; }
}

/* ---------- Bootstrap bindirme ---------- */
.ratio-iframe { border-radius: var(--radius); overflow: hidden; }
.accordion-button { font-weight: 600; font-size: 16px; }
.accordion-button:not(.collapsed) { background: var(--bg-soft); color: var(--brand); box-shadow: none; }
.accordion-button:focus { box-shadow: none; border-color: var(--line); }
.form-label { font-size: 14px; font-weight: 600; }
.form-control, .form-select { border-color: var(--line); border-radius: 12px; padding: 10px 14px; font-size: 15px; }
.form-control:focus, .form-select:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,150,47,.18); }
.page-link { color: var(--brand); border-radius: 10px !important; margin: 0 3px; border-color: var(--line); }
.page-item.active .page-link { background: var(--brand); border-color: var(--brand); }

/* ---------- Mobil tip ölçeği ---------- */
@media (max-width: 768px) {
  :root { --fs-h1: 30px; --fs-h2: 24px; --fs-h3: 20px; }
  /* Mobil hero: tam ekran (kararlı svh — crawl'da uzamaz), içerik ortalı, kenar padding */
  .hero-slide { min-height: auto; }
  .hero-content { text-align: center; padding-left: 20px; padding-right: 20px; padding-top: 56px; padding-bottom: 56px; }
  .hero-content .hero-title, .hero-content .subtitle { margin-left: auto; margin-right: auto; }
  .hero-content .d-flex { justify-content: center; }
  /* Mobil oklar: dikey-ortadan al, alt köşelere küçük daireler (noktalarla aynı hizada) */
  .hero-control { width: 44px; top: auto; bottom: 8px; }
  .hero-control i { width: 36px; height: 36px; font-size: 13px; }
  .section { padding: 56px 0; }
}

/* ---------- Hareket azaltma ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
  .card:hover, .feature-card:hover, .btn-gold:hover { transform: none; }
}

/* ---------- Çerez onay banner'ı ---------- */
.cookie-consent { position: fixed; left: 0; right: 0; bottom: 0; width: 100%; z-index: 1080;
  background: var(--brand); color: #f1e8da; border-top: 2px solid var(--gold);
  box-shadow: var(--shadow-lg); padding: 14px 0; }
.cookie-consent__inner { display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap; }
.cookie-consent__text { margin: 0; font-size: 14px; line-height: 1.6; color: #e6dac9; flex: 1 1 440px; }
.cookie-consent__text a { color: var(--gold); text-decoration: underline; }
.cookie-consent__text a:hover { color: #fbdc8f; }
.cookie-consent__actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-consent .btn { font-size: 14px; padding: 9px 18px; white-space: nowrap; }
.cookie-consent__ghost { border: 1.5px solid rgba(255,255,255,.4); color: #f1e8da; background: transparent; }
.cookie-consent__ghost:hover { background: rgba(255,255,255,.1); color: #fff; }
body.cc-open .floating-actions { bottom: 92px; }
@media (max-width: 767.98px) {
  .cookie-consent__inner { flex-direction: column; align-items: stretch; gap: 12px; }
  /* Kolon yönünde flex-basis (440px) yükseklik olarak uygulanır; metin doğal yüksekliğini almalı. */
  .cookie-consent__text { flex: 0 0 auto; }
  .cookie-consent__actions { width: 100%; }
  .cookie-consent__actions .btn { flex: 1 1 0; }
  body.cc-open .floating-actions { bottom: 158px; }
}
