/* ===================================================================== */
/* ===  WEDDING.CSS — YALNIZCA wedding.html (BEŞYILDIZ DÜĞÜN SALONU) === */
/* ===  Başka hiçbir sayfa bu dosyayı kullanmaz.                     === */
/* ===  TEMA: açık zemin + #bb9944 altın vurgu                       === */
/* ===  YAPI:                                                        === */
/* ===   BÖLÜM A → MASAÜSTÜ KODLARI  (min-width: 993px)              === */
/* ===   BÖLÜM B → MOBİL KODLARI     (max-width: 992px)              === */
/* ===   BÖLÜM C → KÜÇÜK TELEFON     (max-width: 768px)              === */
/* ===  Masaüstü ve mobil hiçbir kuralı paylaşmaz.                   === */
/* ===================================================================== */


/* ################################################################## */
/* #####  BÖLÜM A — MASAÜSTÜ (993px ve üzeri ekranlar)          ##### */
/* ################################################################## */
@media (min-width: 993px) {

    /* ---------- A.1 TEMEL SIFIRLAMA (RESET) ---------- */
    * { margin: 0; padding: 0; box-sizing: border-box; }
    /* HTML kökü */
    html { scroll-behavior: smooth; overflow-x: hidden; width: 100%; background: #f7f7f7; }
    /* Gövde */
    body { font-family: 'Montserrat', sans-serif; background: #f7f7f7; color: #2a2a2a; overflow-x: hidden; width: 100%; position: relative; display: flex; flex-direction: column; min-height: 100vh; }
    a { text-decoration: none; color: inherit; }
    .container { max-width: 1200px; margin: auto; padding: 0 20px; }
    section { scroll-margin-top: 120px; }

    /* ---------- A.2 YARDIMCI SINIFLAR — modal form ve iletişimde kullanılan kısayollar ---------- */
    .color-white { color: #f7f7f7; }     /* Beyaz metin */
    .color-dark { color: #2a2a2a; }      /* Koyu metin (otobüs kutusu başlığı) */
    .color-red { color: #e31c24; }       /* Kırmızı vurgu (YEMEKLİ seçeneği) */
    .text-center { text-align: center; } /* Ortalı metin */
    .text-muted { color: #777; }         /* Soluk bilgilendirme metni */
    .font-bold { font-weight: bold; }    /* Kalın yazı */
    .font-1-2 { font-size: 1.2rem; }     /* Büyük yazı (gönder butonu) */
    .font-0-8 { font-size: 0.8rem; }     /* Küçük yazı (dipnot, menü oku) */
    .mb-10 { margin-bottom: 10px; }      /* 10px alt boşluk */
    .mb-15 { margin-bottom: 15px; }      /* 15px alt boşluk */
    .mt-10 { margin-top: 10px; }         /* 10px üst boşluk (ara toplam satırı) — eksikti, eklendi */
    .mt-15 { margin-top: 15px; }         /* 15px üst boşluk */
    .mt-20 { margin-top: 20px; }         /* 20px üst boşluk */
    .ml-5 { margin-left: 5px; }          /* 5px sol boşluk (menü oku) */

    /* ---------- A.3 ARKA PLAN GÖRSELLERİ ---------- */
    .bg-header-wedding { background-image: url('img/wedding-hero-bg.webp'); }   /* Hero fotoğrafı */
    .bg-dugun2 { background-image: url('img/wedding-kir-dugun.webp'); }                   /* Kır düğünü bölüm görseli */
    .bg-dugun3 { background-image: url('img/wedding-kapali-salon.webp'); }                   /* Kapalı salon bölüm görseli */

    /* ---------- A.4 NAVBAR (ÜST MENÜ) — altın vurgulu alt sayfa modu ---------- */
    .navbar-home { background: transparent; border: none; padding: 5px 0; position: fixed; width: 100%; top: 0; z-index: 1000; transition: background 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease; }
    .navbar-home.scrolled { background: #f7f7f7; padding: 0; box-shadow: 0 2px 15px rgba(0,0,0,0.1); }
    .navbar-home .container { max-width: 100%; padding: 0 80px; display: flex; justify-content: space-between; align-items: center; height: 105px; position: relative; }
    /* Logo */
    .static-logo { display: block; width: 170px; margin-right: auto; }
    .static-logo img { width: 100%; height: auto; display: block; }
    /* Mobil öğeler gizli */
    .hamburger-menu { display: none; }
    .nav-right-mobile { display: none; }
    .mobile-menu-header { display: none; }
    /* Menü linkleri */
    .nav-links { display: flex; list-style: none; gap: 30px; align-items: center; }
    .nav-links > li { position: relative; padding: 10px 0; }
    .nav-links > li > a { color: #f7f7f7; font-weight: bold; font-size: 13px; transition: 0.3s; text-transform: uppercase; text-shadow: 1px 1px 3px rgba(0,0,0,0.8); display: inline-block; position: relative; padding-bottom: 5px; }
    /* Altın alt çizgi animasyonu (düğün teması) */
    .nav-links > li > a::after { content: ''; position: absolute; width: 0; height: 3px; bottom: 0; left: 0; background-color: #bb9944; transition: width 0.3s ease-in-out; }
    .nav-links > li > a:hover::after { width: 100%; }
    .nav-links > li > a:hover { color: #f7f7f7; transform: translateY(-2px); }
    .navbar-home.scrolled .nav-links > li > a { color: #2a2a2a; text-shadow: none; }
    .navbar-home.scrolled .nav-links > li > a:hover { color: #bb9944; }
    /* Açılır alt menü: altın üst şerit */
    .dropdown-menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px); background: #f7f7f7; min-width: 220px; box-shadow: 0 5px 20px rgba(0,0,0,0.15); border-radius: 8px; padding: 15px 0; opacity: 0; visibility: hidden; transition: all 0.3s ease; list-style: none; z-index: 1200; border-top: 4px solid #bb9944; }
    .nav-links > li.has-dropdown:hover .dropdown-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
    .dropdown-menu li a { display: block; padding: 10px 20px; color: #2a2a2a; font-size: 13px; font-weight: 600; transition: 0.2s; white-space: nowrap; }
    .dropdown-menu li a:hover { background: #f7f7f7; color: #bb9944; transform: translateX(5px); }

    /* ---------- A.5 HERO (BAŞLIK) — sabit perde efektli düğün fotoğrafı ---------- */
    .page-hero { position: fixed; top: 0; left: 0; width: 100%; height: 500px; background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; color: #f7f7f7; text-align: center; z-index: 0; }
    /* Karartma katmanı */
    .page-hero .overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1; }
    /* Yazı bloğu */
    .hero-text { position: relative; z-index: 2; max-width: 800px; padding: 20px; }
    .hero-text h1 { font-size: 3.5rem; font-weight: 900; margin-bottom: 15px; text-shadow: 2px 2px 10px rgba(0,0,0,0.6); }
    .hero-text p { font-size: 1.1rem; text-shadow: 1px 1px 5px rgba(0,0,0,0.6); margin-bottom: 20px; }
    /* Buton ortak gövdesi */
    .btn-hero { box-shadow: 5px 5px 50px  #bb9944; display: inline-block; color: #f7f7f7; border-radius: 50px; font-weight: bold; transition: 0.3s; border: none; cursor: pointer; position: relative; z-index: 2; }
    /* Altın rezervasyon butonu: hero ve sayfa ortasındaki büyük CTA */
    .btn-reservation { font-size:17px; background-color: #bb9944; padding: 12px 30px; }
    .btn-reservation:hover { background-color: #9a7d35; transform: translateY(-3px) scale(1.05); }

    /* ---------- A.6 PERDE (CURTAIN) DÜZENİ ---------- */
    body.has-hero-reveal { background: transparent; }
    body.has-hero-reveal section,
    body.has-hero-reveal footer { position: relative; z-index: 1; }
    /* İlk içerik bölümü (NEDEN BEŞYILDIZ) hero altından başlar */
    .over-hero { position: relative; z-index: 1; background: #f7f7f7; margin-top: 500px; box-shadow: 0 -14px 30px rgba(0,0,0,0.18); }

    /* ---------- A.7 "NEDEN BEŞYILDIZ?" BÖLÜMÜ — 4 özellik kartı ---------- */
    /* Bölüm: beyaz zemin, padding'siz (negatif marginlarla başlık logoya oturur) */
    .wedding-why-besyildiz { background: #f7f7f7; padding: 0; }
    /* Başlık: ortalı altın; büyük logoyla hizalamak için negatif üst margin */
    .wedding-why-besyildiz .section-title { text-align: center; margin: -50px 0 0 0; font-size: 2rem; color: #bb9944; font-weight: 800; }
    /* Başlık içindeki büyük Beşyıldız logosu */
    .wedding-logo { height: 362px; width: auto; vertical-align: middle; margin: 0 -50px 48px -50px; display: inline-block; }
    /* Kart ızgarası: logo yüksekliğini dengelemek için negatif üst margin */
    .wedding-why-besyildiz .feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; text-align: center; margin: -100px 0 90px 0; }
    /* Tek özellik kartı: sabit altın gölge + altın alt kenar, hover hareketi YOK */
    .wedding-why-besyildiz .t-feature-item { padding: 36px 30px; border-radius: 16px; background: #f7f7f7; box-shadow: 0 6px 10px #bb9944; border-bottom: 4px solid #bb9944; opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease-out, transform 0.6s ease-out; }
    .wedding-why-besyildiz .t-feature-item.visible { opacity: 1; transform: translateY(0); }
    .wedding-why-besyildiz .t-feature-item:hover,
    .wedding-why-besyildiz .t-feature-item.visible:hover { transform: translateY(0); box-shadow: 0 6px 10px #bb9944; border-bottom: 4px solid #bb9944; }
    /* Kart ikonu ve başlığı: altın */
    .wedding-why-besyildiz .t-feature-item i { font-size: 3rem; color: #bb9944; margin-bottom: 20px; }
    .wedding-why-besyildiz .t-feature-item h3 { margin-bottom: 10px; color: #bb9944; }
    /* Kart açıklaması */
    .wedding-why-besyildiz .t-feature-item p { color: #666; font-size: 0.9rem; line-height: 1.6; }

    /* ---------- A.8 HİZMETLER / KIR DÜĞÜNÜ / KAPALI SALON BÖLÜMLERİ — görsel + metin satırları ---------- */
    .wedding-feature-section { padding: 150px 0 0 0; background: #f7f7f7; }
    .wedding-feature-section.bg-light { background: #f7f7f7; }
    /* Görsel ve metni yan yana dizen satır */
    .feature-row { display: flex; align-items: center; gap: 50px; margin-bottom: 0; }
    /* Ters dizilim: görsel solda, metin sağda */
    .feature-row.reverse { flex-direction: row-reverse; }
    /* Metin sütunu */
    .feature-text { flex: 1; padding: 0; }
    /* Sol hizalı bölüm başlığı: altın, büyük harf */
    .section-title-left { font-size: 2rem; color: #bb9944; margin-bottom: 20px; font-weight: 800; text-transform: uppercase; }
    /* Alt başlık ("Yıldızların Altında...") : altın */
    .feature-text h3 { font-size: 1.5rem; color: #bb9944; margin-bottom: 20px; font-weight: 800; }
    /* Açıklama paragrafı */
    .feature-text p { font-size: 1rem; line-height: 1.6; color: #555; margin-bottom: 30px; }
    /* Hizmet listesi (yıldız/onay ikonlu) */
    .feature-list { list-style: none; padding: 0; }
    .feature-list li { margin-bottom: 12px; font-size: 1.1rem; color: #555; display: flex; align-items: center; }
    .feature-list li:last-child { margin-bottom: 0; }
    /* Liste ikonları: altın */
    .feature-list li i { color: #bb9944; }
    /* İki sütunlu liste varyantı */
    .feature-list.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    /* Bölüm görseli / videosu: 16:10 oran, altın çerçeve */
    .feature-img { width: auto; height: 400px; aspect-ratio: 16 / 10; flex-shrink: 0; background-size: cover; background-position: center; border-radius: 24px; box-shadow: 0px 0px 30px #bb9944; object-fit: cover; border: solid 4px #bb9944; }

    /* ---------- A.9 İSTATİSTİK BANDI — sayaçlı kapasite bilgileri ---------- */
    /* DÜZELTME: orijinaldeki bozuk gradient (sondaki virgül) tüm arka planı geçersiz kılıyordu;
       sayfada gerçekte görünen haliyle (açık zemin) geçerli koda çevrildi */
    .stats-banner.parallax-bg { background: #f7f7f7; padding: 20px 0; width: 100%; margin-top: 90px; margin-bottom: 90px; }
    /* Sayaç ızgarası: eşit aralıklarla yayılır */
    .stats-grid { display: flex; justify-content: space-around; text-align: center; flex-wrap: wrap; gap: 30px; }
    /* İki öğeli varyant: ortalanır */
    .stats-grid.two-items { justify-content: center; gap: 100px; }
    /* Yayılmış varyant (kapasiteler bölümü) */
    .stats-grid.stats-grid-spread { justify-content: space-between; }
    /* Tek istatistik öğesi: ikon + rakam + etiket */
    .stat-item { display: flex; flex-direction: column; align-items: center; }
    .stat-item i { font-size: 2.5rem; margin-bottom: 15px; color: #bb9944; }     /* İkon: altın */
    .stat-item h3 { font-size: 2rem; font-weight: 800; margin-bottom: 5px; color: #bb9944; }   /* Rakam: altın */
    .stat-item p { font-size: 1rem; color: #858585; text-transform: uppercase; letter-spacing: 1px; }  /* Etiket: gri */

    /* ---------- A.10 FİLM ŞERİDİ — kayan fotoğraf galerisi ---------- */
    /* Bölüm: sabit (parallax) arka plan fotoğrafı üzerinde şerit kayar */
    .film-section { margin-bottom: 0; background-image: url('img/wedding-film-bg.webp'); background-attachment: fixed; background-size: cover; background-position: center; padding: 10px 0; overflow: hidden; }
    /* Şerit kapsayıcısı */
    .film-strip-container { width: 100%; overflow: hidden; background: transparent; padding: 10px 0; position: relative; }
    /* Kayan iç şerit: 12 kare, 35 saniyede tur
       DÜZELTME: kayma mesafesi gerçek kare genişliğiyle (400px + 20px margin)
       eşitlendi; tur sonundaki görünür sıçrama giderildi */
    .film-track { display: flex; gap: 0; width: calc(420px * 12); animation: weddingScrollFilm 35s linear infinite; }
    /* Tek film karesi: sinema şeridi görünümlü çerçeve */
    .film-frame { width: 400px; height: 320px; flex-shrink: 0; position: relative; border-top: 5px solid #2a2a2a; border-bottom: 10px solid #2a2a2a; background: #000; margin: 0 10px; box-shadow: 0 5px 20px rgba(0,0,0,0.8); overflow: hidden; border-radius: 2px; }
    /* Üst/alt film delikleri (dekoratif) */
    .film-frame::before, .film-frame::after { content: ''; position: absolute; left: 0; width: 100%; height: 8px; background-image: radial-gradient(#444 30%, transparent 31%); background-size: 20px 8px; z-index: 10; opacity: 0.9; }
    .film-frame::before { top: 1px; }
    .film-frame::after  { bottom: 1px; }
    /* Fotoğraf: filtresiz, orijinal renklerinde (düğün sayfası tasarım kararı) */
    .film-content { width: 100%; height: 100%; object-fit: cover; filter: none; opacity: 1; transition: none; }
    .film-frame:hover .film-content { filter: none; opacity: 1; transform: none; }
    .film-frame:hover { transform: none; }
    /* Kayma animasyonu: 6 kare genişliği kadar (kare 400px + 20px margin) */
    @keyframes weddingScrollFilm { 0% { transform: translateX(0); } 100% { transform: translateX(calc(-420px * 6)); } }

    /* ---------- A.11 REZERVASYON BUTONU BÖLÜMÜ ---------- */
    .reservation-section { background: #f7f7f7; padding: 90px 0; text-align: center; margin-top: 0; margin-bottom: 0; }

    /* ---------- A.12 REZERVASYON MODALI — MODERN fiyat hesaplama formu ---------- */
    /* Tüm ekranı kaplayan karartma + hafif bulanıklık; JS display:flex yapana dek gizli */
    .reservation-modal { display: none; position: fixed; z-index: 2000; inset: 0; width: 100%; height: 100%; background: rgba(20,18,14,0.62); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); justify-content: center; align-items: center; padding: 28px; }
    /* Modal içerik kutusu: DİKEY FLEX (sabit başlık + kaydırılabilir gövde) — X butonu sabit kalır */
    .modal-content { background: #fff; border-radius: 22px; width: 100%; max-width: 880px; max-height: 92vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 30px 80px rgba(0,0,0,0.45); position: relative; animation: weddingModalFadeIn 0.4s cubic-bezier(0.16,1,0.3,1); }
    @keyframes weddingModalFadeIn { from { opacity: 0; transform: translateY(26px) scale(0.97); } to { opacity: 1; transform: translateY(0) scale(1); } }

    /* SABİT BAŞLIK ŞERİDİ: kaydırmadan etkilenmez, X butonu her zaman görünür */
    .modal-header { flex-shrink: 0; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 30px; background: #fff; border-bottom: 1px solid #eee; position: relative; }
    .modal-header::after { content: ''; position: absolute; left: 30px; bottom: -1px; width: 60px; height: 3px; background: #bb9944; border-radius: 3px; }
    /* Modal başlığı: koyu, sol hizalı */
    .modal-title { text-align: left; color: #2a2a2a; margin: 0; font-size: 1.4rem; font-weight: 800; letter-spacing: 0.2px; }
    /* Kapatma butonu: yuvarlak; hover'da altın + döner */
    .close-modal { flex-shrink: 0; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; font-size: 28px; line-height: 1; color: #888; background: #f1f1f1; border: none; border-radius: 50%; cursor: pointer; padding: 0; transition: background 0.25s, color 0.25s, transform 0.3s; }
    .close-modal:hover { background: #bb9944; color: #fff; transform: rotate(90deg); }

    /* KAYDIRILABİLİR GÖVDE */
    .modal-body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 26px 30px 30px; background: #fff; }
    .modal-body::-webkit-scrollbar { width: 10px; }
    .modal-body::-webkit-scrollbar-thumb { background: #dccca8; border-radius: 10px; border: 2px solid #fff; }
    .modal-body::-webkit-scrollbar-track { background: transparent; }

    /* Form bölümü kutusu (Kişisel Bilgiler, Ek Hizmetler vb.) */
    .form-section { background: #fafafa; padding: 22px; border: 1px solid #eee; border-radius: 16px; margin-bottom: 18px; }
    .form-section:last-of-type { margin-bottom: 0; }
    /* Bölüm başlığı: koyu, altın sol şeritli */
    .form-section h4 { color: #2a2a2a; margin: 0 0 18px; padding-left: 13px; font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; border-left: 4px solid #bb9944; line-height: 1.15; }
    /* İki sütunlu giriş ızgarası (Kişisel Bilgiler bölümü) */
    .wedding-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
    /* Etiket + giriş çifti */
    .form-group { margin-bottom: 0; }
    .form-group label { display: block; margin-bottom: 7px; font-weight: 600; color: #555; font-size: 0.9rem; }
    /* Giriş alanları */
    .form-group select, .form-group input, .form-group textarea { width: 100%; padding: 12px 14px; border: 1px solid #ddd; border-radius: 10px; font-size: 0.95rem; font-family: inherit; background: #fff; color: #2a2a2a; transition: border-color 0.2s, box-shadow 0.2s; }
    .form-group select:focus, .form-group input:focus, .form-group textarea:focus { outline: none; border-color: #bb9944; box-shadow: 0 0 0 3px rgba(187,153,68,0.16); }
    .form-group textarea { resize: vertical; min-height: 90px; }
    /* Kısa sayı girişi (davetli sayısı) */
    .form-group .input-short { width: 160px; display: block; }
    /* Telefon kodu + numara yan yana */
    .phone-group { display: flex; gap: 10px; }
    .phone-group select { width: 96px; flex-shrink: 0; }
    .phone-group input { flex-grow: 1; }
    /* Zorunlu alan yıldızı */
    .required-star { color: #e31c24; margin-left: 2px; font-size: 1rem; }
    /* Kırmızı kenarlıklı vurgulu giriş (yemek kişi sayısı) */
    .input-highlight { border-color: #e31c24 !important; }

    /* Onay kutusu ızgarası: her seçenek kart görünümlü */
    .checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(225px, 1fr)); gap: 10px; }
    .checkbox-item { display: flex; align-items: center; font-size: 0.92rem; cursor: pointer; padding: 12px 13px; border: 1px solid #eee; background: #fff; border-radius: 11px; transition: border-color 0.2s, background 0.2s, box-shadow 0.2s; }
    .checkbox-item:hover { border-color: #bb9944; background: #fffdf6; box-shadow: 0 2px 8px rgba(187,153,68,0.12); }
    /* Onay kutusu: altın işaret rengi */
    .checkbox-item input { width: 19px; height: 19px; margin-right: 11px; accent-color: #bb9944; flex-shrink: 0; cursor: pointer; }
    /* Satır içi küçük sayı girişi (araç adetleri) */
    .input-inline { display: inline-block; width: 68px !important; padding: 8px !important; border: 1px solid #ccc; border-radius: 8px; margin-left: 5px; font-family: inherit; }
    /* Masaya servis seçeneği: mavi tonlu vurgu */
    .checkbox-service { color: #003366; border-color: #cfe0ff !important; background: #eef4ff !important; }
    /* "Düğünüm Yemekli Olsun" kutusu */
    .meal-toggle-box { margin-bottom: 0; }
    .meal-toggle-box .checkbox-item { border-color: #f3c9cb; background: #fff6f6; }
    .meal-toggle-box .checkbox-item:hover { border-color: #e31c24; }
    /* Araç sayısı kutusu: mavi çerçeveli varyant */
    .bus-hidden-options { background: #eef4ff !important; border-left-color: #003366 !important; }
    /* Gizli ek seçenek kutuları (JS gösterir) */
    .hidden-options { display: none; margin-top: 16px; padding: 18px; background: #fffdf6; border-left: 4px solid #bb9944; border-radius: 11px; }
    /* Araç adedi satırı */
    .bus-input-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-size: 0.92rem; }
    .bus-input-row:last-child { margin-bottom: 0; }
    .bus-input-row label { width: 160px; font-weight: 600; color: #555; }

    /* Fiyat özeti kutusu: koyu zemin, altın toplam */
    .price-summary { background: linear-gradient(155deg, #313131, #232323); color: #f1f1f1; padding: 26px; border-radius: 18px; margin-top: 22px; box-shadow: 0 12px 30px rgba(0,0,0,0.18); }
    /* Tek fiyat satırı */
    .price-row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 12px; font-size: 0.98rem; color: #c9c9c9; }
    .price-row span:last-child { font-weight: 600; color: #fff; }
    /* GENEL TOPLAM satırı: büyük altın */
    .price-row.total { border-top: 1px solid #4a4a4a; padding-top: 18px; margin-top: 14px; margin-bottom: 0; font-size: 1.4rem; font-weight: 800; color: #bb9944; }
    .price-row.total span:last-child { color: #bb9944; }
    /* Ara toplam satırı: kesikli üst çizgi */
    .price-row.price-subtotal { border-top: 1px dashed #555; padding-top: 14px; margin-top: 4px; color: #e2e2e2; }
    /* Gönder butonu: altın gradyan, hover'da hafif yükselir */
    .btn-submit { width: 100%; padding: 15px; background: linear-gradient(135deg, #c9a64e, #bb9944); color: #fff; border: none; border-radius: 12px; font-size: 1.05rem; font-weight: 700; letter-spacing: 0.3px; cursor: pointer; margin-top: 20px; box-shadow: 0 10px 24px rgba(187,153,68,0.32); transition: transform 0.2s, box-shadow 0.2s, background 0.2s; }
    .btn-submit:hover { background: linear-gradient(135deg, #bb9944, #9a7d35); transform: translateY(-2px); box-shadow: 0 14px 30px rgba(187,153,68,0.42); }
    .btn-submit:active { transform: translateY(0); }
    .btn-submit:disabled { opacity: 0.65; cursor: not-allowed; transform: none; box-shadow: none; }

    /* ---------- A.13 ÖZEL UYARI KUTUSU — başarı/hata penceresi ---------- */
    .custom-alert-overlay { display: none; position: fixed; z-index: 9999; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); justify-content: center; align-items: center; }
    .custom-alert-box { background: #f7f7f7; padding: 30px; border-radius: 15px; text-align: center; box-shadow: 0 10px 40px rgba(0,0,0,0.4); max-width: 400px; width: 90%; animation: weddingAlertPop 0.3s ease-out; }
    @keyframes weddingAlertPop { from { transform: scale(0.8); opacity: 0; } to { transform: scale(1); opacity: 1; } }
    .alert-icon { font-size: 50px; margin-bottom: 20px; display: block; }
    .alert-icon.success { color: #28a745; }
    .alert-icon.error   { color: #dc3545; }
    .alert-title   { font-size: 1.5rem; margin-bottom: 10px; color: #2a2a2a; }
    .alert-message { color: #666; margin-bottom: 20px; line-height: 1.5; }
    .alert-btn { background: #2a2a2a; color: #f7f7f7; border: none; padding: 10px 30px; border-radius: 5px; cursor: pointer; font-size: 1rem; transition: 0.3s; }
    .alert-btn:hover { background: #bb9944; }

    /* ---------- A.14 GOOGLE YORUMLARI — kayan yorum kartları ---------- */
    .google-reviews-section { padding: 30px 0 70px 0; background: #f7f7f7; overflow: hidden; }
    /* Başlık: altın */
    .google-reviews-section .section-title { text-align: center; margin-bottom: 35px; font-size: 2rem; color: #bb9944; font-weight: 800; }
    .reviews-track-wrapper { overflow: hidden;justify-content: center; display: flex;}
    .reviews-track { display: flex; gap: 20px; padding: 10px 4px; width: auto; animation: weddingScrollReviews 32s linear infinite; align-items: stretch; }
    .reviews-track:hover { animation-play-state: paused; }
    .review-item { width: 420px; flex-shrink: 0; border-radius: 14px; overflow: hidden; box-shadow: 0 0 15px #bb9944; background: #fff; border: 1px solid #eee; transition: transform 0.3s ease, box-shadow 0.3s ease; display: flex;           /* ekle */
    flex-direction: column;  /* ekle */
    align-self: stretch;}
    .review-item:hover { transform: translateY(-6px); box-shadow: 0 0 20px #bb9944; }
    .review-item img { width: 100%; height: auto; display: block; object-fit: cover;}
    @keyframes weddingScrollReviews { 0% { transform: translateX(0); } 100% { transform: translateX(calc(-440px * 6)); } }

    /* ---------- A.15 İLETİŞİM & HARİTA — koyu yeşil panel ---------- */
    .home-contact-modern { padding: 80px 0; background: #f7f7f7; }
    .home-contact-modern .container { display: flex; gap: 28px; align-items: stretch; }
    /* İletişim kutusu: koyu yeşil degrade (Beşyıldız kurumsal rengi) */
    .contact-box-modern { background: linear-gradient(135deg, #f7f7f7 0%, #f7f7f7 100%); flex: 1; border-radius: 22px; overflow: hidden; box-shadow: 0 0px 20px #bb9944; border: 1px solid #eee; }
    .contact-info-panel { padding: 45px 55px; }
    /* Başlık: altın */
    .contact-info-panel h2 { font-size: 2rem; margin-bottom: 28px; color: #bb9944; }
    /* Bilgi satırları: altın ikon, beyaz metin */
    .info-row { display: flex; align-items: center; margin-bottom: 22px; }
    .info-row i { width: 50px; height: 50px; min-width: 50px; background: rgba(187,153,68,0.15); color: #bb9944; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; margin-right: 20px; }
    .info-row div span { display: block; font-size: 0.8rem; color: #999; text-transform: uppercase; font-weight: bold; letter-spacing: 0.5px; }
    .info-row div p { margin: 0; font-size: 1.1rem; color: #333; font-weight: 500; }
    /* Aksiyon butonları */
    .contact-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 32px; }
    .btn-action { width:140px; display: flex; justify-content: center; align-items: center; gap: 9px; padding: 14px 20px; border-radius: 50px; font-weight: bold; transition: transform 0.25s ease, box-shadow 0.25s ease; color: #fff; border: none; cursor: pointer; font-size: 0.95rem; }
    .btn-action i { font-size: 1.1rem; }
    .btn-action:hover { transform: translateY(-4px); box-shadow: 0 10px 22px rgba(0,0,0,0.35); }
    .btn-phone     { background: linear-gradient(to bottom, #66D94E, #1FBE07); }
    .btn-whatsapp  { background: #25D366; }
    .btn-mail      { background: #ea4335; }
    .btn-maps      { background: linear-gradient(135deg, #4A89F3 25%, #55AF7B 45%, #F4B327 70%, #E44A3C 90%); }
    .btn-instagram { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); }
    .btn-facebook  { background: #1877f2; }
    /* Harita penceresi */
    .contact-map-window { flex: 1; height: auto; min-height: 400px; border-radius: 22px; overflow: hidden; box-shadow: 0 0px 20px #bb9944; border: 6px solid #fff; }
    .contact-map-window iframe { width: 100%; height: 100%; border: 0; display: block; }

    /* ---------- A.16 FOOTER ---------- */
    footer { text-align: center; padding: 8px; background: #bb9944; color: #f7f7f7; font-size: 0.8rem; margin-top: auto; }

    /* ---------- A.17 KAYDIRMA ANİMASYONLARI ---------- */
    .scroll-reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.65s ease-out, transform 0.65s ease-out; }
    .scroll-reveal.visible { opacity: 1; transform: translateY(0); }
    .sr-auto { opacity: 0; transform: translateY(22px); transition: opacity 0.55s ease-out, transform 0.55s ease-out; }
    .sr-auto.visible { opacity: 1; transform: translateY(0); }
}


































/* ################################################################## */
/* #####  BÖLÜM B — MOBİL (992px ve altı ekranlar)              ##### */
/* ################################################################## */
@media (max-width: 992px) {

    /* ---------- B.1 TEMEL SIFIRLAMA (RESET) — mobil kopya ---------- */
    * { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; overflow-x: hidden; width: 100%; background: #f7f7f7; }
    body { font-family: 'Montserrat', sans-serif; background: #f7f7f7; color: #2a2a2a; overflow-x: hidden; width: 100%; position: relative; display: flex; flex-direction: column; min-height: 100vh; }
    a { text-decoration: none; color: inherit; }
    .container { max-width: 1200px; margin: auto; padding: 0 20px; }
    section { scroll-margin-top: 70px; }

    /* ---------- B.2 YARDIMCI SINIFLAR (mobil kopya) ---------- */
    .color-white { color: #f7f7f7; }
    .color-dark { color: #2a2a2a; }
    .color-red { color: #e31c24; }
    .text-center { text-align: center; }
    .text-muted { color: #777; }
    .font-bold { font-weight: bold; }
    .font-1-2 { font-size: 1.2rem; }
    .font-0-8 { font-size: 0.8rem; }
    .mb-10 { margin-bottom: 10px; }
    .mb-15 { margin-bottom: 15px; }
    .mt-10 { margin-top: 10px; }
    .mt-15 { margin-top: 15px; }
    .mt-20 { margin-top: 20px; }
    .ml-5 { margin-left: 5px; }

    /* ---------- B.3 ARKA PLAN GÖRSELLERİ (mobil kopya) ---------- */
    .bg-header-wedding { background-image: url('img/wedding-hero-bg.webp'); }
    .bg-dugun2 { background-image: url('img/wedding-kir-dugun.webp'); }
    .bg-dugun3 { background-image: url('img/wedding-kapali-salon.webp'); }

    /* ---------- B.4 MOBİL NAVBAR — altın vurgulu hamburger menü ---------- */
    .navbar-home { background: transparent; border: none; padding: 5px 0; position: fixed; width: 100%; top: 0; z-index: 1000; transition: background 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease; }
    .navbar-home.scrolled { background: #f7f7f7; padding: 0; box-shadow: 0 2px 15px rgba(0,0,0,0.1); }
    .navbar-home .container { max-width: 100%; padding: 0 20px; height: 70px; display: flex; justify-content: space-between; align-items: center; width: 100%; position: relative; }
    .static-logo { display: block; width: 170px; margin-right: auto; }
    .static-logo img { width: 100%; height: auto; display: block; }
    .nav-right-mobile { display: flex; align-items: center; }
    .mobile-call-btn { display: flex; align-items: center; justify-content: center; color: #f7f7f7; font-size: 20px; margin-right: 15px; transition: color 0.3s; }
    .navbar-home.scrolled .mobile-call-btn { color: #2a2a2a; }
    .hamburger-menu { display: block; cursor: pointer; z-index: 1200; position: relative; }
    .hamburger-line { width: 30px; height: 3px; background: #f7f7f7; margin: 5px; transition: 0.4s; border-radius: 2px; }
    .navbar-home.scrolled .hamburger-line { background: #2a2a2a; }
    /* Açıkken X şekli: kırmızı (sitenin genel vurgusu) */
    .hamburger-menu.toggle .line1 { transform: rotate(-45deg) translate(-5px, 6px); background: #e31c24; }
    .hamburger-menu.toggle .line2 { opacity: 0; }
    .hamburger-menu.toggle .line3 { transform: rotate(45deg) translate(-5px, -6px); background: #e31c24; }
    /* Sağdan kayan beyaz menü paneli */
    .nav-links { position: fixed; top: 0; right: -100%; width: 280px; height: 100vh; background: #f7f7f7; list-style: none; display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; transition: right 0.4s ease-in-out; z-index: 1100; padding: 80px 20px 40px 20px; overflow-y: auto; gap: 15px; }
    .nav-links.active { right: 0; box-shadow: -5px 0 20px rgba(0,0,0,0.2); }
    /* Panel başlığı: altın "MENÜ" (düğün teması) */
    .mobile-menu-header { display: block; font-size: 20px; font-weight: 900; color: #bb9944; margin-bottom: 10px; }
    .nav-links li { width: 100%; text-align: left; padding: 5px 0; }
    .nav-links > li > a { color: #2a2a2a; text-shadow: none; font-size: 15px; font-weight: bold; text-transform: uppercase; width: 100%; display: flex; justify-content: space-between; transition: 0.3s; }
    /* Dokunma/hover: altın vurgu */
    .nav-links > li > a:hover,
    .nav-links > li > a:focus,
    .nav-links > li > a:active { color: #bb9944; transform: none; }
    /* Panel içi açılır alt menü */
    .dropdown-menu { position: relative; left: 0; top: 0; transform: none; background: #f7f7f7; width: 100%; display: none; list-style: none; opacity: 1; visibility: visible; border-top: none; padding: 5px 10px; margin-top: 5px; box-shadow: none; border-radius: 0; }
    .has-dropdown.active .dropdown-menu { display: block; }
    .dropdown-menu li a { display: block; padding: 8px 10px; font-size: 14px; color: #555; font-weight: 600; transition: 0.2s; white-space: nowrap; }
    .dropdown-menu li a:hover { color: #bb9944; }

    /* ---------- B.5 MOBİL HERO — 320px sabit perde ---------- */
    .page-hero { position: fixed; top: 0; left: 0; width: 100%; height: 320px; background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; color: #f7f7f7; text-align: center; padding: 0 20px; z-index: 0; }
    .page-hero .overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1; }
    .hero-text { position: relative; width: 100%; max-width: 100%; padding: 0; margin: 0 auto; text-align: center; z-index: 2; }
    .hero-text h1 { font-size: 24px; line-height: 1.3; margin: 0 auto 12px auto; max-width: 100%; font-weight: 800; text-shadow: 2px 2px 10px rgba(0,0,0,0.6); }
    .hero-text p { font-size: 0px; line-height: 1.5; margin: 0 auto 20px auto; text-shadow: 1px 1px 5px rgba(0,0,0,0.6); }
    /* Buton gövdesi + altın rezervasyon butonu */
    .btn-hero { display: inline-block; color: #f7f7f7; margin: 0 auto; padding: 10px 24px; border-radius: 50px; font-weight: bold; font-size: 14px; transition: 0.3s; box-shadow: 5px 5px 50px #bb9944; border: none; cursor: pointer; position: relative; z-index: 2; }
    .btn-reservation { background-color: #bb9944; }
    .btn-reservation:hover { background-color: #9a7d35; }

    /* ---------- B.6 PERDE DÜZENİ (mobil) ---------- */
    body.has-hero-reveal { background: transparent; }
    body.has-hero-reveal section,
    body.has-hero-reveal footer { position: relative; z-index: 1; }
    .over-hero { position: relative; z-index: 1; background: #f7f7f7; margin-top: 320px; padding-top: 0; box-shadow: 0 -14px 30px rgba(0,0,0,0.18); }

    /* ---------- B.7 "NEDEN BEŞYILDIZ?" (mobil) ---------- */
    .wedding-why-besyildiz { background: #f7f7f7; padding: 0; }
    /* Başlık: logo ile tek satır (768 altında küçülür) */
    .wedding-why-besyildiz .section-title { display: flex; align-items: center; justify-content: center; flex-wrap: nowrap; white-space: nowrap; gap: 6px; font-size: 22px; padding: 0px 0; color: #bb9944; font-weight: 800; text-align: center; }
    /* Logo: tablet boyutu */
    .wedding-logo { height: 240px; width: auto; vertical-align: middle; margin: 0 -30px 33px -30px; display: inline-block; }
    .wedding-why-besyildiz .feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; text-align: center; margin: -40px 0 40px 0; }
    /* DÜZELTME (mobil): masaüstündeki belirgin altın gölge ve 4px alt kenar
       mobilde soluklaştırılmıştı; masaüstüyle birebir eşitlendi */
    .wedding-why-besyildiz .t-feature-item { padding: 36px 30px; border-radius: 16px; background: #f7f7f7; box-shadow: 0 6px 10px #bb9944; border-bottom: 4px solid #bb9944; opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease-out, transform 0.6s ease-out; }
    .wedding-why-besyildiz .t-feature-item.visible { opacity: 1; transform: translateY(0); }
    .wedding-why-besyildiz .t-feature-item i { font-size: 3rem; color: #bb9944; margin-bottom: 20px; }
    .wedding-why-besyildiz .t-feature-item h3 { margin-bottom: 10px; color: #bb9944; font-size: 18px; }
    .wedding-why-besyildiz .t-feature-item p { color: #666; font-size: 14px; line-height: 1.6; }

    /* ---------- B.8 HİZMET / DÜĞÜN BÖLÜMLERİ (mobil) — dikey dizilim ---------- */
    .wedding-feature-section { padding: 70px 0 0 0; background: #f7f7f7; }
    .wedding-feature-section.bg-light { background: #f7f7f7; }
    /* Görsel ve metin alt alta */
    .feature-row,
    .feature-row.reverse { display: flex; flex-direction: column; align-items: center; gap: 30px; margin-bottom: 0; }
    .feature-text {margin:0 0px 30px 0px; width: 100%; padding: 0 20px 0 20px; }
    /* Başlıklar: 22px altın */
    .section-title-left { font-size: 22px; color: #bb9944; margin-bottom: 15px; font-weight: 700; text-transform: uppercase; }
    .feature-text h3 { font-size: 18px; color: #bb9944; margin-bottom: 15px; font-weight: 600; }
    .feature-text p { font-size: 14px; line-height: 1.6; color: #555; margin-bottom: 30px; }
    .feature-list { list-style: none; padding: 0 0; }
    .feature-list li {gap:4px; margin-bottom: 12px; font-size: 14px; color: #555; display: flex; align-items: center; }
    .feature-list li:last-child { margin-bottom: 12px; }
    .feature-list li i { color: #bb9944; }
    .feature-list.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    /* Görsel/video — DÜZELTME (mobil): sabit 240px yükseklik geniş ekranlarda
       2:1'e varan tutarsız kırpmalara yol açıyordu; masaüstündeki 16:10 oranına
       sabitlendi ve altın gölge masaüstüyle eşitlendi */
    .feature-img { width: 95%; height: auto; aspect-ratio: 16 / 10; flex-shrink: 0; background-size: cover; background-position: center; border-radius: 20px; box-shadow: 0px 0px 25px #bb9944; object-fit: cover; border: solid 3px #bb9944; }

    /* ---------- B.9 İSTATİSTİK BANDI (mobil) — 2 sütun küçük sayaçlar ---------- */
    /* DÜZELTME: bozuk gradient yerine geçerli açık zemin */
    .stats-banner.parallax-bg { background: #f7f7f7; padding: 20px 20px; width: 100%; margin-top: 40px; margin-bottom: 50px; }
    /* Sayaçlar 2 sütunlu ızgarada */
    .stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; text-align: center; }
    .stats-grid.two-items { gap: 12px; }
    .stat-item {padding: 10px 0; display: flex; flex-direction: column; align-items: center; }
    .stat-item i { font-size: 1.5rem; margin-bottom: 6px; color: #bb9944; }
    .stat-item h3 { font-size: 1.2rem; font-weight: 800; margin-bottom: 2px; color: #bb9944; }
    .stat-item p { font-size: 0.75rem; color: #858585; text-transform: uppercase; letter-spacing: 0.5px; }

    /* ---------- B.10 FİLM ŞERİDİ (mobil) — masaüstüyle aynı kare oranı ---------- */
    /* Varsayılan (eski tarayıcı yedeği): arka plan sayfayla kayar */
    .film-section { margin-top: 0px; background-image: url('img/wedding-film-bg.webp'); background-attachment: scroll; background-size: cover; background-position: center; padding: 0px 0; overflow: hidden; }
    /* DÜZELTME (mobil): iOS/Android background-attachment:fixed desteklemediği için
       sabit (parallax) arka plan, clip-path ile kırpılan position:fixed sözde-öğe
       tekniğiyle sağlanır — arka plan kaydırma sırasında tamamen sabit kalır */
    @supports ((clip-path: inset(0)) or (-webkit-clip-path: inset(0))) {
        .film-section { background-image: none; position: relative; -webkit-clip-path: inset(0); clip-path: inset(0); }
        .film-section::before { content: ''; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background-image: url('img/wedding-film-bg.webp'); background-size: cover; background-position: center; z-index: -1; pointer-events: none; }
    }
    .film-strip-container { width: 100%; overflow: hidden; background: transparent; padding: 10px 0; position: relative; }
    .film-track { display: flex; gap: 0; width: calc(270px * 12); animation: weddingScrollFilmMobile 35s linear infinite; }
    /* DÜZELTME (mobil): 400x165 kare masaüstüne göre aşırı yatay kırpıyordu;
       kare, masaüstündeki 400x305 görünür fotoğraf oranına (1.31:1) eşitlendi:
       300px genişlik → 229px fotoğraf + 15px bordür = 244px kare yüksekliği */
    .film-frame { width: 250px; height: 200px; flex-shrink: 0; position: relative; border-top: 0px solid #2a2a2a; border-bottom: 0px solid #2a2a2a; background: #000; margin: 5px 8px; box-shadow: 0 5px 20px rgba(0,0,0,0.8); overflow: hidden; border-radius: 2px; }
    .film-frame::before, .film-frame::after { content: ''; position: absolute; left: 0; width: 100%; height: 8px; background-image: radial-gradient(#444 30%, transparent 31%); background-size: 20px 8px; z-index: 10; opacity: 0.9; }
    .film-frame::before { top: 1px; }
    .film-frame::after  { bottom: 1px; }
    /* Fotoğraf: kırpma object-fit:cover ile, bozulma yok */
    .film-content { width: 100%; height: 100%; object-fit: cover; filter: none; opacity: 1; transition: none; }
    /* Kayma mesafesi yeni kare genişliğine (300px + 20px margin) göre */
    @keyframes weddingScrollFilmMobile { 0% { transform: translateX(0); } 100% { transform: translateX(calc(-320px * 6)); } }

    /* ---------- B.11 REZERVASYON BUTONU BÖLÜMÜ (mobil) ---------- */
    .reservation-section { background: #f7f7f7; padding: 50px 0; text-align: center; margin: 0; }

    /* ---------- B.12 REZERVASYON MODALI (mobil) — MODERN ---------- */
    .reservation-modal { display: none; position: fixed; z-index: 2000; inset: 0; width: 100%; height: 100%; background: rgba(20,18,14,0.62); -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); justify-content: center; align-items: center; padding: 16px; }
    /* Dikey flex: sabit başlık + kaydırılabilir gövde */
    .modal-content { background: #fff; border-radius: 20px; width: 100%; max-width: 760px; max-height: 94vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,0.45); position: relative; animation: weddingModalFadeInMobile 0.35s cubic-bezier(0.16,1,0.3,1); }
    @keyframes weddingModalFadeInMobile { from { opacity: 0; transform: translateY(22px) scale(0.97); } to { opacity: 1; transform: translateY(0) scale(1); } }
    /* SABİT BAŞLIK ŞERİDİ */
    .modal-header { flex-shrink: 0; display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 18px 22px; background: #fff; border-bottom: 1px solid #eee; position: relative; }
    .modal-header::after { content: ''; position: absolute; left: 22px; bottom: -1px; width: 52px; height: 3px; background: #bb9944; border-radius: 3px; }
    .modal-title { text-align: left; color: #2a2a2a; margin: 0; font-size: 1.2rem; font-weight: 800; }
    .close-modal { flex-shrink: 0; width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; font-size: 26px; line-height: 1; color: #888; background: #f1f1f1; border: none; border-radius: 50%; cursor: pointer; padding: 0; transition: background 0.25s, color 0.25s; }
    .close-modal:hover, .close-modal:active { background: #bb9944; color: #fff; }
    /* KAYDIRILABİLİR GÖVDE */
    .modal-body { flex: 1 1 auto; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 20px 22px 24px; background: #fff; }
    .form-section { background: #fafafa; padding: 18px; border: 1px solid #eee; border-radius: 14px; margin-bottom: 16px; }
    .form-section:last-of-type { margin-bottom: 0; }
    .form-section h4 { color: #2a2a2a; margin: 0 0 16px; padding-left: 12px; font-size: 15px; text-transform: uppercase; font-weight: 700; letter-spacing: 0.4px; border-left: 4px solid #bb9944; line-height: 1.15; }
    /* Tablet: 2 sütun korunur (768 altında teke düşer) */
    .wedding-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    .form-group { margin-bottom: 0; }
    .form-group label { display: block; margin-bottom: 7px; font-weight: 600; color: #555; font-size: 14px; }
    /* font-size:16px → mobil tarayıcıların alana odaklanınca otomatik yakınlaşmasını (zoom) engeller */
    .form-group select, .form-group input, .form-group textarea { width: 100%; padding: 12px 14px; border: 1px solid #ddd; border-radius: 10px; font-size: 16px; font-family: inherit; background: #fff; color: #2a2a2a; transition: border-color 0.2s, box-shadow 0.2s; }
    .form-group select:focus, .form-group input:focus, .form-group textarea:focus { outline: none; border-color: #bb9944; box-shadow: 0 0 0 3px rgba(187,153,68,0.16); }
    .form-group textarea { resize: vertical; min-height: 90px; }
    .form-group .input-short { width: 160px; display: block; }
    .phone-group { display: flex; gap: 10px; }
    .phone-group select { width: 92px; flex-shrink: 0; }
    .phone-group input { flex-grow: 1; min-width: 0; }
    .required-star { color: #e31c24; margin-left: 2px; }
    .input-highlight { border-color: #e31c24 !important; }
    .checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; }
    .checkbox-item { display: flex; align-items: center; font-size: 14px; cursor: pointer; padding: 13px; border: 1px solid #eee; background: #fff; border-radius: 11px; transition: border-color 0.2s, background 0.2s; }
    .checkbox-item input { width: 20px; height: 20px; margin-right: 11px; accent-color: #bb9944; flex-shrink: 0; }
    .input-inline { display: inline-block; width: 64px !important; padding: 8px !important; border: 1px solid #ccc; border-radius: 8px; margin-left: 5px; font-size: 16px; font-family: inherit; }
    .checkbox-service { color: #003366; border-color: #cfe0ff !important; background: #eef4ff !important; }
    .meal-toggle-box { margin-bottom: 0; }
    .meal-toggle-box .checkbox-item { border-color: #f3c9cb; background: #fff6f6; }
    .bus-hidden-options { background: #eef4ff !important; border-left-color: #003366 !important; }
    .hidden-options { display: none; margin-top: 16px; padding: 16px; background: #fffdf6; border-left: 4px solid #bb9944; border-radius: 11px; }
    .bus-input-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-size: 14px; }
    .bus-input-row:last-child { margin-bottom: 0; }
    .bus-input-row label { width: 150px; font-weight: 600; color: #555; }
    .price-summary { background: linear-gradient(155deg, #313131, #232323); color: #f1f1f1; padding: 22px 18px; border-radius: 16px; margin-top: 20px; }
    .price-row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 11px; font-size: 14px; color: #c9c9c9; }
    .price-row span:last-child { font-weight: 600; color: #fff; }
    .price-row.total { border-top: 1px solid #4a4a4a; padding-top: 16px; margin-top: 13px; margin-bottom: 0; font-size: 1.25rem; font-weight: 800; color: #bb9944; }
    .price-row.total span:last-child { color: #bb9944; }
    .price-row.price-subtotal { border-top: 1px dashed #555; padding-top: 12px; margin-top: 3px; color: #e2e2e2; }
    /* Gönder butonu: altın gradyan */
    .btn-submit { width: 100%; padding: 15px; background: linear-gradient(135deg, #c9a64e, #bb9944); color: #fff; border: none; border-radius: 12px; font-size: 1.05rem; font-weight: 700; cursor: pointer; margin-top: 18px; box-shadow: 0 10px 24px rgba(187,153,68,0.32); transition: background 0.2s, box-shadow 0.2s; }
    .btn-submit:hover, .btn-submit:active { background: linear-gradient(135deg, #bb9944, #9a7d35); }
    .btn-submit:disabled { opacity: 0.65; cursor: not-allowed; }

    /* ---------- B.13 ÖZEL UYARI KUTUSU (mobil) ---------- */
    .custom-alert-overlay { display: none; position: fixed; z-index: 9999; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); justify-content: center; align-items: center; }
    .custom-alert-box { background: #f7f7f7; padding: 30px; border-radius: 15px; text-align: center; box-shadow: 0 10px 40px rgba(0,0,0,0.4); max-width: 400px; width: 90%; animation: weddingAlertPopMobile 0.3s ease-out; }
    @keyframes weddingAlertPopMobile { from { transform: scale(0.8); opacity: 0; } to { transform: scale(1); opacity: 1; } }
    .alert-icon { font-size: 50px; margin-bottom: 20px; display: block; }
    .alert-icon.success { color: #28a745; }
    .alert-icon.error   { color: #dc3545; }
    .alert-title   { font-size: 1.5rem; margin-bottom: 10px; color: #2a2a2a; }
    .alert-message { color: #666; margin-bottom: 20px; line-height: 1.5; font-size: 14px; }
    .alert-btn { background: #2a2a2a; color: #f7f7f7; border: none; padding: 10px 30px; border-radius: 5px; cursor: pointer; font-size: 1rem; transition: 0.3s; }
    .alert-btn:hover { background: #bb9944; }

    /* ---------- B.14 GOOGLE YORUMLARI (mobil) — BÜYÜTÜLMÜŞ 320px kartlar ---------- */
    /* DÜZELTME (mobil): 200px kartlar okunamayacak kadar küçüktü;
       kartlar belirgin ve okunabilir olacak şekilde 320px'e büyütüldü */
    .google-reviews-section { padding: 40px 0 35px; background: #f7f7f7; overflow: hidden; }
    .google-reviews-section .section-title { text-align: center; margin-bottom: 30px; font-size: 22px; color: #bb9944; font-weight: 700; }
    .reviews-track-wrapper { overflow: hidden; }
    .reviews-track { display: flex; gap: 20px; padding: 10px 4px; width: auto; animation: weddingScrollReviewsMobile 32s linear infinite; }
    .review-item { width: 320px; flex-shrink: 0; border-radius: 14px; overflow: hidden; box-shadow: 0 0 15px #bb9944; background: #fff; border: 1px solid #eee; }
    .review-item:hover { transform: translateY(0px); box-shadow: 0 0 15px #bb9944; }
    .review-item img { width: 100%; height: auto; display: block; }
    /* Kayma mesafesi yeni kart genişliğine (320px + 20px ara) göre */
    @keyframes weddingScrollReviewsMobile { 0% { transform: translateX(0); } 100% { transform: translateX(calc(-340px * 6)); } }

    /* ---------- B.15 İLETİŞİM & HARİTA (mobil) ---------- */
    /* DÜZELTME (mobil): kutu masaüstünde açık zemin + altın gölge iken mobilde
       koyu yeşil görünüyordu; renk düzeni ve gölgeler masaüstüyle eşitlendi */
    .home-contact-modern { padding: 30px 0; background: #f7f7f7; }
    .contact-box-modern { background: linear-gradient(135deg, #f7f7f7 0%, #f7f7f7 100%); width: 100%; margin: 0 auto; border-radius: 22px; overflow: hidden; box-shadow: 0 0px 20px #bb9944; border: 1px solid #eee; }
    .contact-info-panel { padding: 30px 20px; }
    .contact-info-panel h2 { font-size: 22px; margin-bottom: 15px; color: #bb9944; font-weight: 700; }
    .info-row { display: flex; align-items: center; margin-bottom: 22px; }
    .info-row i { width: 50px; height: 50px; min-width: 50px; background: rgba(187,153,68,0.15); color: #bb9944; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; margin-right: 20px; }
    .info-row div span { display: block; font-size: 0.8rem; color: #999; text-transform: uppercase; font-weight: bold; letter-spacing: 0.5px; }
    .info-row div p { margin: 0; font-size: 14px; line-height: 1.6; color: #333; font-weight: 500; }
    .contact-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; width: 100%; margin-top: 32px; }
    .btn-action { display: flex; justify-content: center; align-items: center; gap: 9px; width: 100%; padding: 12px 5px; border-radius: 25px; font-weight: bold; transition: transform 0.25s ease, box-shadow 0.25s ease; color: #fff; border: none; cursor: pointer; font-size: 13px; }
    .btn-action i { font-size: 1.1rem; }
    .btn-phone     { background: linear-gradient(to bottom, #66D94E, #1FBE07); }
    .btn-whatsapp  { background: #25D366; }
    .btn-mail      { background: #ea4335; }
    .btn-maps      { background: linear-gradient(135deg, #4A89F3 25%, #55AF7B 45%, #F4B327 70%, #E44A3C 90%); }
    .btn-instagram { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); }
    .btn-facebook  { background: #1877f2; }
    /* DÜZELTME (mobil): harita gölgesi masaüstündeki altın parlamayla eşitlendi */
    .contact-map-window { width: 100%; margin: 18px auto 0; height: 250px; border-radius: 22px; overflow: hidden; box-shadow: 0 0px 20px #bb9944; border: 6px solid #fff; }
    .contact-map-window iframe { width: 100%; height: 100%; border: 0; display: block; }

    /* ---------- B.16 FOOTER (mobil) ---------- */
    /* DÜZELTME (mobil): masaüstündeki altın footer rengi mobilde eksikti */
    footer { text-align: center; padding: 10px; background: #bb9944; color: #f7f7f7; font-size: 0.8rem; margin-top: auto; }

    /* ---------- B.17 KAYDIRMA ANİMASYONLARI (mobil kopya) ---------- */
    .scroll-reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.65s ease-out, transform 0.65s ease-out; }
    .scroll-reveal.visible { opacity: 1; transform: translateY(0); }
    .sr-auto { opacity: 0; transform: translateY(22px); transition: opacity 0.55s ease-out, transform 0.55s ease-out; }
    .sr-auto.visible { opacity: 1; transform: translateY(0); }
}





















/* ################################################################## */
/* #####  BÖLÜM C — KÜÇÜK TELEFON (768px ve altı)                ##### */
/* #####  Mobil bloğunun üzerine eklenen daraltma kuralları      ##### */
/* ################################################################## */
@media (max-width: 768px) {

    /* Hero: 250px yüksekliğe iner */
    .page-hero { height: 250px; }
    .over-hero { margin-top: 250px; }
    /* Başlık: 20px, dar genişlik */
    .hero-text h1 { font-size: 21px; line-height: 1.4; margin: 46px auto 12px auto; width: 100%; max-width: 290px; text-align: center; display: block; }
    .hero-text h1 span { font-size: 21px; display: block; margin-top: 0; }
    /* Buton: 13px */
    .btn-hero { margin: 0 auto; padding: 10px 24px; font-size: 13px; display: inline-block; }

    /* NEDEN başlığı: 18px, negatif margin ile logoya oturur */
    .wedding-why-besyildiz .section-title { font-size: 18px; margin: -43px 0 -85px 0; }
    /* NEDEN kartları: 2 sütun — DÜZELTME (mobil): iç boşluk ve yazı boyutları
       okunabilirlik ve dengeli nefes payı için artırıldı */
    .wedding-why-besyildiz .feature-grid { grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 10px; margin: 0 -10px 40px -10px; }
    .wedding-why-besyildiz .t-feature-item {height:195px; padding: 10px 10px; border-bottom: 4px solid #bb9944; }
    .wedding-why-besyildiz .t-feature-item i { font-size: 1.6rem;margin-top:7px; margin-bottom: 8px; }
    .wedding-why-besyildiz .t-feature-item h3 { font-size: 12px; margin-bottom: 15px; }
    .wedding-why-besyildiz .t-feature-item p { font-size: 11px; line-height: 1.45; padding-top: 0px; padding-bottom: 0px; }

    /* Modal (telefon): karartma boşluğu daraltılır, pencere neredeyse tam ekran */
    .reservation-modal { padding: 10px; }
    .modal-content { max-height: 95vh; border-radius: 16px; }
    .modal-header { padding: 16px 18px; }
    .modal-header::after { left: 18px; width: 46px; }
    .modal-title { font-size: 1.08rem; }
    .close-modal { width: 40px; height: 40px; font-size: 24px; }
    .modal-body { padding: 16px 16px 20px; }
    .form-section { padding: 16px 14px; border-radius: 13px; }
    /* Kişisel bilgiler ve onay kutuları telefonda tek sütuna düşer */
    .wedding-grid-2 { grid-template-columns: 1fr; gap: 14px; }
    .checkbox-grid { grid-template-columns: 1fr; gap: 9px; }
    .phone-group select { width: 84px; }
    .bus-input-row { flex-wrap: wrap; }
    .bus-input-row label { width: auto; flex: 1 1 100%; margin-bottom: 2px; }
    .price-summary { padding: 20px 16px; }
    .price-row { font-size: 13.5px; }
    .price-row.total { font-size: 1.18rem; }
}
