/* ============================================================
   ErzincanPortal — Genel (Public) Tasarım Sistemi
   Saf CSS. Token → bileşen → cila → motion.
   ============================================================ */

/* ---------- 1. TOKENLAR ---------- */
:root{
  /* Marka & renk */
  --bordo:        #6E1622;   /* logo bordosu — marka, header derinliği */
  --bordo-koyu:   #500F18;
  --kirmizi:      #C81E2D;   /* aksiyon — buton, fiyat, aktif durum */
  --kirmizi-koyu: #A01521;   /* hover */
  --kirmizi-soft: #FBEAEB;   /* açık kırmızı zemin (rozet/uyarı) */

  --ink:          #18120F;   /* en koyu metin / siyah header */
  --antrasit:     #221B17;

  /* Nötr rampa (sıcak gri) */
  --bg:           #F4F3F1;   /* sayfa zemini */
  --surface:      #FFFFFF;   /* kart yüzeyi */
  --surface-2:    #FAF9F7;   /* hafif gri yüzey */
  --line:         rgba(24,18,15,.10);
  --line-strong:  rgba(24,18,15,.16);
  --text:         #1D1814;
  --muted:        #6E6760;   /* ikincil metin */
  --faint:        #9A938B;   /* en silik */

  /* Durum */
  --basari:   #15803D;
  --basari-bg:#E7F4EC;
  --uyari:    #B45309;
  --uyari-bg: #FBF0DC;
  --bilgi:    #1D6FB8;
  --gold:     #C98A12;   /* vitrin — koyu altın, beyaz üstünde okunur */
  --gold-bg:  #FBF1D9;
  --gold-line:#E7C25A;

  /* Tipografi */
  --font: "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Boşluk (4/8 grid) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px; --s7:48px; --s8:64px;

  /* Radius */
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:22px; --r-pill:999px;

  /* Gölge — katmanlı, ince */
  --sh-1: 0 1px 2px rgba(24,18,15,.05), 0 1px 1px rgba(24,18,15,.04);
  --sh-2: 0 4px 16px -8px rgba(24,18,15,.18), 0 1px 2px rgba(24,18,15,.06);
  --sh-3: 0 14px 34px -14px rgba(24,18,15,.28), 0 2px 6px rgba(24,18,15,.08);

  /* Motion */
  --ease: cubic-bezier(.22,1,.36,1);
  --dur:  220ms;

  --maxw: 1240px;
}

/* ---------- 2. RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ overflow-x:hidden; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--font); color:var(--text);
  background:var(--bg); font-size:15px; line-height:1.55;
  font-weight:400; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; line-height:1.08; letter-spacing:-.02em; font-weight:800; color:var(--ink); }
h1{ font-size:34px; }
h2{ font-size:25px; }
h3{ font-size:19px; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
:focus-visible{ outline:2.5px solid var(--kirmizi); outline-offset:2px; border-radius:4px; }
.tnum{ font-variant-numeric:tabular-nums; }

/* ---------- 3. LAYOUT ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--s5); }
.section{ padding-block:var(--s7); }
.row{ display:flex; gap:var(--s3); align-items:center; }
.spread{ display:flex; justify-content:space-between; align-items:center; gap:var(--s4); }
.stack{ display:flex; flex-direction:column; }
.grow{ flex:1; }
.hide{ display:none !important; }

/* ---------- 4. TOPBAR (ince, koyu) ---------- */
.topbar{
  background:var(--ink); color:#E9E4DF; font-size:13px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar .wrap{ display:flex; align-items:center; gap:var(--s4); height:38px; }
.topbar a{ color:#C9C2BB; display:inline-flex; align-items:center; gap:6px; transition:color var(--dur); }
.topbar a:hover{ color:#fff; }
.topbar .loc{ font-weight:600; color:#fff; }
.topbar .sep{ width:1px; height:16px; background:rgba(255,255,255,.14); }
.topbar .right{ margin-left:auto; display:flex; align-items:center; gap:var(--s4); }

/* ---------- 5. HEADER ---------- */
.header{ background:var(--surface); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:50; }
.header .wrap{ display:flex; align-items:center; gap:var(--s5); height:74px; }
.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand img{ width:42px; height:42px; border-radius:9px; }
.brand .bt{ display:flex; flex-direction:column; line-height:1; }
.brand .bt b{ font-size:18px; font-weight:800; letter-spacing:-.02em; color:var(--ink); }
.brand .bt span{ font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--kirmizi); font-weight:700; margin-top:3px; }

/* Arama çubuğu */
.searchbar{ flex:1; display:flex; align-items:stretch; background:var(--surface-2);
  border:1.5px solid var(--line-strong); border-radius:var(--r-pill); height:48px; overflow:hidden;
  transition:border-color var(--dur), box-shadow var(--dur); max-width:560px; }
.searchbar:focus-within{ border-color:var(--kirmizi); box-shadow:0 0 0 4px var(--kirmizi-soft); }
.searchbar select{ border:0; background:transparent; padding:0 12px 0 18px; font:inherit; font-weight:600;
  color:var(--text); cursor:pointer; max-width:140px; }
.searchbar .div{ width:1px; background:var(--line-strong); margin-block:10px; }
.searchbar input{ border:0; background:transparent; flex:1; padding:0 14px; font:inherit; min-width:60px; }
.searchbar input:focus{ outline:none; }
.searchbar button{ border:0; background:var(--kirmizi); color:#fff; width:48px; display:grid; place-items:center;
  margin:4px; border-radius:var(--r-pill); transition:background var(--dur); }
.searchbar button:hover{ background:var(--kirmizi-koyu); }

.header .acts{ display:flex; align-items:center; gap:var(--s3); margin-left:auto; }
.iconbtn{ position:relative; width:42px; height:42px; border-radius:var(--r-md); border:1px solid var(--line);
  background:var(--surface); display:grid; place-items:center; color:var(--text); transition:all var(--dur); }
.iconbtn:hover{ background:var(--surface-2); border-color:var(--line-strong); }
.iconbtn .dot{ position:absolute; top:-5px; right:-5px; min-width:18px; height:18px; padding:0 4px;
  background:var(--kirmizi); color:#fff; font-size:11px; font-weight:700; border-radius:var(--r-pill);
  display:grid; place-items:center; border:2px solid var(--surface); }

/* ---------- 6. NAV (kategori şeridi) ---------- */
.catnav{ background:var(--surface); border-bottom:1px solid var(--line); }
.catnav .wrap{ display:flex; align-items:center; gap:2px; height:50px; overflow-x:auto; scrollbar-width:none; }
.catnav .wrap::-webkit-scrollbar{ display:none; }
.catnav a{ display:inline-flex; align-items:center; gap:7px; padding:0 14px; height:34px; border-radius:var(--r-sm);
  font-size:14px; font-weight:600; color:var(--muted); white-space:nowrap; transition:all var(--dur); }
.catnav a:hover{ background:var(--surface-2); color:var(--ink); }
.catnav a.all{ color:var(--ink); font-weight:700; }
.catnav a.on{ color:var(--kirmizi); background:var(--kirmizi-soft); }
.catnav a svg{ width:17px; height:17px; }

/* ---------- 7. BUTONLAR ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; height:44px; padding:0 20px;
  border-radius:var(--r-sm); border:1.5px solid transparent; font-weight:700; font-size:14.5px; line-height:1;
  transition:transform 120ms var(--ease), background var(--dur), border-color var(--dur), box-shadow var(--dur);
  white-space:nowrap; }
.btn:active{ transform:scale(.97); }
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--kirmizi); color:#fff; box-shadow:var(--sh-2); }
.btn-primary:hover{ background:var(--kirmizi-koyu); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ background:var(--antrasit); }
.btn-ghost{ background:var(--surface); color:var(--text); border-color:var(--line-strong); }
.btn-ghost:hover{ background:var(--surface-2); border-color:var(--ink); }
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ filter:brightness(.94); }
.btn-sm{ height:36px; padding:0 14px; font-size:13.5px; border-radius:var(--r-sm); }
.btn-lg{ height:52px; padding:0 28px; font-size:16px; }
.btn-block{ width:100%; }
.btn-ilanver{ background:var(--kirmizi); color:#fff; box-shadow:var(--sh-2); font-weight:800; }
.btn-ilanver:hover{ background:var(--kirmizi-koyu); }

/* ---------- 8. ROZETLER ---------- */
.badge{ display:inline-flex; align-items:center; gap:5px; height:24px; padding:0 9px; border-radius:var(--r-sm);
  font-size:12px; font-weight:700; letter-spacing:.01em; white-space:nowrap; }
.badge svg{ width:13px; height:13px; }
.badge-vitrin{ background:var(--gold-bg); color:#8A5D00; border:1px solid var(--gold-line); }
.badge-aktif{ background:var(--basari-bg); color:var(--basari); }
.badge-bekliyor{ background:var(--uyari-bg); color:var(--uyari); }
.badge-satildi{ background:#EFEDEB; color:var(--muted); }
.badge-sifir{ background:#EAF1FB; color:var(--bilgi); }
.badge-ikinci{ background:#EFEDEB; color:var(--muted); }
.badge-soft{ background:var(--surface-2); color:var(--muted); border:1px solid var(--line); }

/* ---------- 9. İLAN KARTI (en kritik) ---------- */
.card-grid{ display:grid; gap:var(--s4); grid-template-columns:repeat(4,1fr); }
.ilan{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  display:flex; flex-direction:column; transition:transform var(--dur) var(--ease), box-shadow var(--dur), border-color var(--dur); position:relative; }
.ilan:hover{ transform:translateY(-4px); box-shadow:var(--sh-3); border-color:var(--line-strong); }
.ilan.vitrinli{ border-color:var(--gold-line); box-shadow:0 0 0 1px var(--gold-line); }
.ilan .ph{ aspect-ratio:4/3; position:relative; overflow:hidden; }
.ilan .ph img{ width:100%; height:100%; object-fit:cover; transition:transform 500ms var(--ease); }
.ilan:hover .ph img{ transform:scale(1.05); }
.ilan .fav{ position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.92); backdrop-filter:blur(4px); border:0; display:grid; place-items:center;
  color:var(--ink); box-shadow:var(--sh-1); transition:transform 120ms var(--ease), color var(--dur); z-index:2; }
.ilan .fav:hover{ transform:scale(1.1); }
.ilan .fav.on{ color:var(--kirmizi); }
.ilan .fav.on svg{ fill:currentColor; }
.ilan .ph .ribbon{ position:absolute; top:10px; left:10px; z-index:2; }
.ilan .body{ padding:12px 13px 14px; display:flex; flex-direction:column; gap:6px; flex:1; }
.ilan .price{ font-size:19px; font-weight:800; color:var(--kirmizi); letter-spacing:-.01em; }
.ilan .title{ font-size:14.5px; font-weight:600; color:var(--ink); line-height:1.35; display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.7em; }
.ilan .meta{ margin-top:auto; display:flex; align-items:center; gap:8px; color:var(--faint); font-size:12.5px; }
.ilan .meta .mi{ display:inline-flex; align-items:center; gap:4px; }
.ilan .meta svg{ width:13px; height:13px; }
.ilan .meta .d{ margin-left:auto; }

/* ---------- 10. KATEGORİ IZGARASI ---------- */
.cat-grid{ display:grid; gap:var(--s3); grid-template-columns:repeat(8,1fr); }
.cat-tile{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:18px 12px;
  display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; transition:all var(--dur) var(--ease); }
.cat-tile:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); border-color:var(--line-strong); }
.cat-tile .ci{ width:48px; height:48px; border-radius:var(--r-md); display:grid; place-items:center;
  background:var(--kirmizi-soft); color:var(--kirmizi); }
.cat-tile:hover .ci{ background:var(--kirmizi); color:#fff; }
.cat-tile .ci svg{ width:24px; height:24px; }
.cat-tile b{ font-size:13px; font-weight:700; color:var(--ink); }
.cat-tile span{ font-size:11.5px; color:var(--faint); }

/* ---------- 11. BÖLÜM BAŞLIĞI ---------- */
.shead{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s4); margin-bottom:var(--s5); }
.shead .tt{ display:flex; flex-direction:column; gap:4px; }
.shead .kicker{ font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--kirmizi); }
.shead h2{ font-size:24px; }
.shead a.more{ font-size:14px; font-weight:700; color:var(--muted); display:inline-flex; align-items:center; gap:5px; transition:color var(--dur); }
.shead a.more:hover{ color:var(--kirmizi); }
.shead a.more svg{ width:16px; height:16px; }

/* ---------- 12. İŞLETME / HABER KARTLARI ---------- */
.biz{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:all var(--dur) var(--ease); }
.biz:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); }
.biz .ph{ aspect-ratio:16/10; }
.biz .ph img{ width:100%; height:100%; object-fit:cover; }
.biz .body{ padding:14px; display:flex; flex-direction:column; gap:7px; }
.biz .body h3{ font-size:16px; }
.biz .body p{ font-size:13px; color:var(--muted); line-height:1.5; }

.haber{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:all var(--dur) var(--ease); display:flex; flex-direction:column; }
.haber:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); }
.haber .ph{ aspect-ratio:16/9; }
.haber .ph img{ width:100%; height:100%; object-fit:cover; }
.haber .body{ padding:16px; display:flex; flex-direction:column; gap:8px; flex:1; }
.haber .body .dt{ font-size:12px; font-weight:700; color:var(--kirmizi); letter-spacing:.02em; }
.haber .body h3{ font-size:17px; line-height:1.25; }
.haber .body p{ font-size:13.5px; color:var(--muted); line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ---------- 13. PLACEHOLDER GÖRSEL (gradient) ---------- */
.ph{ background:linear-gradient(135deg,#E8E4DF,#D9D3CB); position:relative; }
.ph[data-tone="1"]{ background:linear-gradient(135deg,#E9D8C3,#D8BE9E); }
.ph[data-tone="2"]{ background:linear-gradient(135deg,#D7E0E8,#B6C6D4); }
.ph[data-tone="3"]{ background:linear-gradient(135deg,#E6D7DA,#CFA9B0); }
.ph[data-tone="4"]{ background:linear-gradient(135deg,#D9E2D6,#B2C4AC); }
.ph[data-tone="5"]{ background:linear-gradient(135deg,#E5DDD0,#CBBFA6); }
.ph[data-tone="6"]{ background:linear-gradient(135deg,#DDD9E2,#B9B1C8); }
.ph .ph-ic{ position:absolute; inset:0; display:grid; place-items:center; color:rgba(24,18,15,.16); }
.ph .ph-ic svg{ width:38px; height:38px; }

/* ---------- 14. FORM ---------- */
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:var(--s4); }
.field > label{ font-size:13.5px; font-weight:700; color:var(--ink); }
.field .hint{ font-size:12.5px; color:var(--faint); }
.input, .select, .textarea{ width:100%; border:1.5px solid var(--line-strong); background:var(--surface);
  border-radius:var(--r-sm); padding:0 14px; height:46px; font:inherit; color:var(--text); transition:border-color var(--dur), box-shadow var(--dur); }
.textarea{ height:auto; padding:12px 14px; resize:vertical; min-height:120px; line-height:1.55; }
.input:focus, .select:focus, .textarea:focus{ outline:none; border-color:var(--kirmizi); box-shadow:0 0 0 4px var(--kirmizi-soft); }
.input::placeholder, .textarea::placeholder{ color:var(--faint); }
.select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236E6760' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:40px; cursor:pointer; }
.input-price{ position:relative; }
.input-price input{ padding-left:34px; }
.input-price::before{ content:"₺"; position:absolute; left:14px; top:0; height:46px; display:grid; align-items:center; color:var(--kirmizi); font-weight:800; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s4); }

/* Switch */
.switch{ position:relative; width:46px; height:26px; flex-shrink:0; }
.switch input{ position:absolute; opacity:0; width:100%; height:100%; margin:0; cursor:pointer; }
.switch .track{ position:absolute; inset:0; background:var(--line-strong); border-radius:var(--r-pill); transition:background var(--dur); }
.switch .track::after{ content:""; position:absolute; top:3px; left:3px; width:20px; height:20px; background:#fff; border-radius:50%; box-shadow:var(--sh-1); transition:transform var(--dur) var(--ease); }
.switch input:checked + .track{ background:var(--kirmizi); }
.switch input:checked + .track::after{ transform:translateX(20px); }

/* ---------- 15. BREADCRUMB / PAGINATION / TABS ---------- */
.crumb{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); flex-wrap:wrap; }
.crumb a:hover{ color:var(--kirmizi); }
.crumb .sep{ color:var(--faint); }
.crumb .cur{ color:var(--ink); font-weight:600; }

.pager{ display:flex; align-items:center; justify-content:center; gap:6px; margin-top:var(--s6); }
.pager a, .pager span{ min-width:40px; height:40px; padding:0 8px; border-radius:var(--r-sm); border:1px solid var(--line);
  display:grid; place-items:center; font-weight:700; font-size:14px; background:var(--surface); color:var(--text); transition:all var(--dur); }
.pager a:hover{ border-color:var(--ink); }
.pager .on{ background:var(--kirmizi); color:#fff; border-color:var(--kirmizi); }
.pager .nope{ color:var(--faint); cursor:default; }

.tabs{ display:flex; gap:2px; border-bottom:1.5px solid var(--line); }
.tabs button{ background:none; border:0; padding:12px 16px; font:inherit; font-weight:700; font-size:14.5px;
  color:var(--muted); border-bottom:2.5px solid transparent; margin-bottom:-1.5px; transition:color var(--dur), border-color var(--dur); }
.tabs button:hover{ color:var(--ink); }
.tabs button.on{ color:var(--kirmizi); border-bottom-color:var(--kirmizi); }

/* ---------- 16. FİLTRE PANELİ ---------- */
.filters{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:18px; align-self:start; position:sticky; top:90px; }
.filters .fg{ padding-block:16px; border-bottom:1px solid var(--line); }
.filters .fg:first-child{ padding-top:0; }
.filters .fg:last-child{ border-bottom:0; padding-bottom:0; }
.filters .fg > b{ display:block; font-size:13.5px; font-weight:800; color:var(--ink); margin-bottom:12px; }
.chk{ display:flex; align-items:center; gap:9px; padding:5px 0; font-size:13.5px; color:var(--text); cursor:pointer; }
.chk input{ width:18px; height:18px; accent-color:var(--kirmizi); cursor:pointer; }
.chk .ct{ margin-left:auto; color:var(--faint); font-size:12.5px; }
.price-range{ display:grid; grid-template-columns:1fr auto 1fr; gap:8px; align-items:center; }
.price-range input{ height:40px; border:1.5px solid var(--line-strong); border-radius:var(--r-sm); padding:0 10px; font:inherit; width:100%; }
.price-range span{ color:var(--faint); }

/* ---------- 17. AVATAR / BOŞ DURUM / TOAST ---------- */
.avatar{ border-radius:50%; object-fit:cover; background:var(--surface-2); display:grid; place-items:center;
  font-weight:800; color:var(--kirmizi); flex-shrink:0; }
.empty{ text-align:center; padding:var(--s8) var(--s5); color:var(--muted); }
.empty .ei{ width:72px; height:72px; border-radius:50%; background:var(--surface-2); display:grid; place-items:center; margin:0 auto 16px; color:var(--faint); }
.empty h3{ margin-bottom:6px; }

.toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff;
  padding:13px 20px; border-radius:var(--r-md); box-shadow:var(--sh-3); font-weight:600; font-size:14px; z-index:200;
  opacity:0; pointer-events:none; transition:all var(--dur) var(--ease); display:flex; align-items:center; gap:10px; }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.toast svg{ width:18px; height:18px; color:var(--gold); }

/* ---------- 18. FOOTER ---------- */
.footer{ background:var(--ink); color:#B8B1AA; margin-top:var(--s8); }
.footer .wrap{ padding-block:var(--s7); }
.footer .cols{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:var(--s6); }
.footer h4{ color:#fff; font-size:14px; letter-spacing:.04em; text-transform:uppercase; margin-bottom:16px; font-weight:800; }
.footer .fbrand{ display:flex; align-items:center; gap:11px; margin-bottom:14px; }
.footer .fbrand img{ width:44px; height:44px; border-radius:9px; }
.footer .fbrand b{ color:#fff; font-size:18px; }
.footer ul li{ margin-bottom:10px; }
.footer ul a{ font-size:14px; transition:color var(--dur); }
.footer ul a:hover{ color:#fff; }
.footer .desc{ font-size:13.5px; line-height:1.6; max-width:280px; }
.footer .social{ display:flex; gap:10px; margin-top:16px; }
.footer .social a{ width:38px; height:38px; border-radius:var(--r-sm); background:rgba(255,255,255,.07); display:grid; place-items:center; color:#C9C2BB; transition:all var(--dur); }
.footer .social a:hover{ background:var(--kirmizi); color:#fff; }
.footer .bottom{ border-top:1px solid rgba(255,255,255,.08); margin-top:var(--s6); padding-top:var(--s4); display:flex; justify-content:space-between; align-items:center; gap:var(--s4); font-size:13px; }
.footer .bottom .made b{ color:var(--kirmizi); font-weight:700; }

/* ---------- 19. MOTION ---------- */
@keyframes fadeUp{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(200,30,45,.5); } 50%{ box-shadow:0 0 0 6px rgba(200,30,45,0); } }
.live-dot{ width:8px; height:8px; border-radius:50%; background:var(--kirmizi); animation:pulse 2s infinite; }
@media (prefers-reduced-motion:no-preference){
  .reveal{ animation:fadeUp var(--dur) var(--ease) both; }
}

/* ---------- 19b. EK BİLEŞENLER ---------- */
.noscroll{ overflow:hidden; }

/* Hero arama bandı */
.hero{ background:
    radial-gradient(120% 130% at 85% 0%, rgba(200,30,45,.12), transparent 60%),
    linear-gradient(180deg, #221B17, #18120F);
  color:#fff; position:relative; overflow:hidden; }
.hero::after{ content:""; position:absolute; inset:0; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size:22px 22px; }
.hero .wrap{ position:relative; z-index:1; padding-block:48px 56px; }
.hero h1{ color:#fff; font-size:40px; max-width:640px; line-height:1.05; }
.hero p{ color:#CDC6BF; font-size:17px; margin-top:14px; max-width:560px; }
.hero .hsearch{ margin-top:28px; max-width:680px; background:#fff; border-radius:var(--r-pill); height:60px; display:flex; align-items:center; padding:6px; box-shadow:var(--sh-3); }
.hero .hsearch select{ border:0; background:transparent; padding:0 14px 0 18px; font:inherit; font-weight:700; color:var(--ink); cursor:pointer; }
.hero .hsearch .div{ width:1px; height:28px; background:var(--line-strong); }
.hero .hsearch input{ flex:1; border:0; padding:0 16px; font:inherit; font-size:15px; }
.hero .hsearch input:focus{ outline:none; }
.hero .hsearch button{ height:48px; padding:0 26px; border:0; border-radius:var(--r-pill); background:var(--kirmizi); color:#fff; font-weight:800; font-size:15px; display:flex; align-items:center; gap:8px; transition:background var(--dur); }
.hero .hsearch button:hover{ background:var(--kirmizi-koyu); }
.hero .hsearch button svg{ width:18px; height:18px; }
.hero .tags{ display:flex; gap:8px; margin-top:18px; flex-wrap:wrap; align-items:center; }
.hero .tags span{ color:#9A938B; font-size:13px; font-weight:600; }
.hero .tags a{ font-size:13px; font-weight:600; color:#E9E4DF; padding:5px 12px; border-radius:var(--r-pill); border:1px solid rgba(255,255,255,.16); transition:all var(--dur); }
.hero .tags a:hover{ background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.3); }
.hero .stats{ display:flex; gap:32px; margin-top:30px; }
.hero .stats .st b{ display:block; font-size:26px; font-weight:800; color:#fff; }
.hero .stats .st span{ font-size:13px; color:#9A938B; }

/* Vitrin şeridi */
.vitrin-strip{ background:linear-gradient(180deg,#FFFDF7,var(--bg)); }
.vitrin-head{ display:flex; align-items:center; gap:10px; }
.vitrin-head .vb{ display:inline-flex; align-items:center; gap:6px; background:var(--gold); color:#fff; font-weight:800; font-size:12px; letter-spacing:.06em; text-transform:uppercase; padding:5px 11px; border-radius:var(--r-sm); }
.vitrin-head .vb svg{ width:14px; height:14px; }

/* Dropdown (üye menüsü) */
.dropdown{ position:absolute; top:calc(100% + 10px); right:0; min-width:230px; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-3); padding:7px; z-index:80;
  opacity:0; visibility:hidden; transform:translateY(-6px); transition:all 160ms var(--ease); }
.dropdown.open{ opacity:1; visibility:visible; transform:none; }
.dropdown .dh{ padding:10px 12px; display:flex; align-items:center; gap:10px; border-bottom:1px solid var(--line); margin-bottom:6px; }
.dropdown .dh b{ font-size:14px; display:block; }
.dropdown .dh span{ font-size:12px; color:var(--faint); }
.dropdown a{ display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:var(--r-sm); font-size:14px; font-weight:600; color:var(--text); transition:background var(--dur); }
.dropdown a:hover{ background:var(--surface-2); }
.dropdown a svg{ width:17px; height:17px; color:var(--muted); }
.dropdown a.danger{ color:var(--kirmizi); }
.dropdown a.danger svg{ color:var(--kirmizi); }
.dropdown .sep{ height:1px; background:var(--line); margin:6px 4px; }
.menu-wrap{ position:relative; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; background:rgba(15,11,9,.92); z-index:300; display:grid; place-items:center;
  opacity:0; visibility:hidden; transition:opacity var(--dur); padding:40px; }
.lightbox.show{ opacity:1; visibility:visible; }
.lightbox .lb-stage{ width:min(900px,90vw); aspect-ratio:4/3; border-radius:var(--r-lg); }
.lightbox .lb-close{ position:absolute; top:24px; right:24px; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.12); border:0; color:#fff; display:grid; place-items:center; transition:background var(--dur); }
.lightbox .lb-close:hover{ background:rgba(255,255,255,.24); }
.lightbox .lb-close svg{ width:22px; height:22px; }

/* Mobil filtre overlay */
@media (max-width:900px){
  .filters{ position:fixed; inset:auto 0 0 0; top:auto; max-height:84vh; overflow-y:auto; border-radius:var(--r-xl) var(--r-xl) 0 0;
    transform:translateY(102%); transition:transform var(--dur) var(--ease); z-index:120; box-shadow:var(--sh-3); }
  .filters.filters-open{ transform:none; }
  .filters-mobile-head{ display:flex !important; }
}
.filters-mobile-head{ display:none; }

/* Liste sayfası düzeni */
.list-layout{ display:grid; grid-template-columns:280px 1fr; gap:var(--s5); align-items:start; }
.list-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:var(--s4); margin-bottom:var(--s4);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:12px 16px; }
.list-toolbar .lc{ font-size:14px; color:var(--muted); }
.list-toolbar .lc b{ color:var(--ink); }
.list-toolbar .sort{ display:flex; align-items:center; gap:10px; }
.list-toolbar .sort .select{ height:40px; width:auto; min-width:160px; }
.view-toggle{ display:flex; gap:2px; background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-sm); padding:3px; }
.view-toggle button{ width:34px; height:30px; border:0; background:none; border-radius:6px; display:grid; place-items:center; color:var(--muted); }
.view-toggle button.on{ background:var(--surface); color:var(--kirmizi); box-shadow:var(--sh-1); }
.view-toggle svg{ width:16px; height:16px; }
.active-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:var(--s4); }
.active-chips .chip{ display:inline-flex; align-items:center; gap:6px; background:var(--kirmizi-soft); color:var(--kirmizi);
  font-size:13px; font-weight:600; padding:6px 10px; border-radius:var(--r-pill); }
.active-chips .chip button{ border:0; background:none; color:inherit; display:grid; place-items:center; padding:0; }
.active-chips .chip svg{ width:13px; height:13px; }
.active-chips .clear{ font-size:13px; font-weight:700; color:var(--muted); background:none; border:0; }
.active-chips .clear:hover{ color:var(--kirmizi); }
@media (max-width:900px){
  .list-layout{ grid-template-columns:1fr; }
  .filters-backdrop{ position:fixed; inset:0; background:rgba(15,11,9,.5); z-index:110; }
}
.btn-filter-mobile{ display:none; }
@media (max-width:900px){ .btn-filter-mobile{ display:inline-flex; } }

/* Liste görünümü (yatay kart) */
.card-grid.as-list{ grid-template-columns:1fr; }
.card-grid.as-list .ilan{ flex-direction:row; }
.card-grid.as-list .ilan .ph{ width:240px; aspect-ratio:4/3; flex-shrink:0; }
.card-grid.as-list .ilan .body{ padding:16px 18px; }
.card-grid.as-list .ilan .title{ font-size:16px; -webkit-line-clamp:1; min-height:0; }
.card-grid.as-list .ilan .price{ font-size:21px; order:-1; }
@media (max-width:560px){ .card-grid.as-list .ilan{ flex-direction:column; } .card-grid.as-list .ilan .ph{ width:100%; } }

/* ---------- İLAN DETAY ---------- */
.detail-layout{ display:grid; grid-template-columns:1fr 350px; gap:var(--s5); align-items:start; }
.gallery .main{ aspect-ratio:4/3; border-radius:var(--r-lg); overflow:hidden; cursor:zoom-in; position:relative; border:1px solid var(--line); }
.gallery .main .ph-ic{ color:rgba(24,18,15,.2); }
.gallery .main .zoom{ position:absolute; bottom:14px; right:14px; background:rgba(255,255,255,.92); backdrop-filter:blur(4px);
  border-radius:var(--r-pill); padding:7px 13px; font-size:13px; font-weight:700; display:flex; align-items:center; gap:6px; box-shadow:var(--sh-1); }
.gallery .main .zoom svg{ width:15px; height:15px; }
.gallery .main .gcount{ position:absolute; top:14px; left:14px; background:rgba(15,11,9,.7); color:#fff; border-radius:var(--r-pill); padding:5px 12px; font-size:13px; font-weight:600; }
.gallery .thumbs{ display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-top:12px; }
.gallery .thumbs .th{ aspect-ratio:1; border-radius:var(--r-sm); overflow:hidden; cursor:pointer; border:2px solid transparent; position:relative; }
.gallery .thumbs .th.on{ border-color:var(--kirmizi); }
.gallery .thumbs .th .ph-ic svg{ width:22px; height:22px; }

.dt-title{ display:flex; flex-direction:column; gap:10px; margin-top:24px; }
.dt-title .badges{ display:flex; gap:8px; }
.dt-title h1{ font-size:27px; line-height:1.15; }
.dt-title .dt-meta{ display:flex; align-items:center; gap:16px; color:var(--muted); font-size:13.5px; flex-wrap:wrap; }
.dt-title .dt-meta span{ display:inline-flex; align-items:center; gap:6px; }
.dt-title .dt-meta svg{ width:15px; height:15px; }

.dt-section{ margin-top:32px; }
.dt-section h2{ font-size:19px; margin-bottom:14px; padding-bottom:10px; border-bottom:2px solid var(--line); }
.dt-desc{ color:var(--text); line-height:1.7; font-size:15px; }
.dt-desc p{ margin-bottom:12px; }

/* Özellik tablosu */
.spec-table{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; }
.spec-table .sp{ background:var(--surface); padding:13px 16px; display:flex; justify-content:space-between; gap:12px; font-size:14px; }
.spec-table .sp .k{ color:var(--muted); }
.spec-table .sp .v{ font-weight:700; color:var(--ink); text-align:right; }
@media (max-width:560px){ .spec-table{ grid-template-columns:1fr; } }

/* Fiyat kutusu + satıcı (sticky) */
.dt-aside{ position:sticky; top:90px; display:flex; flex-direction:column; gap:16px; }
.price-box{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--sh-2); }
.price-box .pp{ font-size:32px; font-weight:800; color:var(--kirmizi); letter-spacing:-.02em; }
.price-box .pgorus{ font-size:13px; color:var(--muted); margin-top:2px; }
.price-box .pacts{ display:flex; flex-direction:column; gap:10px; margin-top:18px; }
.price-box .pacts .splitrow{ display:flex; gap:10px; }
.price-box .pacts .splitrow .btn{ flex:1; }

.seller-box{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; }
.seller-box .sh{ display:flex; align-items:center; gap:12px; }
.seller-box .sh .avatar{ width:52px; height:52px; font-size:18px; }
.seller-box .sh b{ font-size:16px; display:block; }
.seller-box .sh .rate{ display:flex; align-items:center; gap:4px; color:var(--gold); font-size:13px; font-weight:700; margin-top:2px; }
.seller-box .sh .rate svg{ width:14px; height:14px; }
.seller-box .sh .rate span{ color:var(--muted); font-weight:500; }
.seller-box .smeta{ font-size:13px; color:var(--muted); margin-top:14px; display:flex; flex-direction:column; gap:7px; }
.seller-box .smeta div{ display:flex; align-items:center; gap:8px; }
.seller-box .smeta svg{ width:15px; height:15px; color:var(--faint); }
.safety{ background:var(--gold-bg); border:1px solid var(--gold-line); border-radius:var(--r-md); padding:14px 16px; font-size:12.5px; color:#7A5400; line-height:1.5; display:flex; gap:10px; }
.safety svg{ width:18px; height:18px; flex-shrink:0; color:var(--gold); margin-top:1px; }
.dt-minor{ display:flex; gap:18px; margin-top:14px; }
.dt-minor button{ background:none; border:0; color:var(--muted); font-size:13px; font-weight:600; display:inline-flex; align-items:center; gap:6px; padding:0; }
.dt-minor button:hover{ color:var(--kirmizi); }
.dt-minor svg{ width:15px; height:15px; }

@media (max-width:900px){ .detail-layout{ grid-template-columns:1fr; } .dt-aside{ position:static; } }

/* ---------- AUTH (giriş / kayıt) ---------- */
.auth-wrap{ min-height:calc(100vh - 113px); display:grid; grid-template-columns:1fr 1fr; }
.auth-side{ background:
    radial-gradient(120% 120% at 80% 10%, rgba(200,30,45,.18), transparent 55%),
    linear-gradient(180deg,#221B17,#18120F); color:#fff; padding:56px; display:flex; flex-direction:column; position:relative; overflow:hidden; }
.auth-side::after{ content:""; position:absolute; inset:0; opacity:.5; background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size:22px 22px; }
.auth-side .as-in{ position:relative; z-index:1; display:flex; flex-direction:column; height:100%; }
.auth-side .abrand{ display:flex; align-items:center; gap:12px; }
.auth-side .abrand img{ width:46px; height:46px; border-radius:10px; }
.auth-side .abrand b{ font-size:20px; }
.auth-side .amid{ margin-top:auto; }
.auth-side h2{ color:#fff; font-size:30px; line-height:1.15; max-width:420px; }
.auth-side p{ color:#CDC6BF; margin-top:14px; font-size:16px; max-width:420px; line-height:1.55; }
.auth-side .feats{ margin-top:28px; display:flex; flex-direction:column; gap:14px; }
.auth-side .feats div{ display:flex; align-items:center; gap:12px; font-size:14.5px; color:#E9E4DF; }
.auth-side .feats .fi{ width:34px; height:34px; border-radius:9px; background:rgba(255,255,255,.1); display:grid; place-items:center; flex-shrink:0; }
.auth-side .feats svg{ width:18px; height:18px; color:var(--gold); }
.auth-main{ display:grid; place-items:center; padding:48px 24px; background:var(--bg); }
.auth-card{ width:100%; max-width:400px; }
.auth-card .ac-head{ text-align:center; margin-bottom:28px; }
.auth-card .ac-head h1{ font-size:27px; }
.auth-card .ac-head p{ color:var(--muted); margin-top:8px; }
.auth-card .ac-head p a{ color:var(--kirmizi); font-weight:700; }
.auth-divider{ display:flex; align-items:center; gap:14px; margin:22px 0; color:var(--faint); font-size:13px; font-weight:600; }
.auth-divider::before, .auth-divider::after{ content:""; flex:1; height:1px; background:var(--line); }
.social-auth{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.social-auth a{ height:46px; border:1.5px solid var(--line-strong); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; gap:9px; font-weight:700; font-size:14px; background:var(--surface); transition:border-color var(--dur); }
.social-auth a:hover{ border-color:var(--ink); }
.social-auth svg{ width:19px; height:19px; }
.input-pass{ position:relative; }
.input-pass .toggle{ position:absolute; right:10px; top:0; height:46px; width:38px; display:grid; place-items:center; background:none; border:0; color:var(--faint); }
.forgot{ text-align:right; margin:-8px 0 18px; }
.forgot a{ font-size:13px; font-weight:700; color:var(--kirmizi); }
.checkrow{ display:flex; align-items:flex-start; gap:9px; font-size:13.5px; color:var(--muted); line-height:1.4; margin-bottom:18px; }
.checkrow input{ width:18px; height:18px; accent-color:var(--kirmizi); margin-top:1px; flex-shrink:0; }
.checkrow a{ color:var(--kirmizi); font-weight:700; }
@media (max-width:860px){ .auth-wrap{ grid-template-columns:1fr; } .auth-side{ display:none; } }

/* ---------- İLAN VER (sihirbaz) ---------- */
.wizard{ display:grid; grid-template-columns:240px 1fr; gap:var(--s6); align-items:start; }
.steps{ position:sticky; top:90px; display:flex; flex-direction:column; gap:4px; }
.steps .step{ display:flex; align-items:center; gap:13px; padding:13px 14px; border-radius:var(--r-md); position:relative; }
.steps .step .num{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:14px;
  background:var(--surface); border:1.5px solid var(--line-strong); color:var(--muted); flex-shrink:0; transition:all var(--dur); }
.steps .step .lbl b{ display:block; font-size:14px; color:var(--ink); }
.steps .step .lbl span{ font-size:12px; color:var(--faint); }
.steps .step.on{ background:var(--surface); box-shadow:var(--sh-1); }
.steps .step.on .num{ background:var(--kirmizi); border-color:var(--kirmizi); color:#fff; }
.steps .step.done .num{ background:var(--basari); border-color:var(--basari); color:#fff; }
.steps .step.done .num svg{ width:16px; height:16px; }
.wizard-panel{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px 30px; box-shadow:var(--sh-1); }
.wizard-panel > h2{ font-size:21px; margin-bottom:4px; }
.wizard-panel > .sub{ color:var(--muted); font-size:14px; margin-bottom:24px; }
.wizard-actions{ display:flex; justify-content:space-between; gap:12px; margin-top:28px; padding-top:22px; border-top:1px solid var(--line); }

/* Kategori seçici (büyük tile) */
.cat-pick{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.cat-pick label{ cursor:pointer; }
.cat-pick input{ position:absolute; opacity:0; }
.cat-pick .cp{ border:1.5px solid var(--line-strong); border-radius:var(--r-md); padding:18px 14px; display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; transition:all var(--dur); }
.cat-pick label:hover .cp{ border-color:var(--ink); }
.cat-pick input:checked + .cp{ border-color:var(--kirmizi); background:var(--kirmizi-soft); box-shadow:0 0 0 3px var(--kirmizi-soft); }
.cat-pick .cp .ci{ width:46px; height:46px; border-radius:11px; background:var(--surface-2); display:grid; place-items:center; color:var(--kirmizi); }
.cat-pick input:checked + .cp .ci{ background:var(--kirmizi); color:#fff; }
.cat-pick .cp .ci svg{ width:24px; height:24px; }
.cat-pick .cp b{ font-size:14px; }

/* Foto yükleme */
.uploader{ border:2px dashed var(--line-strong); border-radius:var(--r-md); padding:34px; text-align:center; background:var(--surface-2); transition:all var(--dur); cursor:pointer; }
.uploader:hover, .uploader.drag{ border-color:var(--kirmizi); background:var(--kirmizi-soft); }
.uploader .ui{ width:58px; height:58px; border-radius:14px; background:var(--surface); box-shadow:var(--sh-1); display:grid; place-items:center; margin:0 auto 14px; color:var(--kirmizi); }
.uploader .ui svg{ width:28px; height:28px; }
.uploader b{ font-size:16px; display:block; }
.uploader span{ color:var(--muted); font-size:13.5px; }
.photo-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:12px; margin-top:18px; }
.photo-grid .pcell{ aspect-ratio:1; border-radius:var(--r-sm); position:relative; overflow:hidden; }
.photo-grid .pcell .del{ position:absolute; top:6px; right:6px; width:26px; height:26px; border-radius:50%; background:rgba(15,11,9,.7); border:0; color:#fff; display:grid; place-items:center; }
.photo-grid .pcell .del svg{ width:13px; height:13px; }
.photo-grid .pcell .cover-tag{ position:absolute; bottom:0; left:0; right:0; background:var(--kirmizi); color:#fff; font-size:10.5px; font-weight:800; text-align:center; padding:3px; letter-spacing:.04em; }
.photo-grid .pcell .ph-ic svg{ width:22px; height:22px; }

/* Önizleme kartı (sticky) */
.preview-card{ position:sticky; top:90px; }
.preview-tag{ font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; }

/* Başarı ekranı */
.success-screen{ text-align:center; max-width:480px; margin:0 auto; padding:48px 24px; }
.success-screen .si{ width:88px; height:88px; border-radius:50%; background:var(--basari-bg); display:grid; place-items:center; margin:0 auto 24px; color:var(--basari); }
.success-screen .si svg{ width:44px; height:44px; }
.success-screen h1{ font-size:28px; margin-bottom:10px; }
.success-screen p{ color:var(--muted); font-size:15px; line-height:1.6; }
.success-screen .sacts{ display:flex; gap:12px; justify-content:center; margin-top:28px; }

@media (max-width:860px){ .wizard{ grid-template-columns:1fr; } .steps{ position:static; flex-direction:row; overflow-x:auto; } .steps .step .lbl{ display:none; } .cat-pick{ grid-template-columns:repeat(2,1fr); } .photo-grid{ grid-template-columns:repeat(3,1fr); } }

/* ---------- 20. RESPONSIVE ---------- */
@media (max-width:1024px){
  .card-grid{ grid-template-columns:repeat(3,1fr); }
  .cat-grid{ grid-template-columns:repeat(4,1fr); }
  .footer .cols{ grid-template-columns:1fr 1fr; gap:var(--s5); }
  h1{ font-size:28px; }
}
@media (max-width:720px){
  .wrap{ padding-inline:var(--s4); }
  .header .wrap{ height:62px; gap:var(--s3); }
  .searchbar{ display:none; }
  .brand .bt span{ display:none; }
  .card-grid{ grid-template-columns:repeat(2,1fr); gap:var(--s3); }
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
  .section{ padding-block:var(--s6); }
  .footer .cols{ grid-template-columns:1fr 1fr; }
  .ilan .price{ font-size:17px; }
  h1{ font-size:24px; } h2{ font-size:21px; }
  .field-row{ grid-template-columns:1fr; }
}
@media (max-width:460px){
  .card-grid{ grid-template-columns:1fr 1fr; }
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
}
