/* ═══════════════════════════════════════════════════════════
   Elifnur & Efe — Roman Summer Supper
   Stil dosyası
   ═══════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --cream:    #F5F1E8;
  --parchment:#EDE7D5;
  --ink:      #2C2A22;
  --olive:    #4A5240;
  --olive-lt: #6B7560;
  --gold:     #9A7C3A;
  --gold-lt:  #C8A85A;
  --divider:  #C5B99A;
}

html { scroll-behavior: smooth; }

body {
  background: var(--cream);
  color: var(--ink);
  font-family: 'EB Garamond', Georgia, serif;
  font-size: 17px;
  line-height: 1.7;
  overflow-x: hidden;
}

/* ─── HERO ─── */
.hero {
  /* Tek ekranlık poster: vinyet üstte, başlık ortada, panorama altta —
     hepsi pencere yüksekliğine sığsın diye yükseklikler svh ile ölçeklenir */
  height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: clamp(8px, 2svh, 24px);
  padding: clamp(14px, 3.5svh, 44px) 24px;
  position: relative;
  overflow: hidden;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 40% at 50% 100%, rgba(74,82,64,.08) 0%, transparent 70%),
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(154,124,58,.06) 0%, transparent 60%);
  pointer-events: none;
}

/* Üstteki Roma vinyeti (sketch 01) — davetiyedeki gibi başlığın üstünde */
.hero-sketch {
  flex: 0 0 auto;
  width: 100%;
  text-align: center;
  opacity: 0;
  animation: fadeUp .8s ease .1s forwards;
}

.hero-sketch img {
  display: inline-block;
  width: auto;
  height: auto;
  max-width: clamp(200px, 50vw, 320px);
  max-height: clamp(48px, 11svh, 116px);   /* kısa ekranlarda küçülür */
}

/* Geniş ekranda (>1000px): üst eskiz ve tarih rakamı küçülsün, dikey aralıklar sıkışsın */
@media (min-width: 1000px) {
  .hero-sketch img { max-width: clamp(180px, 16vw, 240px); max-height: clamp(44px, 8svh, 88px); }
  /* "Roman Summer Supper" üst eskize biraz yaklaşsın */
  .hero-content { margin-top: clamp(-48px, -5svh, -16px); }
  /* 11 biraz daha küçük; tarih bloğu biraz daha aşağı itilsin */
  .hero-date-block { margin-top: clamp(22px, 5svh, 68px); }
  .hero-date-block .date-num { font-size: clamp(24px, min(4vw, 4.5svh), 44px); }
  /* Tarih iki satır + biraz daha küçük */
  .hero-date-block .date-label { font-size: 12px; letter-spacing: 4px; }
  .hero-date-block .date-label .dl-month,
  .hero-date-block .date-label .dl-day { display: block; }
  .hero-date-block .date-label .dl-sep { display: none; }
}

/* Dar ekranda (<1000px) */
@media (max-width: 999.98px) {
  /* Üstteki Roma eskizi geniş sürümle aynı küçüklükte */
  .hero-sketch img { max-width: clamp(180px, 16vw, 240px); max-height: clamp(44px, 8svh, 88px); }
  /* Üst üç satır eskizin hemen altından başlasın: içeriği ortalamak yerine
     üstten hizala, blok yukarı toplanır → tepedeki boşluk kapanır */
  .hero-content { justify-content: flex-start; margin-top: clamp(-20px, -2svh, -6px); }
  /* Tagline ("Bu mutlu…") ile isimler arasındaki nefes alanı, dikey çizginin
     aşağı uzamasıyla verilir → çizgi yukarıda kısa kalıp altında boşluk bırakmaz */
  .hero-divider { height: clamp(48px, 10svh, 110px); }
  /* İsimler daha büyük; genişlik daraldıkça küçülmesin diye boyut svh'ye dayalı */
  .hero-names .name-efe,
  .hero-names .name-elif { font-size: clamp(56px, min(16.5vw, 13svh), 150px); }
  /* Tarih bloğu en alta itilsin → "11 Temmuz 2026" panoramaya yakın, daha aşağıda */
  .hero-date-block { margin-top: auto; }
  /* "ve" biraz daha büyük; yukarı, Elifnur'a yakın (alta Efe'ye boşluk) */
  .hero-names .name-ve { font-size: clamp(18px, 3vw, 30px); margin-top: clamp(0px, .2svh, 4px); margin-bottom: clamp(6px, 1.2svh, 18px); }
  /* "Temmuz 2026" ve "Cumartesi" iki satıra ayrılsın */
  .hero-date-block .date-label .dl-month,
  .hero-date-block .date-label .dl-day { display: block; }
  .hero-date-block .date-label .dl-sep { display: none; }
}

/* Ortadaki metin bloğu — kalan boşluğu doldurur, içeriğini dikeyde ortalar */
.hero-content {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(6px, 1.5svh, 16px);
  width: 100%;
  /* Panorama akıştan çıktığı için içerik tüm yükseklikte ortalanır;
     bu alt boşluk metnin panorama çizimiyle çakışmamasını sağlar */
  padding-bottom: clamp(110px, 30svh, 340px);
  /* Panoramanın (z-index'siz, alttaki) üstünde kalsın */
  position: relative;
  z-index: 1;
}

.hero-label {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 5px;
  color: var(--gold);
  text-transform: uppercase;
  opacity: 0;
  animation: fadeUp .8s ease .2s forwards;
}

.hero-families {
  font-family: 'Cormorant SC', serif;
  font-size: 13px;
  letter-spacing: 4px;
  color: var(--olive-lt);
  display: flex;
  gap: clamp(20px, 5vw, 48px);
  justify-content: center;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp .8s ease .4s forwards;
}

.hero-tagline {
  font-size: clamp(13px, 1.7svh, 14px);
  letter-spacing: 1.5px;
  line-height: 1.5;
  color: var(--olive-lt);
  font-style: italic;
  max-width: 520px;
  margin: 0 auto;
  opacity: 0;
  animation: fadeUp .8s ease .5s forwards;
}

.hero-divider {
  width: 1px;
  height: clamp(16px, 3.5svh, 40px);
  background: var(--divider);
  margin: 0 auto;
  opacity: 0;
  animation: fadeUp .8s ease .6s forwards;
}

.hero-names {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-style: italic;
  line-height: 1.05;
  color: var(--olive);
  opacity: 0;
  animation: fadeUp 1s ease .7s forwards;
}

/* İsimler hem genişliğe (vw) hem yüksekliğe (svh) göre ölçeklenir */
.hero-names .name-efe,
.hero-names .name-elif { font-size: clamp(34px, min(9.5vw, 8svh), 92px); }
.hero-names .name-ve   { font-size: clamp(15px, 2.6vw, 26px); display: block; margin: clamp(5px, 1.2svh, 16px) 0 clamp(-8px, -.4svh, -3px); color: var(--gold); font-style: italic; font-weight: 400; font-family: 'Cormorant Garamond', serif; text-transform: lowercase; letter-spacing: 1px; opacity: .85; }

.hero-date-block {
  position: relative;
  margin-top: clamp(32px, 7svh, 96px);
  opacity: 0;
  animation: fadeUp .8s ease 1s forwards;
}

/* Tarih ve "11" arkasında, zemin renginde yumuşak (gaussian) hale —
   panoramanın çizgileri tarihin arkasında belirsizleşsin diye.
   z-index:-1 ile metnin arkasında ama panoramanın önünde kalır. */
.hero-date-block::before {
  content: '';
  position: absolute;
  z-index: -1;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 150%;
  height: 165%;
  background: var(--cream);
  border-radius: 50%;
  filter: blur(20px);
  opacity: .8;
  pointer-events: none;
}

.hero-date-block .date-num {
  /* Rakamlar için EB Garamond — bkz. .center-date .num açıklaması */
  font-family: 'EB Garamond', serif;
  font-size: clamp(30px, min(7vw, 6svh), 64px);
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
}

.hero-date-block .date-label {
  font-family: 'Cormorant SC', serif;
  font-size: 13px;
  letter-spacing: 5px;
  color: var(--olive-lt);
  margin-top: clamp(2px, .6svh, 6px);
}


/* ─── PANORAMA (Roma silueti çizimi — sketch 02) ───
   • Zemin mix-blend-mode: darken ile kaldırılır: kremden açık her piksel
     krem zemine düşer (kaybolur), yalnızca çizgiler kalır. multiply zemini
     kremden DAHA koyu yaptığı için (görsel zemini saf beyaz değil) darken
     kullanılıyor.
   • Yükseklik svh ile sınırlandığı için her zaman ekrana sığar; geniş/kısa
     ekranlarda görsel ortalanır (kırpılmaz). */
/* DİKKAT: Buraya opacity/transform (animasyon) EKLEME!
   Bunlar yeni bir "stacking context" oluşturur ve alttaki img'nin
   blend karışımını yalıtır → zemin geri gelir.
   Panorama bu yüzden giriş animasyonu olmadan görünür. */
.hero-panorama {
  /* Akıştan çıkarıldı: artık üstteki metin/flex'leri SIKIŞTIRMAZ.
     Hero'nun en altına sabitlenir, içerik onun üstünde ortalanır.
     DİKKAT: Buraya z-index/opacity/transform EKLEME — stacking context
     oluşturup alttaki img'nin mix-blend karışımını bozar (zemin geri gelir). */
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  text-align: center;
  line-height: 0;
  pointer-events: none;
}

.hero-panorama img {
  display: block;
  /* Tam genişliğe yayılır; yükseklik orana göre artar (geniş ekranda yukarı doğru büyür) */
  width: 100%;
  /* Dar ekranda küçülmek yerine bu boyutta sabit kalır, ortalı olur (taşan kısım kırpılır) */
  min-width: 1400px;
  /* Çok geniş ekranda büyümeyi durdur: 1650px'te sabit, ortalı kalır */
  max-width: 1650px;
  /* Tüm görsel görünür (kırpılmaz); arka planda alttan yukarı doğru uzanır.
     Akıştan çıktığı için yüksekliği metni etkilemez. */
  height: auto;
  /* min-width devreye girip taşınca iki yandan eşit (ortalı) kırpılması için */
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  mix-blend-mode: darken;
}

/* >1650px: panorama büyümeye devam etsin ama aşağı doğru —
   üst (silüet) sabit kalır, artan yükseklik alttan (hero overflow ile) taşar.
   Oran ≈ 7668/2176 = 3.524; alt kaydırma = (büyüyen yükseklik kadar). */
@media (min-width: 1650px) {
  .hero-panorama img { max-width: 93vw; }
  .hero-panorama { bottom: calc((1650px - 100vw) / 30.524); }
}

/* ─── SECTION WRAPPER ─── */
.section {
  max-width: 820px;
  margin: 0 auto;
  padding: 72px 32px;
}

.section-eyebrow {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 5px;
  color: var(--gold);
  text-align: center;
  margin-bottom: 16px;
}

.section-divider {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 auto 56px;
  max-width: 320px;
}

.section-divider::before,
.section-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--divider);
}

.section-divider .diamond {
  width: 6px;
  height: 6px;
  background: var(--gold);
  transform: rotate(45deg);
  flex-shrink: 0;
}

/* ─── EVENT CARDS ─── */
.events-grid {
  display: grid;
  /* Orta sütun (11 Temmuz + zeytin dalı) da yan kartlar kadar geniş olsun */
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  align-items: start;
  margin: 0 -8px;
}

.event-card {
  text-align: center;
  padding: 40px 32px;
}

.event-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 20px;
  color: var(--gold);
}

.event-icon svg { width: 100%; height: 100%; }

/* PNG ikon (örn. vino.png): beyaz zemini krem zemine yedirmek için multiply.
   Kutu diğer ikonlarla aynı (48×48) kalsın diye boyut .event-icon'dan gelir. */
.event-icon--img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}

/* Yüzük ikonu yatay bir görsel: kutu genişletilir (yükseklik 48px sabit) ve
   görsel cover ile büyütülür; çevresindeki boşluk kırpılır. Genişliği buradan
   ayarlayabilirsiniz. */
.event-icon--wide { width: 72px; }
.event-icon--wide img { object-fit: cover; }

/* Kadeh ikonu: kutu yüksekliği 48px sabit kalır, görsel taşarak biraz büyür.
   transform DEĞİL (stacking context blend'i bozar); taşma + flex ortalama.
   Büyüklüğü buradaki height değerinden ayarlayabilirsiniz. */
.event-icon--lg {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}
.event-icon--lg img {
  width: auto;
  height: 58px;
}

.event-title {
  font-family: 'Cormorant SC', serif;
  font-size: 13px;
  letter-spacing: 4px;
  color: var(--olive);
  margin-bottom: 16px;
}

.event-time {
  font-size: 15px;
  color: var(--olive-lt);
  margin-bottom: 4px;
}

.event-venue {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: 24px;
}

.event-address {
  font-size: 14px;
  color: var(--olive-lt);
  font-style: italic;
  line-height: 1.6;
}

.event-address a {
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-lt);
  transition: color .2s, border-color .2s;
}

.event-address a:hover { color: var(--olive); border-color: var(--olive); }

/* Adres bloğu içindeki harita butonu, link alt-çizgisi değil tam çerçeveli
   bir kutu olarak görünür. Alt kenar da divider rengiyle tamamlanır;
   aksi halde .event-address a kuralı alt kenarı eziyordu. */
.event-address .map-btn { border-bottom: 1px solid var(--divider); margin-top: 16px; }
.event-address .map-btn:hover { border-bottom-color: var(--olive); }

.center-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
  border-left: 1px solid var(--divider);
  border-right: 1px solid var(--divider);
  min-height: 280px;
}

.center-date .num {
  /* EB Garamond: Cormorant'ın "1" rakamı "I" gibi göründüğü için
     rakamlar bu fontla yazılıyor (örn. "11" doğru görünsün) */
  font-family: 'EB Garamond', serif;
  font-size: 56px;
  font-weight: 500;
  color: var(--gold);
  line-height: 1;
}

.center-date .month {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-style: italic;
  color: var(--olive);
  margin-top: 4px;
}

.center-date .day {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--olive-lt);
  margin-top: 12px;
}

.center-ornament {
  margin-top: 40px;
}

/* Zeytin dalı (olive.png) — multiply ile zemin krem zemine yedirilir */
.center-ornament img {
  display: block;
  width: auto;
  height: 150px;
  margin: 0 auto;
  mix-blend-mode: multiply;
}

/* ─── MAP BUTTON ─── */
.map-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--olive);
  text-decoration: none;
  border: 1px solid var(--divider);
  padding: 10px 20px;
  transition: background .2s, border-color .2s, color .2s;
  margin-top: 12px;
}

.map-btn:hover {
  background: var(--parchment);
  border-color: var(--olive);
  color: var(--ink);
}

/* ─── RSVP SECTION ─── */
.rsvp-section {
  background: var(--parchment);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}

.rsvp-inner {
  max-width: 640px;
  margin: 0 auto;
  padding: 72px 32px;
  text-align: center;
}

.rsvp-heading {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 300;
  font-style: italic;
  color: var(--olive);
  margin-bottom: 16px;
}

.rsvp-sub {
  font-size: 16px;
  color: var(--olive-lt);
  margin-bottom: 40px;
  font-style: italic;
}

.rsvp-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  text-align: left;
}

.rsvp-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-field label {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--olive-lt);
}

.form-field input,
.form-field select,
.form-field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--divider);
  padding: 10px 2px;
  font-family: 'EB Garamond', serif;
  font-size: 16px;
  color: var(--ink);
  outline: none;
  transition: border-color .2s;
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  border-radius: 0;
}

.form-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7560' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  padding-right: 24px;
  cursor: pointer;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-bottom-color: var(--olive);
}

.form-field textarea {
  resize: vertical;
  min-height: 80px;
}

.rsvp-submit {
  margin-top: 8px;
  padding: 16px 40px;
  background: var(--olive);
  color: var(--cream);
  border: none;
  font-family: 'Cormorant SC', serif;
  font-size: 12px;
  letter-spacing: 4px;
  cursor: pointer;
  transition: background .2s;
  align-self: center;
}

.rsvp-submit:hover { background: var(--ink); }
.rsvp-submit:disabled { opacity: .6; cursor: not-allowed; }

.rsvp-success {
  display: none;
  text-align: center;
  padding: 32px;
  font-style: italic;
  color: var(--olive);
  font-size: 18px;
}

/* ─── FOOTER ─── */
footer {
  text-align: center;
  padding: 56px 24px;
  border-top: 1px solid var(--divider);
}

.footer-monogram {
  font-family: 'Cormorant SC', serif;
  font-size: 28px;
  letter-spacing: 12px;
  color: var(--gold);
  margin-bottom: 24px;
}

.footer-closing {
  font-size: 15px;
  font-style: italic;
  color: var(--olive-lt);
  max-width: 440px;
  margin: 0 auto 24px;
}

.footer-meta {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--divider);
}

/* ─── COUNTDOWN ─── */
.countdown-wrap {
  text-align: center;
  margin-bottom: 56px;
}

.countdown {
  display: inline-flex;
  gap: 32px;
  align-items: flex-end;
}

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

.countdown-unit .n {
  /* Rakamlar için EB Garamond — bkz. .center-date .num açıklaması */
  font-family: 'EB Garamond', serif;
  font-size: 44px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1;
  display: block;
}

.countdown-unit .l {
  font-family: 'Cormorant SC', serif;
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--olive-lt);
  display: block;
  margin-top: 4px;
}

.countdown-sep {
  font-size: 36px;
  color: var(--gold);
  line-height: 1;
  padding-bottom: 8px;
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s ease, transform .8s ease;
}
.reveal.visible {
  opacity: 1;
  transform: none;
}

/* ─── ORNAMENT SVG ─── */
.ornament {
  color: var(--gold);
  margin: 0 auto;
  display: block;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 680px) {
  .events-grid {
    grid-template-columns: 1fr;
  }
  .center-date {
    border-left: none;
    border-right: none;
    border-top: 1px solid var(--divider);
    border-bottom: 1px solid var(--divider);
    min-height: auto;
    padding: 32px 16px;
  }
  .rsvp-row {
    grid-template-columns: 1fr;
  }
  .hero-families { gap: 24px; flex-wrap: wrap; }
}

/* Küçük telefonlarda geri sayımın taşmaması için */
@media (max-width: 480px) {
  .countdown { gap: 14px; }
  .countdown-unit .n { font-size: 32px; }
  .countdown-sep { font-size: 24px; padding-bottom: 6px; }
}

/* ─── PROGRAM / MEKAN BUTONLARI ─── */
.program-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-bottom: 56px;
}

.ghost-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Cormorant SC', serif;
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--olive);
  background: transparent;
  border: 1px solid var(--divider);
  padding: 14px 26px;
  cursor: pointer;
  transition: background .25s, border-color .25s, color .25s;
}

.ghost-btn svg { color: var(--gold); flex-shrink: 0; }

.ghost-btn:hover {
  background: var(--parchment);
  border-color: var(--olive);
  color: var(--ink);
}

/* ─── MODAL ─── */
body.modal-open { overflow: hidden; }

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(44, 42, 34, .55);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
}

.modal-overlay.open {
  opacity: 1;
  visibility: visible;
}

.modal {
  position: relative;
  background: var(--cream);
  border: 1px solid var(--divider);
  box-shadow: 0 24px 60px rgba(44, 42, 34, .28);
  width: 100%;
  max-width: 600px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  transform: translateY(16px) scale(.985);
  transition: transform .35s cubic-bezier(.2, .7, .2, 1);
}

.modal-overlay.open .modal { transform: none; }

/* İçeriden 10px boşlukta ince bir çerçeve — gravür/davetiye hissi */
.modal::before {
  content: '';
  position: absolute;
  inset: 9px;
  border: 1px solid var(--divider);
  opacity: .5;
  pointer-events: none;
  z-index: 1;
}

.modal-close {
  position: absolute;
  top: 13px;
  right: 13px;
  z-index: 3;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--olive-lt);
  cursor: pointer;
  transition: color .2s, transform .25s;
}

.modal-close:hover { color: var(--ink); transform: rotate(90deg); }

.modal-scroll {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 46px 40px 42px;
}

.modal-head { text-align: center; margin-bottom: 36px; }

.modal-eyebrow {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}

.modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-style: italic;
  font-size: clamp(30px, 6vw, 42px);
  color: var(--olive);
  line-height: 1.1;
  margin-bottom: 24px;
}

.modal-head .section-divider { margin-bottom: 0; max-width: 220px; }

/* ─── TIMELINE (Hafta Sonu Programı) ─── */
.timeline { position: relative; }

.timeline::before {
  content: '';
  position: absolute;
  left: 5px;
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: var(--divider);
}

.tl-day {
  font-family: 'Cormorant SC', serif;
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  padding-left: 30px;
  margin: 30px 0 14px;
}

.tl-day:first-child { margin-top: 0; }

.tl-item {
  position: relative;
  padding-left: 30px;
  padding-bottom: 22px;
}

.tl-item:last-child { padding-bottom: 0; }

.tl-dot {
  position: absolute;
  left: 0;
  top: 6px;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--cream);
  border: 1.5px solid var(--gold);
}

.tl-time {
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--olive-lt);
  margin-bottom: 3px;
}

.tl-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 4px;
}

.tl-venue {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 16px;
  color: var(--olive);
  margin-bottom: 6px;
}

.tl-desc {
  font-size: 14.5px;
  color: var(--olive-lt);
  line-height: 1.6;
}

/* ─── PLACES (Önemli Noktalar) ─── */
.places { display: flex; flex-direction: column; }

.place {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(197, 185, 154, .4);
}

.place:first-child { padding-top: 0; }
.place:last-child { border-bottom: none; }

.place-icon {
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  border: 1px solid var(--divider);
  border-radius: 50%;
}

.place-icon svg { width: 22px; height: 22px; }

.place-name {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 20px;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 3px;
}

.place-meta {
  font-size: 13.5px;
  font-style: italic;
  color: var(--olive-lt);
  line-height: 1.5;
}

.places-quote {
  text-align: center;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 19px;
  color: var(--olive);
  line-height: 1.5;
  margin-top: 30px;
  padding-top: 28px;
  border-top: 1px solid var(--divider);
}

/* Modal — küçük ekran */
@media (max-width: 480px) {
  .modal-scroll { padding: 44px 22px 32px; }
  .program-cta { gap: 12px; }
  .ghost-btn { width: 100%; justify-content: center; }
  .modal-title { font-size: 30px; }
}

/* ─── DAVETİYE · 3D KİTAPÇIK (yarım katlama) ─── */
.booklet-section { padding-bottom: 48px; }

.booklet-wrap {
  /* Panel boyutu — açıkken iki panel (2×--pw) ekrana sığsın diye sınırlı */
  --pw: clamp(168px, 44vw, 320px);
  --ph: calc(var(--pw) * 1.4156);   /* görsel oranı 1054×1492 */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
  perspective: 2200px;
  perspective-origin: 50% 42%;
}

.booklet {
  position: relative;
  width: var(--pw);
  height: var(--ph);
  cursor: pointer;
  transform-style: preserve-3d;
  -webkit-tap-highlight-color: transparent;
}

/* Yere düşen yumuşak gölge — açılınca genişler */
.booklet::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -24px;
  width: 76%;
  height: 24px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center, rgba(44, 42, 34, .26) 0%, rgba(44, 42, 34, 0) 72%);
  filter: blur(3px);
  transition: width 1s ease, opacity 1s ease;
  pointer-events: none;
  z-index: -1;
}
.booklet.state-open::after { width: 152%; opacity: .8; }

.booklet-stage {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transition: transform 1s cubic-bezier(.42, .12, .2, 1);
}

.booklet-base {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
}

/* Sol cilt kenarından (spine) açılan kapak */
.booklet-cover {
  position: absolute;
  inset: 0;
  transform-origin: left center;
  transform-style: preserve-3d;
  transform: translateZ(1px) rotateY(0deg);
  transition: transform 1s cubic-bezier(.42, .12, .2, 1);
}

.face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: 3px;
  overflow: hidden;
  background: var(--cream);
  box-shadow: 0 12px 32px rgba(44, 42, 34, .22), 0 3px 10px rgba(44, 42, 34, .14);
}

.face img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.face--back,
.face--inside-left { transform: rotateY(180deg); }

/* Cilt payı (spine) gölgeleri — iç sayfaların ortaya bakan kenarı koyulaşır */
.face--inside-left::after,
.face--inside-right::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 24%;
  pointer-events: none;
}
.face--inside-left::after  { right: 0; background: linear-gradient(to right, rgba(44, 42, 34, 0), rgba(44, 42, 34, .17)); }
.face--inside-right::after { left: 0;  background: linear-gradient(to left,  rgba(44, 42, 34, 0), rgba(44, 42, 34, .17)); }

/* Durumlar */
.booklet.state-open .booklet-stage { transform: translateX(50%); }
.booklet.state-open .booklet-cover { transform: translateZ(1px) rotateY(-180deg); }
.booklet.state-back .booklet-stage { transform: rotateY(180deg); }

.booklet:focus-visible { outline: 2px solid var(--gold); outline-offset: 10px; }

.booklet-hint {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--olive-lt);
  transition: opacity .5s ease;
  animation: bookletHintPulse 2.6s ease-in-out infinite;
}
.booklet-hint svg { color: var(--gold); }
.booklet-wrap.is-playing .booklet-hint { opacity: 0; animation: none; }

@keyframes bookletHintPulse {
  0%, 100% { opacity: .55; }
  50%      { opacity: 1; }
}

/* ─── "Tam ekran görüntüle" butonu ─── */
.booklet-fs-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  background: transparent;
  border: 1px solid var(--divider);
  border-radius: 999px;
  font-family: 'Cormorant SC', serif;
  font-size: 11px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--olive);
  cursor: pointer;
  transition: color .2s, border-color .2s, background .2s;
}
.booklet-fs-btn svg { color: var(--gold); }
.booklet-fs-btn:hover { color: var(--ink); border-color: var(--gold); background: rgba(154, 124, 58, .06); }
.booklet-fs-btn:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }

/* ═══════════════ TAM EKRAN · 3D DAVETİYE GÖRÜNTÜLEYİCİ ═══════════════ */
.book-fs {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  /* Açık iki-panel yayılımı (2×pw) genişliğe, yükseklik ekrana sığacak şekilde.
     dvh destekleyen tarayıcılarda ikinci satır ilkini geçersiz kılar. */
  --pw: min( calc((100vw - 56px) / 2), calc((100vh  - 168px) / 1.4156) );
  --pw: min( calc((100vw - 56px) / 2), calc((100dvh - 168px) / 1.4156) );
  --ph: calc(var(--pw) * 1.4156);
  opacity: 0;
  visibility: hidden;
  transition: opacity .34s ease, visibility .34s ease;
  touch-action: none;
}
.book-fs.open { opacity: 1; visibility: visible; }

.book-fs-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26, 25, 20, .84);
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
}

.book-fs-stage {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: grab;
  /* Açılış animasyonu — modal diliyle uyumlu yumuşak büyüme */
  transform: scale(.94);
  transition: transform .4s cubic-bezier(.2, .7, .2, 1);
}
.book-fs.open .book-fs-stage { transform: scale(1); }
.book-fs-stage.is-grabbing { cursor: grabbing; }

/* Pinch / pan / çift-dokunuş yakınlaştırması bu sarmalayıcıya uygulanır */
.book-fs-zoom {
  transform-origin: center center;
  transform: translate(0px, 0px) scale(1);
  transition: transform .28s cubic-bezier(.2, .7, .2, 1);
  will-change: transform;
}
.book-fs-zoom.is-dragging { transition: none; }

.book-fs-perspective {
  perspective: 2600px;
  perspective-origin: 50% 50%;
}

/* Tam ekrandaki kitapçık ana kitapçık 3B yapısını yeniden kullanır */
.book-fs .booklet { cursor: default; }

/* Kapat + ok düğmeleri */
.book-fs-close,
.book-fs-arrow {
  position: absolute;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(245, 241, 232, .10);
  border: 1px solid rgba(245, 241, 232, .22);
  color: #f3ede0;
  cursor: pointer;
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  transition: background .2s, color .2s, opacity .25s, visibility .25s;
}
.book-fs-close {
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  transition: background .2s, color .2s, transform .25s;
}
.book-fs-close:hover { background: rgba(245, 241, 232, .2); transform: rotate(90deg); }

.book-fs-arrow {
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 50%;
}
.book-fs-prev { left: 16px; }
.book-fs-next { right: 16px; }
.book-fs-arrow:hover { background: rgba(245, 241, 232, .2); }
.book-fs-arrow.is-hidden { opacity: 0; visibility: hidden; pointer-events: none; }

.book-fs-close:focus-visible,
.book-fs-arrow:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }

/* Alt bilgi — sayfa noktaları + ipucu */
.book-fs-foot {
  position: absolute;
  z-index: 3;
  left: 0;
  right: 0;
  bottom: calc(22px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  pointer-events: none;
}
.book-fs-dots { display: inline-flex; gap: 9px; }
.book-fs-dots i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(245, 241, 232, .3);
  transition: background .25s, transform .25s;
}
.book-fs-dots i.active { background: var(--gold); transform: scale(1.25); }
.book-fs-hint {
  font-family: 'Cormorant SC', serif;
  font-size: 10.5px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(245, 241, 232, .6);
}

/* Dokunmatik cihazlarda oklar yerine kaydırma kullanılır */
@media (pointer: coarse) {
  .book-fs-arrow { display: none; }
}

/* Telefonlarda daha geniş kitapçık için kenar boşluğunu azalt */
@media (max-width: 600px) {
  .book-fs {
    --pw: min( calc((100vw - 24px) / 2), calc((100vh  - 140px) / 1.4156) );
    --pw: min( calc((100vw - 24px) / 2), calc((100dvh - 140px) / 1.4156) );
    --ph: calc(var(--pw) * 1.4156);
  }
  .book-fs-close { width: 40px; height: 40px; top: 14px; right: 14px; }
  /* Dar ekranda düğme gerekmez — kitapçığa dokunmak doğrudan açar */
  .booklet-fs-btn { display: none; }
}

/* ─── HARİTA (Mapbox) ─── */
.map-section {
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}

.mapbox-map {
  width: 100%;
  height: clamp(360px, 56vh, 560px);
  background: var(--parchment);
}

/* Mapbox arayüz yazı tipini sitenin tonuna yaklaştır */
.mapbox-map .mapboxgl-ctrl-attrib,
.mapbox-map .mapboxgl-ctrl-attrib a { color: var(--olive-lt); }

/* Mekan baloncukları (popup) — site paletine uydurulmuş */
.mapboxgl-popup-content {
  background: var(--cream);
  border: 1px solid var(--divider);
  border-radius: 4px;
  padding: 12px 16px;
  box-shadow: 0 10px 28px rgba(44, 42, 34, .22);
}
.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip { border-top-color: var(--cream); }
.mapboxgl-popup-anchor-top .mapboxgl-popup-tip { border-bottom-color: var(--cream); }
.mapboxgl-popup-anchor-left .mapboxgl-popup-tip { border-right-color: var(--cream); }
.mapboxgl-popup-anchor-right .mapboxgl-popup-tip { border-left-color: var(--cream); }

.map-popup strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 16px;
  color: var(--ink);
  line-height: 1.25;
}
.map-popup span {
  display: block;
  font-family: 'EB Garamond', serif;
  font-size: 12.5px;
  font-style: italic;
  color: var(--olive-lt);
  margin-top: 3px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
