/* =========================================
   1. GENEL AYARLAR VE DEĞİŞKENLER
   ========================================= */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

:root {
    --primary-gold: #cba328;
    --primary-gold-dark: #b08d22;
    --text-white: #ffffff;
    --text-off-white: #e6e6e6;
    --bg-dark: #1a1a1a;
    --bg-light: #f9f9f9;
    --font-serif: 'Playfair Display', serif;
    --font-sans: 'Montserrat', sans-serif;
}

body { font-family: var(--font-sans); background-color: var(--bg-dark); overflow-x: hidden; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* =========================================
   2. NAVBAR
   ========================================= */
.navbar { display: flex; justify-content: space-between; align-items: center; padding: 25px 40px; position: absolute; width: 100%; top: 0; z-index: 999; background: transparent; }
.logo { display: flex; align-items: center; gap: 12px; z-index: 1000; }
.logo-icon { font-size: 28px; color: var(--primary-gold); }
.logo-text h1 { font-family: var(--font-serif); font-size: 20px; color: var(--text-white); font-weight: 700; }
.logo-text span { display: block; font-size: 10px; color: var(--text-off-white); }
.nav-links { display: flex; gap: 30px; list-style: none; }
.nav-links li a { text-decoration: none; color: var(--text-white); font-size: 12px; font-weight: 600; }
.btn-contact { background-color: var(--primary-gold); color: #fff !important; padding: 10px 25px; border-radius: 20px; }
.menu-icon { display: none; cursor: pointer; flex-direction: column; gap: 6px; z-index: 1000; }
.bar { width: 28px; height: 2px; background-color: var(--text-white); }

/* =========================================
   3. HERO SECTION
   ========================================= */
.hero { background-image: linear-gradient(rgba(20, 20, 20, 0.75), rgba(20, 20, 20, 0.75)), url('images/backgroun.png'); background-size: cover; background-position: center; height: 100vh; display: flex; align-items: center; justify-content: center; text-align: center; color: var(--text-white); }
.hero-content { max-width: 750px; padding-top: 60px; }
.sub-title { color: var(--primary-gold); font-size: 13px; font-weight: 600; letter-spacing: 2px; margin-bottom: 20px; }
.main-title { font-family: var(--font-serif); font-size: 56px; line-height: 1.15; margin-bottom: 25px; }
.highlight { color: var(--primary-gold); font-style: italic; }
.description { font-size: 16px; color: var(--text-off-white); max-width: 600px; margin: 0 auto 40px auto; }
.buttons { display: flex; justify-content: center; gap: 20px; }
.btn { text-decoration: none; padding: 14px 32px; font-size: 14px; font-weight: 600; border-radius: 2px; }
.btn-primary { background-color: var(--primary-gold); color: #fff; border: 2px solid var(--primary-gold); }
.btn-outline { border: 2px solid rgba(255,255,255,0.5); color: #fff; }

/* =========================================
   4. HAKKIMIZDA & HİZMETLER
   ========================================= */
.about-section { background-color: #fff; padding: 100px 0; }
.about-section .container { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.about-img { width: 100%; border-radius: 4px; position: relative; z-index: 2; box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.section-tag { display: flex; align-items: center; gap: 10px; color: var(--primary-gold); font-size: 12px; font-weight: 700; }
.section-tag .line { width: 40px; height: 2px; background-color: var(--primary-gold); }
.section-title { font-family: var(--font-serif); font-size: 36px; color: #333; margin-bottom: 25px; }
.text-content { font-size: 15px; color: #666; line-height: 1.7; margin-bottom: 20px; }
.features-list { margin-top: 30px; display: flex; flex-direction: column; gap: 25px; }
.feature-item { display: flex; gap: 20px; }
.icon-box { width: 50px; height: 50px; background: #f9f6f0; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.icon-box i { font-size: 22px; color: var(--primary-gold); }

/* Yeni Eklenen Hizmetler Bölümü */
.services-area { background-color: #fcfbf9; border-top: 1px solid #eaeaea; }
.services-area .image-decoration { left: auto; right: -20px; }

/* =========================================
   5. ÜRÜN SLIDER (DÜZELTİLMİŞ)
   ========================================= */
.products-section { background-color: var(--bg-light); padding: 80px 0; }
.products-header { text-align: center; margin-bottom: 40px; }
.sub-text { text-align: center; color: #777; margin-bottom: 30px; font-size: 14px; }
.center-text { text-align: center; }

/* Arama Çubuğu */
.search-wrapper { max-width: 600px; margin: 0 auto 30px; position: relative; }
.search-wrapper input { width: 100%; padding: 15px 20px 15px 50px; border: 1px solid #ddd; border-radius: 50px; outline: none; }
.search-icon { position: absolute; left: 20px; top: 50%; transform: translateY(-50%); color: #999; }

/* Filtre Butonları */
.filter-buttons { display: flex; justify-content: center; gap: 15px; margin-bottom: 30px; flex-wrap: wrap; }
.filter-btn { padding: 10px 25px; border: 1px solid #ccc; border-radius: 25px; background: transparent; cursor: pointer; transition: 0.3s; color: #555; }
.filter-btn:hover, .filter-btn.active { background-color: #595452; color: #fff; border-color: #595452; }

/* Swiper Konteyner */
.swiper { width: 100%; padding: 20px 5px 60px 5px; /* Alt boşluk noktalar için */ }

/* Swiper Slide Kartı */
.swiper-slide {
    height: auto; /* Kartların boyu eşit olsun */
    display: flex;
    justify-content: center;
}

/* Ürün Kartı Tasarımı */
.product-card {
    background-color: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    /* width: 100%;  BURAYI SİLDİK, Swiper kontrol edecek */
    margin: 0; /* Margin Swiper tarafından spaceBetween ile verilir */
    transition: transform 0.3s;
}

.product-card:hover { transform: translateY(-5px); }

.card-image { height: 240px; width: 100%; position: relative; }
.card-image img { width: 100%; height: 100%; object-fit: cover; }
.category-tag { position: absolute; top: 15px; right: 15px; background: #fff; padding: 6px 14px; border-radius: 30px; font-size: 11px; font-weight: 700; }

.card-content { padding: 25px; display: flex; flex-direction: column; flex-grow: 1; }
.card-content h3 { font-family: var(--font-serif); font-size: 20px; margin-bottom: 12px; color: #222; }
.card-content p { font-size: 14px; color: #666; margin-bottom: 25px; }

.card-footer { margin-top: auto; display: flex; justify-content: space-between; border-top: 1px solid #f0f0f0; padding-top: 15px; }
.link-gold { text-decoration: none; color: var(--primary-gold); font-size: 12px; font-weight: 700; }
.hashtag { font-size: 12px; color: #aaa; font-style: italic; }

/* Slider Okları */
.swiper-button-next, .swiper-button-prev { color: var(--primary-gold) !important; background: rgba(255,255,255,0.9); width: 45px; height: 45px; border-radius: 50%; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.swiper-button-next:after, .swiper-button-prev:after { font-size: 18px !important; font-weight: bold; }

/* Noktalar */
.swiper-pagination-bullet-active { background: var(--primary-gold) !important; width: 25px; border-radius: 10px; }

/* =========================================
   6. REFERANSLAR & İLETİŞİM & FOOTER
   ========================================= */
.references-section { background: #fff; padding: 100px 0; }
.clients-grid { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 30px; margin-top: 50px; }
.client-item { text-align: center; }
.client-icon { width: 80px; height: 80px; background: #f8f8f8; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px; }
.client-icon i { font-size: 32px; color: #555; }

.contact-section { background: #262220; padding: 80px 0; color: #fff; }
.contact-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; }
.contact-form-card { background: #322d2a; padding: 40px; border-radius: 8px; }
.form-group input { width: 100%; padding: 15px; background: #423d3a; border: none; color: #fff; margin-bottom: 20px; }
.btn-submit { width: 100%; background: var(--primary-gold); color: #fff; padding: 15px; border: none; font-weight: bold; cursor: pointer; }

.main-footer { background: #000; padding: 25px 0; border-top: 1px solid #222; }
.footer-content { display: flex; justify-content: space-between; color: #666; font-size: 12px; }

/* =========================================
   MOBİL AYARLAR
   ========================================= */
@media (max-width: 768px) {
    .navbar { padding: 20px; background: #fff; position: fixed; box-shadow: 0 2px 10px rgba(0,0,0,0.1); }
    .logo-text h1 { color: #333; }
    .bar { background: #333; }
    .menu-icon { display: flex; }
    .nav-links { position: absolute; right: 0; top: 8vh; background: #fff; flex-direction: column; width: 60%; transform: translateX(100%); transition: 0.5s; height: 92vh; padding-top: 50px; }
    .nav-links.nav-active { transform: translateX(0%); }
    .nav-links li a { color: #333; }
    
    .hero { padding-top: 100px; }
    .main-title { font-size: 32px; }
    .about-section .container, .contact-wrapper, .clients-grid { grid-template-columns: 1fr; }
    .services-area .container { display: flex; flex-direction: column-reverse; }
    .buttons { flex-direction: column; }
    
    /* Mobilde Slider Kart Boyutu */
    .card-image { height: 200px; }
}

/* =========================================
   REFERANS SLIDER AYARLARI
   ========================================= */
.referenceSwiper {
    width: 100%;
    padding: 40px 0;
}

/* Slide içindeki elemanları ortala */
.referenceSwiper .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
}

/* =========================================
   İLETİŞİM BÖLÜMÜ DÜZELTMESİ (GRID YAPISI)
   ========================================= */
.contact-section {
    background-color: #262220;
    padding: 80px 0;
    color: #fff;
    position: relative;
}

.contact-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr; /* İki eşit sütun */
    gap: 80px;
    align-items: flex-start;
}

.info-items {
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin-top: 40px;
}

.info-item {
    display: flex;
    align-items: center;
    gap: 20px;
}

.info-icon {
    width: 60px;
    height: 60px;
    background-color: rgba(255,255,255,0.05);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.info-icon i {
    font-size: 24px;
    color: var(--primary-gold);
}

.info-text h4 { font-size: 14px; color: #fff; margin-bottom: 5px; }
.info-text p { font-size: 14px; color: #aaa; }

/* Form Tasarımı */
.contact-form-card {
    background-color: #322d2a;
    padding: 40px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.05);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.form-group { margin-bottom: 25px; }
.form-group label {
    display: block;
    font-size: 11px;
    color: var(--primary-gold);
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: 1px;
}

.form-group input, .form-group select, .form-group textarea {
    width: 100%;
    background-color: #423d3a;
    border: 1px solid #555;
    padding: 15px;
    color: #ddd;
    border-radius: 4px;
    outline: none;
}

.form-group input:focus, .form-group textarea:focus { border-color: var(--primary-gold); }

/* Mobil Uyumluluk */
@media (max-width: 768px) {
    .contact-wrapper {
        grid-template-columns: 1fr; /* Mobilde alt alta */
        gap: 40px;
    }
    .form-row {
        grid-template-columns: 1fr; /* Mobilde inputlar alt alta */
    }
}
/* =========================================
   HİZMET DİYAGRAMI ÖZEL AYARLARI
   ========================================= */
.diagram-wrapper {
    display: flex;
    justify-content: center; /* Resmi ortalar */
    align-items: center;
    background: transparent; /* Arka plan temiz */
    padding: 20px;
}

.diagram-img {
    width: 100%;
    max-width: 500px; /* Resim çok devasa olmasın, okunabilir kalsın */
    height: auto;
    object-fit: contain; /* Resmi kesmeden sığdır */
    box-shadow: none !important; /* Standart gölgeyi kaldır, grafik olduğu için */
    border-radius: 20px; /* Köşeleri hafif yumuşat */
    
    /* Eğer resmin arka planı sitenin arka planından çok farklıysa
       bunu açarak hafif bir karışım sağlayabiliriz (Opsiyonel): */
    /* mix-blend-mode: multiply; */ 
}

/* Mobilde diyagram ayarı */
@media (max-width: 768px) {
    .diagram-wrapper {
        padding: 0;
        margin-top: 30px;
    }
    .diagram-img {
        max-width: 100%; /* Mobilde tam genişlik */
    }
}