/* ========================================
   HAK MÜHENDİSLİK - Ana Stil Dosyası
   ======================================== */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ========================================
   CSS DEĞİŞKENLERİ (Custom Properties)
   ======================================== */
:root {
  --renk-antrasit: #2C2C2A;
  --renk-bronz: #9A7B4F;
  --renk-bronz-acik: #B8956A;
  --renk-bronz-koyu: #7D6340;
  --renk-arka-plan: #F5F5F3;
  --renk-beyaz: #FFFFFF;
  --renk-gri-acik: #E8E8E6;
  --renk-gri-orta: #999999;
  --renk-metin: #2C2C2A;
  --renk-metin-acik: #666666;

  --font-baslik: 'Inter', sans-serif;
  --font-govde: 'DM Sans', sans-serif;

  --gecis: all 0.3s ease;
  --golge: 0 4px 24px rgba(0,0,0,0.08);
  --golge-hover: 0 8px 40px rgba(0,0,0,0.14);
  --kenar-radius: 4px;
  --kenar-radius-buyuk: 8px;

  --container-genislik: 1200px;
  --header-yukseklik: 96px;
}

/* ========================================
   RESET & TEMEL
   ======================================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-govde);
  color: var(--renk-metin);
  background-color: var(--renk-beyaz);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
  transition: var(--gecis);
}

ul {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: var(--font-govde);
}

/* ========================================
   YARDIMCI SINIFLAR
   ======================================== */
.container {
  max-width: var(--container-genislik);
  margin: 0 auto;
  padding: 0 24px;
}

.section-padding {
  padding: 88px 0;
}

.section-padding-sm {
  padding: 60px 0;
}

/* Bölüm başlık etiketi */
.section-etiket {
  display: inline-block;
  font-family: var(--font-baslik);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--renk-bronz);
  margin-bottom: 12px;
}

.section-baslik {
  font-family: var(--font-baslik);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  color: var(--renk-antrasit);
  line-height: 1.2;
  margin-bottom: 16px;
}

.section-aciklama {
  font-size: 16px;
  color: var(--renk-metin-acik);
  max-width: 560px;
  line-height: 1.7;
}

.text-center {
  text-align: center;
}

.text-center .section-aciklama {
  margin: 0 auto;
}

/* ========================================
   BUTONLAR
   ======================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-baslik);
  font-size: 14px;
  font-weight: 600;
  padding: 14px 28px;
  border-radius: var(--kenar-radius);
  transition: var(--gecis);
  letter-spacing: 0.3px;
}

.btn-bronz {
  background: var(--renk-bronz);
  color: var(--renk-beyaz);
}

.btn-bronz:hover {
  background: var(--renk-bronz-koyu);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(154, 123, 79, 0.35);
}

.btn-outline {
  border: 2px solid var(--renk-bronz);
  color: var(--renk-bronz);
}

.btn-outline:hover {
  background: var(--renk-bronz);
  color: var(--renk-beyaz);
}

.btn-beyaz {
  background: var(--renk-beyaz);
  color: var(--renk-antrasit);
}

.btn-beyaz:hover {
  background: var(--renk-arka-plan);
}

.btn-outline-beyaz {
  border: 2px solid rgba(255,255,255,0.5);
  color: var(--renk-beyaz);
}

.btn-outline-beyaz:hover {
  border-color: var(--renk-beyaz);
  background: rgba(255,255,255,0.1);
}

/* ========================================
   HEADER - Stiller partials/header.html
   içindeki <style> bloğunda tanımlıdır.
   ======================================== */

/* ========================================
   FOOTER
   ======================================== */
/* ========================================
   FOOTER ANA
   ======================================== */
.site-footer {
  background: var(--renk-antrasit);
  color: rgba(255,255,255,0.75);
}

.footer-ana {
  padding-top: 64px;
}

.footer-ust {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.footer-logo img {
  height: 90px;
  width: auto;
  margin-bottom: 16px;
  filter: brightness(0) invert(1);
}

.footer-logo-metin {
  font-family: var(--font-baslik);
  font-size: 20px;
  font-weight: 700;
  color: var(--renk-beyaz);
  margin-bottom: 4px;
}

.footer-logo-metin span {
  display: block;
  font-size: 11px;
  font-weight: 400;
  color: var(--renk-bronz);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.footer-aciklama {
  font-size: 14px;
  line-height: 1.7;
  margin-top: 12px;
  color: rgba(255,255,255,0.6);
}

.footer-sosyal {
  display: flex;
  gap: 12px;
  margin-top: 20px;
}

.footer-sosyal a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
  font-size: 16px;
  transition: var(--gecis);
}

.footer-sosyal a:hover {
  background: var(--renk-bronz);
  border-color: var(--renk-bronz);
  color: var(--renk-beyaz);
}

.footer-baslik {
  font-family: var(--font-baslik);
  font-size: 13px;
  font-weight: 600;
  color: var(--renk-beyaz);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.footer-baslik::after {
  content: '';
  display: block;
  width: 28px;
  height: 2px;
  background: var(--renk-bronz);
  margin-top: 8px;
}

.footer-linkler li {
  margin-bottom: 10px;
}

.footer-linkler a {
  font-size: 14px;
  color: rgba(255,255,255,0.6);
  transition: var(--gecis);
  display: flex;
  align-items: center;
  gap: 6px;
}

.footer-linkler a:hover {
  color: var(--renk-bronz);
  padding-left: 4px;
}

.footer-linkler a::before {
  content: '';
  width: 4px;
  height: 4px;
  background: var(--renk-bronz);
  border-radius: 50%;
  flex-shrink: 0;
}

.footer-iletisim-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
  font-size: 14px;
  color: rgba(255,255,255,0.6);
}

.footer-iletisim-item i {
  color: var(--renk-bronz);
  font-size: 16px;
  margin-top: 2px;
  flex-shrink: 0;
  width: 18px;
}

.footer-iletisim-item a {
  color: rgba(255,255,255,0.6);
}

.footer-iletisim-item a:hover {
  color: var(--renk-bronz);
}

.footer-alt {
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer-alt-metin {
  font-size: 13px;
  color: rgba(255,255,255,0.4);
}

.footer-alt-metin span {
  color: var(--renk-bronz);
}

/* Hero CSS index.html içinde tanımlıdır */

/* ========================================
   HİZMETLER ÖNİZLEME (Anasayfa)
   ======================================== */
.hizmetler-onizleme {
  background: var(--renk-antrasit);
  padding: 88px 0;
}

.hizmetler-onizleme .section-baslik {
  color: var(--renk-beyaz);
}

.hizmetler-onizleme .section-aciklama {
  color: rgba(255,255,255,0.6);
}

.hizmetler-onizleme-ust {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 48px;
  gap: 24px;
}

.hizmetler-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

/* Hizmet kartı - anasayfa versiyonu */
.hizmet-kart {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
}

.hizmet-kart img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.hizmet-kart-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(44,44,42,0.9) 0%, rgba(44,44,42,0.2) 50%, transparent 100%);
  transition: var(--gecis);
}

.hizmet-kart:hover img {
  transform: scale(1.05);
}

.hizmet-kart:hover .hizmet-kart-overlay {
  background: linear-gradient(to top, rgba(44,44,42,0.95) 0%, rgba(44,44,42,0.5) 60%, rgba(44,44,42,0.1) 100%);
}

.hizmet-kart-icerik {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px;
}

.hizmet-kart-baslik {
  font-family: var(--font-baslik);
  font-size: 16px;
  font-weight: 600;
  color: var(--renk-beyaz);
  margin-bottom: 6px;
  line-height: 1.3;
}

.hizmet-kart-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--renk-bronz);
  letter-spacing: 1px;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(8px);
  transition: var(--gecis);
}

.hizmet-kart:hover .hizmet-kart-link {
  opacity: 1;
  transform: translateY(0);
}

/* ========================================
   NEDEN BİZ (Anasayfa)
   ======================================== */
.neden-biz {
  background: var(--renk-arka-plan);
  padding: 88px 0;
}

.neden-biz-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.neden-biz-gorsel {
  position: relative;
}

.neden-biz-gorsel img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  border-radius: var(--kenar-radius-buyuk);
}

.neden-biz-gorsel-badge {
  position: absolute;
  bottom: 24px;
  left: -24px;
  background: var(--renk-bronz);
  color: var(--renk-beyaz);
  padding: 20px 24px;
  border-radius: var(--kenar-radius);
  font-family: var(--font-baslik);
}

.neden-biz-gorsel-badge .rakam {
  font-size: 36px;
  font-weight: 800;
  line-height: 1;
}

.neden-biz-gorsel-badge .label {
  font-size: 13px;
  opacity: 0.85;
  margin-top: 4px;
}

.neden-biz-ozellikler {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-top: 40px;
}

.ozellik-kart {
  padding: 24px;
  background: var(--renk-beyaz);
  border-radius: var(--kenar-radius);
  border-left: 3px solid var(--renk-bronz);
  transition: var(--gecis);
}

.ozellik-kart:hover {
  box-shadow: var(--golge);
  transform: translateY(-2px);
}

.ozellik-ikon {
  width: 44px;
  height: 44px;
  background: rgba(154, 123, 79, 0.1);
  border-radius: var(--kenar-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--renk-bronz);
  font-size: 20px;
  margin-bottom: 12px;
}

.ozellik-baslik {
  font-family: var(--font-baslik);
  font-size: 15px;
  font-weight: 600;
  color: var(--renk-antrasit);
  margin-bottom: 6px;
}

.ozellik-metin {
  font-size: 13px;
  color: var(--renk-metin-acik);
  line-height: 1.6;
}

/* ========================================
   SAYAÇ BÖLÜMÜ
   ======================================== */
.sayac-bolumu {
  background: var(--renk-antrasit);
  padding: 72px 0;
}

.sayac-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.sayac-item {
  text-align: center;
  padding: 32px;
  border-right: 1px solid rgba(255,255,255,0.1);
}

.sayac-item:last-child {
  border-right: none;
}

.sayac-rakam {
  font-family: var(--font-baslik);
  font-size: 52px;
  font-weight: 800;
  color: var(--renk-bronz);
  line-height: 1;
  margin-bottom: 8px;
}

.sayac-label {
  font-size: 14px;
  color: rgba(255,255,255,0.6);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ========================================
   CTA BÖLÜMÜ
   ======================================== */
.cta-bolumu {
  background: var(--renk-bronz);
  padding: 72px 0;
}

.cta-ici {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.cta-baslik {
  font-family: var(--font-baslik);
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 700;
  color: var(--renk-beyaz);
  line-height: 1.2;
}

.cta-aciklama {
  font-size: 16px;
  color: rgba(255,255,255,0.8);
  margin-top: 8px;
  max-width: 500px;
}

/* ========================================
   HİZMETLER SAYFASI KARTLARI
   ======================================== */
.hizmetler-hero {
  background: var(--renk-antrasit);
  padding: 80px 0 60px;
  text-align: center;
}

.hizmetler-hero .section-baslik {
  color: var(--renk-beyaz);
}

.hizmetler-hero p {
  color: rgba(255,255,255,0.65);
  font-size: 17px;
  max-width: 540px;
  margin: 0 auto;
}

.hizmetler-sayfa-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  padding: 80px 0;
}

.hizmet-sayfa-kart {
  background: var(--renk-beyaz);
  border-radius: var(--kenar-radius-buyuk);
  overflow: hidden;
  box-shadow: var(--golge);
  transition: var(--gecis);
}

.hizmet-sayfa-kart:hover {
  box-shadow: var(--golge-hover);
  transform: translateY(-4px);
}

.hizmet-sayfa-kart:hover .hizmet-sayfa-kart-gorsel {
  border-bottom-color: var(--renk-bronz);
}

.hizmet-sayfa-kart-gorsel {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
  border-bottom: 3px solid transparent;
  transition: var(--gecis);
}

.hizmet-sayfa-kart-gorsel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.hizmet-sayfa-kart:hover .hizmet-sayfa-kart-gorsel img {
  transform: scale(1.04);
}

.hizmet-sayfa-kart-icerik {
  padding: 24px;
}

.hizmet-sayfa-kart-baslik {
  font-family: var(--font-baslik);
  font-size: 17px;
  font-weight: 700;
  color: var(--renk-antrasit);
  margin-bottom: 10px;
}

.hizmet-sayfa-kart-metin {
  font-size: 14px;
  color: var(--renk-metin-acik);
  line-height: 1.6;
  margin-bottom: 20px;
}

.hizmet-sayfa-kart-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-baslik);
  font-size: 13px;
  font-weight: 600;
  color: var(--renk-bronz);
  background: transparent;
  border: 1.5px solid var(--renk-bronz);
  border-radius: 8px;
  padding: 9px 18px;
  letter-spacing: 0.3px;
  transition: var(--gecis);
}

.hizmet-sayfa-kart-btn:hover {
  background: var(--renk-bronz);
  color: #fff;
  gap: 12px;
  box-shadow: 0 4px 14px rgba(166, 124, 82, 0.25);
}

/* ========================================
   HAKKIMIZDA SAYFASI
   ======================================== */
.hakkimizda-hero {
  background: var(--renk-antrasit);
  padding: 80px 0 60px;
  text-align: center;
}

.hakkimizda-hero .section-baslik { color: var(--renk-beyaz); }
.hakkimizda-hero p { color: rgba(255,255,255,0.65); font-size: 17px; max-width: 540px; margin: 0 auto; }

.hikaye-bolumu {
  padding: 88px 0;
}

.hikaye-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.hikaye-gorseller {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
}

.hikaye-gorseller img {
  border-radius: var(--kenar-radius);
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.hikaye-gorseller img:first-child {
  grid-column: span 2;
  height: 280px;
}

.degerler-bolumu {
  background: var(--renk-arka-plan);
  padding: 88px 0;
}

.degerler-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}

.deger-kart {
  background: var(--renk-beyaz);
  padding: 36px 28px;
  border-radius: var(--kenar-radius-buyuk);
  text-align: center;
  transition: var(--gecis);
  border-top: 3px solid transparent;
}

.deger-kart:hover {
  border-top-color: var(--renk-bronz);
  box-shadow: var(--golge);
  transform: translateY(-3px);
}

.deger-ikon {
  width: 64px;
  height: 64px;
  background: rgba(154,123,79,0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--renk-bronz);
  font-size: 26px;
  margin: 0 auto 20px;
}

.deger-baslik {
  font-family: var(--font-baslik);
  font-size: 17px;
  font-weight: 700;
  color: var(--renk-antrasit);
  margin-bottom: 10px;
}

.deger-metin {
  font-size: 14px;
  color: var(--renk-metin-acik);
  line-height: 1.6;
}

/* ========================================
   GALERİ SAYFASI
   ======================================== */
.galeri-hero {
  background: var(--renk-antrasit);
  padding: 80px 0 60px;
  text-align: center;
}

.galeri-hero .section-baslik { color: var(--renk-beyaz); }
.galeri-hero p { color: rgba(255,255,255,0.65); font-size: 17px; max-width: 540px; margin: 0 auto; }

.galeri-filtre {
  padding: 40px 0 0;
  text-align: center;
}

.filtre-butonlar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}

.filtre-btn {
  padding: 9px 20px;
  font-family: var(--font-baslik);
  font-size: 13px;
  font-weight: 500;
  color: var(--renk-metin-acik);
  border: 1px solid var(--renk-gri-acik);
  border-radius: 100px;
  transition: var(--gecis);
  cursor: pointer;
  background: var(--renk-beyaz);
}

.filtre-btn:hover,
.filtre-btn.aktif {
  background: var(--renk-bronz);
  color: var(--renk-beyaz);
  border-color: var(--renk-bronz);
}

.galeri-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 40px 0 80px;
}

.galeri-item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
  cursor: pointer;
}

.galeri-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.galeri-item:hover img {
  transform: scale(1.06);
}

.galeri-item-overlay {
  position: absolute;
  inset: 0;
  background: rgba(44,44,42,0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--gecis);
}

.galeri-item:hover .galeri-item-overlay {
  background: rgba(44,44,42,0.55);
}

.galeri-item-overlay i {
  color: var(--renk-beyaz);
  font-size: 28px;
  opacity: 0;
  transform: scale(0.8);
  transition: var(--gecis);
}

.galeri-item:hover .galeri-item-overlay i {
  opacity: 1;
  transform: scale(1);
}

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

.lightbox.aktif {
  display: flex;
}

.lightbox-ici {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
}

.lightbox-ici img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: var(--kenar-radius);
}

.lightbox-kapat {
  position: absolute;
  top: -48px;
  right: 0;
  color: var(--renk-beyaz);
  font-size: 32px;
  cursor: pointer;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-onceki,
.lightbox-sonraki {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  color: var(--renk-beyaz);
  font-size: 24px;
  cursor: pointer;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.1);
  border-radius: 50%;
  transition: var(--gecis);
}

.lightbox-onceki { left: 20px; }
.lightbox-sonraki { right: 20px; }

.lightbox-onceki:hover,
.lightbox-sonraki:hover {
  background: var(--renk-bronz);
}

/* ========================================
   İLETİŞİM SAYFASI
   ======================================== */
.iletisim-hero {
  background: var(--renk-antrasit);
  padding: 80px 0 60px;
  text-align: center;
}

.iletisim-hero .section-baslik { color: var(--renk-beyaz); }
.iletisim-hero p { color: rgba(255,255,255,0.65); font-size: 17px; max-width: 540px; margin: 0 auto; }

.iletisim-bolumu {
  padding: 80px 0;
}

.iletisim-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 64px;
}

.iletisim-bilgi-baslik {
  font-family: var(--font-baslik);
  font-size: 24px;
  font-weight: 700;
  color: var(--renk-antrasit);
  margin-bottom: 8px;
}

.iletisim-bilgi-altbaslik {
  font-size: 15px;
  color: var(--renk-metin-acik);
  margin-bottom: 36px;
  line-height: 1.6;
}

.iletisim-bilgi-item {
  display: flex;
  gap: 16px;
  margin-bottom: 28px;
  align-items: flex-start;
}

.iletisim-bilgi-ikon {
  width: 48px;
  height: 48px;
  background: rgba(154,123,79,0.1);
  border-radius: var(--kenar-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--renk-bronz);
  font-size: 20px;
  flex-shrink: 0;
}

.iletisim-bilgi-icerik strong {
  display: block;
  font-family: var(--font-baslik);
  font-size: 14px;
  font-weight: 600;
  color: var(--renk-antrasit);
  margin-bottom: 4px;
}

.iletisim-bilgi-icerik span,
.iletisim-bilgi-icerik a {
  font-size: 15px;
  color: var(--renk-metin-acik);
  line-height: 1.5;
}

.iletisim-bilgi-icerik a:hover {
  color: var(--renk-bronz);
}

/* İletişim Formu */
.iletisim-form-wrapper {
  background: var(--renk-arka-plan);
  padding: 40px;
  border-radius: var(--kenar-radius-buyuk);
}

.form-baslik {
  font-family: var(--font-baslik);
  font-size: 22px;
  font-weight: 700;
  color: var(--renk-antrasit);
  margin-bottom: 28px;
}

.form-satir {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.form-grup {
  margin-bottom: 16px;
}

.form-grup label {
  display: block;
  font-family: var(--font-baslik);
  font-size: 13px;
  font-weight: 600;
  color: var(--renk-antrasit);
  margin-bottom: 8px;
  letter-spacing: 0.3px;
}

.form-grup input,
.form-grup textarea,
.form-grup select {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid var(--renk-gri-acik);
  border-radius: var(--kenar-radius);
  font-family: var(--font-govde);
  font-size: 15px;
  color: var(--renk-metin);
  background: var(--renk-beyaz);
  transition: var(--gecis);
  outline: none;
}

.form-grup input:focus,
.form-grup textarea:focus {
  border-color: var(--renk-bronz);
  box-shadow: 0 0 0 3px rgba(154,123,79,0.15);
}

.form-grup textarea {
  resize: vertical;
  min-height: 140px;
}

.form-basari {
  display: none;
  background: #e8f5e9;
  border: 1px solid #4caf50;
  color: #2e7d32;
  padding: 16px 20px;
  border-radius: var(--kenar-radius);
  margin-top: 16px;
  font-size: 15px;
  align-items: center;
  gap: 10px;
}

.form-basari.goster {
  display: flex;
}

/* Harita */
.harita-bolumu {
  background: var(--renk-arka-plan);
  padding: 0 0 80px;
}

.harita-wrapper {
  border-radius: var(--kenar-radius-buyuk);
  overflow: hidden;
  box-shadow: var(--golge);
}

.harita-wrapper iframe {
  display: block;
  width: 100%;
  height: 420px;
  border: 0;
}

/* ========================================
   SAYFA YÜKLEME ANİMASYONU
   ======================================== */
.sayfa-fade-in {
  animation: sayfaGiris 0.4s ease both;
}

@keyframes sayfaGiris {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.gorunur {
  opacity: 1;
  transform: translateY(0);
}

/* ========================================
   RESPONSİVE — Tablet
   ======================================== */
@media (max-width: 1024px) {
  .footer-ust {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }

  .hizmetler-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hizmetler-sayfa-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .neden-biz-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .neden-biz-gorsel {
    max-width: 540px;
  }

  .neden-biz-gorsel-badge {
    left: 0;
  }

  .sayac-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sayac-item {
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }

  .sayac-item:nth-child(2n) {
    border-right: none;
  }

  .hikaye-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .degerler-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .galeri-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .iletisim-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

/* ========================================
   RESPONSİVE — Mobil
   ======================================== */
@media (max-width: 768px) {
  :root {
    --header-yukseklik: 80px;
  }

  .section-padding {
    padding: 60px 0;
  }

  /* Header responsive kuralları partials/header.html içindedir */

  .hizmetler-onizleme-ust {
    flex-direction: column;
    align-items: flex-start;
  }

  .hizmetler-grid {
    grid-template-columns: 1fr;
  }

  .neden-biz-ozellikler {
    grid-template-columns: 1fr;
  }

  .sayac-grid {
    grid-template-columns: 1fr 1fr;
  }

  .cta-ici {
    flex-direction: column;
    text-align: center;
  }

  .hizmetler-sayfa-grid {
    grid-template-columns: 1fr;
  }

  .hikaye-gorseller img {
    height: 160px;
  }

  .hikaye-gorseller img:first-child {
    height: 220px;
  }

  .degerler-grid {
    grid-template-columns: 1fr;
  }

  .galeri-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .form-satir {
    grid-template-columns: 1fr;
  }

  .iletisim-form-wrapper {
    padding: 24px;
  }

  .footer-ust {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .footer-alt {
    flex-direction: column;
    text-align: center;
  }

  .hizmetler-onizleme {
    padding: 60px 0;
  }

  .hizmetler-hero,
  .hakkimizda-hero,
  .galeri-hero,
  .iletisim-hero {
    padding-top: 120px;
  }
}

@media (max-width: 480px) {
  .galeri-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2px;
  }

  .filtre-butonlar {
    gap: 8px;
  }

  .filtre-btn {
    font-size: 12px;
    padding: 7px 14px;
  }
}