/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: "Roboto", sans-serif; color: #54595f; background: #fff; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ── Header ── */
.site-header {
  position: relative; /* Bunu kontrol edin */
  padding: 20px 0;
  border-bottom: 1px solid #eee;
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.logo img { width: 240px; }

.nav { display: flex; gap: 24px; }
.nav-item {
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #7a7a7a;
  transition: color .2s;
}
.nav-item:hover, .nav-item.active { color: #54595f; }

.nav-toggle { display: none; background: none; border: none; font-size: 24px; cursor: pointer; }
@media (max-width: 767px) {
  .nav { 
    display: none; 
    flex-direction: column; 
    position: absolute; 
    /* top: 64px yerine %100 yaparsak header yüksekliği değişse de tam altına yapışır */
    top: 100%; 
    left: 0; 
    right: 0; 
    background: #fff; 
    padding: 16px 24px; 
    border-bottom: 1px solid #eee; 
    /* Proje kartlarının (z-index: 2) önünde kalması için değeri artırıyoruz */
    z-index: 9999; 
    /* Mobilde daha şık durması için hafif bir gölge */
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  }
  
  /* .nav.open kuralına !important eklemek, display çakışmalarını garantili çözer */
  .nav.open { 
    display: flex !important; 
  }
  
  .nav-toggle { 
    display: block; 
    /* Burger ikonunun boyutunu ve görünümünü netleştirelim */
    font-size: 28px;
    background: none;
    border: none;
    cursor: pointer;
  }
}

.nav-item.active {
  color: #54595f; /* Aktif renk */
  text-decoration: none; /* Standart alt çizgiyi kaldırıyoruz */
  border-bottom: 1px solid #54595f; /* Daha ince ve zarif bir çizgi */
  padding-bottom: 4px; /* Yazı ile çizgi arasındaki "nefes alma" boşluğu */
  display: inline-block; /* Boşluğun doğru çalışması için */
}

/* ── Footer ── */
.site-footer {
  padding: 16px 0;
  border-top: 1px solid #eee;
  color: #7a7a7a;
}
.site-footer .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-icons { display: flex; gap: 14px; }
.footer-icons a { display: flex; align-items: center; }
.footer-icons svg { width: 24px; height: 24px; fill: #7a7a7a; transition: fill .2s; }
.footer-icons a:hover svg { fill: #54595f; }

/* ── Filters ── */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: 60px 0 40px;
  justify-content: center; /* Butonları yatayda ortalar */
  align-items: center;    /* Butonları dikeyde (ihtiyaç olursa) hizalar */
}
.filter-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  color: #7a7a7a;
  padding: 6px 0;
  transition: color .2s;
}
.filter-btn + .filter-btn::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 12px;
  background: #ccc;
  margin: 0 12px;
  vertical-align: middle;
}
.filter-btn.active, .filter-btn:hover { color: #000; }

@media (max-width: 767px) {
  .filters {
    gap: 10px; /* Mobilde butonlar arasına biraz mesafe ekler */
  }
  .filter-btn + .filter-btn::before {
    display: none; /* Mobildeki dikey çizgileri kaldırarak daha temiz bir görünüm sağlar */
  }
}

/* ── Proje Grid ── */
.proje-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 11px;
  margin-bottom: 80px;
}

@media (max-width: 1024px) { .proje-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .proje-grid { grid-template-columns: 1fr; } }


/* -- Proje Kartı Kapsayıcı -- */
.proje-kart {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: #000;
  transition: opacity 0.4s ease, transform 0.4s ease, filter 0.4s ease;
}

.proje-kart img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 1; /* Normalde resim tam net */
  transition: opacity 0.3s ease, transform 0.5s ease;
}

/* -- Karartma Katmanı (Overlay) -- */
.proje-kart-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.75); /* İstediğin o %75 siyahlık */
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* STANDARTTA GİZLİ OLMALI */
  opacity: 0; 
  visibility: hidden;
  
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 2;
}

.proje-kart-overlay span {
  color: #fff;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  padding: 0 16px;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ── HOVER DURUMU (Sihir Burası) ── */

/* 1. Üzerine gelince resim biraz şeffaflaşsın ki arkadaki siyahlık sızsın */
.proje-kart:hover img {
  opacity: 0.6; 
  transform: scale(1.05);
}

/* 2. Üzerine gelince overlay ve yazı görünür olsun */
.proje-kart:hover .proje-kart-overlay {
  opacity: 0.6;
  visibility: visible;
}

/* ── Proje Detay ── */
.proje-detay { padding-top: 40px; padding-bottom: 80px; }

.proje-meta-ust .kategori-etiket {
  font-size: 24px;
  font-weight: 400;
  color: #54595f;
}
.proje-meta-ust hr { border: none; border-top: 1px solid #000; margin: 16px 0; }

.proje-icerik {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
}
@media (max-width: 767px) {
  .proje-icerik { grid-template-columns: 1fr; padding: 0 16px; }
}

.proje-kapak {
  width: 100%;
  height: 240px;
  object-fit: cover;
  margin-bottom: 16px;
}
.proje-icerik h1 {
  font-size: 28px;
  font-weight: 600;
  color: #54595f;
  margin-bottom: 12px;
}
.proje-meta p { font-size: 18px; color: #54595f; margin-top: 4px; }

.proje-galeri {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
@media (max-width: 767px) { .proje-galeri { grid-template-columns: 1fr; } }

.proje-galeri img {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  cursor: pointer;
  transition: opacity .2s;
}
.proje-galeri img:hover { opacity: .85; }

/* ── Lightbox ── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.9);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
.lightbox.active { display: flex; }

#lb-img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
}

.lb-kapat {
  position: absolute;
  top: 20px; right: 24px;
  background: none; border: none;
  color: #fff; font-size: 28px;
  cursor: pointer; line-height: 1;
}
.lb-prev, .lb-next {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  background: none; border: none;
  color: #fff; font-size: 56px;
  cursor: pointer; line-height: 1;
  padding: 0 16px;
  user-select: none;
}
.lb-prev { left: 0; }
.lb-next { right: 0; }

/* ── Statik Sayfalar ── */
.sayfa-icerik {
  max-width: 800px;
  margin: 60px auto 80px;
  padding: 0 24px;
  line-height: 1.8;
  font-size: 16px;
  color: #54595f;
}
.sayfa-icerik h1 { font-size: 28px; margin-bottom: 24px; }

/* İletişim Sayfası Özel Stilleri */
.harita-ust {
  margin-top: 40px;
  width: 100%;
}

.iletisim-detaylar {
  margin-top: 40px;
  margin-bottom: 80px;
}

.iletisim-detaylar h1 {
  font-size: 32px;
  font-weight: 600;
  color: #54595f;
  margin-bottom: 20px;
}

.iletisim-detaylar .adres {
  font-size: 16px;
  color: #7a7a7a;
  margin-bottom: 30px;
}

.iletisim-linkler p {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
}

.iletisim-linkler a {
  color: #54595f;
  font-size: 15px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.iletisim-linkler svg { width: 24px; height: 24px; fill: #7a7a7a; transition: fill .2s; }

.iletisim-grid iframe { width: 100%; height: 400px; border: none; filter: saturate(90%); }
.iletisim-bilgi h2 { font-size: 24px; margin-bottom: 16px; }
.iletisim-bilgi p { margin-bottom: 8px; }
.iletisim-bilgi a { color: #54595f; border-bottom: 1px solid #ccc; }



/* ── Referanslar ── */
.referans-liste {
  margin: 40px 0 80px;
  display: flex;
  flex-direction: column;
}
.referans-item {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px 0;
  border-bottom: 1px solid #f0f0f0;
  font-size: 14px;
}
.referans-isim { font-weight: 600; color: #000; }


/* ── Hakkımızda Sayfası ── */
.hakkimizda-ust-bolum {
  display: grid;
  grid-template-columns: 1.2fr 1fr; /* Metin alanını biraz daha geniş tutar */
  gap: 60px;
  margin: 60px 0 80px;
  align-items: start;
}

.hakkimizda-metin {
  font-size: 16px;
  line-height: 1.8;
  color: #54595f;
}

.hakkimizda-metin p {
  margin-bottom: 24px;
}

.hakkimizda-gorsel img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Kurucular Bölümü */
.kurucular-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 40px;
  border-top: 1px solid #f0f0f0;
  padding-top: 30px;
}

.kurucu-item {
  display: flex;
  flex-direction: column;
}

.kurucu-isim {
  font-weight: 500;
  color: #333;
}

.kurucu-unvan {
  font-size: 14px;
  color: #7a7a7a;
}

/* Mobil Uyumluluk */
@media (max-width: 991px) {
  .hakkimizda-ust-bolum {
    grid-template-columns: 1fr; /* Mobilde alt alta geçer */
    gap: 40px;
  }
  .hakkimizda-gorsel {
    order: -1; /* Mobilde görselin metnin üstüne çıkmasını sağlar */
  }
}