/* Basit tema değişkenleri (kırmızı) */
:root{
  --pf-border:#e5e7eb;
  --pf-bg:#ffffff;
  --pf-soft:#f7f7f9;
  --pf-accent:#e11d48;  /* kırmızı */
  --pf-text:#0f172a;
  --pf-muted:#6b7280;
  --pf-shadow:0 12px 28px rgba(0,0,0,.08);
  --pf-radius:16px;
}

.portfolio-page{ background:#fff; color:var(--pf-text); }
.portfolio-wrap{ max-width:min(1200px,94vw); margin:0 auto; padding:0 12px; }

/* Başlık */
.page-head{ padding:16px 0 10px; }
.portfolio-headline{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.portfolio-headline h1{ margin:0; font-weight:800; font-size:clamp(22px,2.6vw,30px); }
.portfolio-count{ font-weight:700; color:#111; }

/* Üst kontrol barı */
.pf-controls{ display:flex; align-items:center; gap:12px; margin:8px 0 10px; }
.pf-controls .spacer{ flex:1 1 auto; }
.pf-controls .mini-count{ color:#334155; font-weight:600; }

/* Toggle butonu */
.filter-toggle{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px; border-radius:12px; border:1px solid var(--pf-border);
  background:#0b1220; color:#fff; cursor:pointer; font-weight:800;
}
.filter-toggle svg{ width:18px; height:18px; fill:none; stroke:#fff; stroke-width:2; }

/* Filtre paneli */
.filter-bar{
  border:1px solid var(--pf-border);
  border-radius:var(--pf-radius);
  background:var(--pf-bg);
  box-shadow:var(--pf-shadow);
  overflow:hidden;
  transition:max-height .28s ease, padding .2s ease, border-width .2s ease, margin .2s ease;
}
.filter-inner{ padding:12px; }
.filter-row{ display:grid; gap:10px; grid-template-columns:repeat(5, minmax(0,1fr)); }
.field{ display:flex; flex-direction:column; gap:6px; }
.field label{ font-weight:700; font-size:13px; color:#111; }
.field input,.field select{ border:1px solid var(--pf-border); border-radius:12px; padding:10px 12px; background:#fff; }

/* Butonlar */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 16px; border-radius:12px; font-weight:800;
  background:var(--pf-accent); color:#fff; border:1px solid #be123c;
  box-shadow:0 8px 18px rgba(225,29,72,.22); cursor:pointer;
}
.btn.ghost{ background:var(--pf-soft); color:#0f172a; border:1px solid var(--pf-border); box-shadow:none; }
.filter-actions{ display:flex; gap:10px; margin-top:10px; }

/* Grid */
.portfolio-grid{
  list-style:none; margin:14px 0 16px; padding:0;
  display:grid; gap:14px;
  grid-template-columns:repeat(3, minmax(0,1fr));
}

/* ==== KART ===== */
.pf-card{
  position:relative; border:1px solid var(--pf-border); border-radius:18px; overflow:hidden;
  background:#fff; box-shadow:0 12px 28px rgba(0,0,0,.06);
  transition:transform .18s ease, box-shadow .18s ease;
}
.pf-card:hover{ transform:translateY(-2px); box-shadow:0 18px 36px rgba(0,0,0,.10); }

/* Görsel */
.pf-card .card-fig{ position:relative; aspect-ratio:16/10; background:#f2f4f7; overflow:hidden; }
.pf-card .card-fig img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s ease; }
.pf-card:hover .card-fig img{ transform:scale(1.03); }
.pf-card .card-fig::after{
  content:""; position:absolute; inset:auto 0 0 0; height:32%;
  background:linear-gradient(180deg,rgba(0,0,0,0) 0%, rgba(0,0,0,.12) 70%, rgba(0,0,0,.18) 100%);
  pointer-events:none;
}

/* Rozet */
.badge{
  position:absolute; left:12px; top:12px; z-index:4;
  display:inline-flex; align-items:center; gap:8px;
  height:28px; padding:0 12px;
  border-radius:999px; font-weight:800; font-size:12px; letter-spacing:.2px;
  color:#fff; border:1px solid rgba(0,0,0,.12);
  box-shadow:0 8px 18px rgba(0,0,0,.12); user-select:none;
  backdrop-filter: blur(6px);
}
.badge.satilik{ background:linear-gradient(180deg,#f43f5e,#e11d48); }
.badge.kiralik{ background:linear-gradient(180deg,#fecaca,#fb7185); color:#7f1d1d; }

/* Gövde */
.pf-card .card-body{ padding:16px 18px 18px; display:grid; gap:6px; }
.pf-card .card-title{ margin:0; font-weight:900; font-size:clamp(18px,2.2vw,24px); color:#0f172a; }

.pf-card .card-meta{
  display:flex; flex-wrap:wrap; align-items:center; gap:10px;
  color:#475569; font-size:13px; font-weight:600;
}
.pf-card .price{ font-weight:900; color:#e11d48; } /* kırmızı fiyat */
.pf-card .dot{ width:4px; height:4px; border-radius:50%; background:#cbd5e1; display:inline-block; }

/* Kartın tamamı tıklanabilir */
.pf-card .card-link{ position:absolute; inset:0; z-index:5; }

/* Sayfalama */
.pager{ display:flex; align-items:center; justify-content:center; gap:10px; margin:8px 0 20px; }
.pager .info{ font-weight:700; }

/* RESPONSIVE */
@media (max-width:1023px){
  .filter-toggle{ display:inline-flex; }
  .filter-bar{ max-height:0; padding:0; border-width:0; margin:0 0 8px; }
  .filter-bar[data-open="true"]{ max-height:900px; border-width:1px; margin:0 0 10px; }
  .filter-bar[data-open="true"] .filter-inner{ padding:12px; }
  .filter-bar:not([data-open="true"]) .filter-inner{ padding:0; }

  .filter-row{ grid-template-columns:1fr 1fr; }
  .portfolio-grid{ grid-template-columns:1fr; }
}
@media (min-width:640px) and (max-width:1023px){
  .portfolio-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (min-width:1024px){
  .filter-toggle{ display:none; }
  .filter-bar{ max-height:none; padding:0; border-width:1px; margin:0 0 12px; }
  .filter-inner{ padding:12px; }
  .filter-row{ grid-template-columns:repeat(5, minmax(0,1fr)); }
  .portfolio-grid{ grid-template-columns:repeat(3, minmax(0,1fr)); }
}
