/* Header */
/* Photo placeholders · backgrounds painted by photo-layer.js (Unsplash) */
.ph { background-color: #2C3E2D; background-size: cover; background-position: center; position: relative; transition: opacity .6s ease; }
.ph::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.18) 100%); pointer-events: none; opacity: 0; transition: opacity .4s ease; }
.ph.photo-loaded::after { opacity: 1; }
.ph:not(.photo-loaded) { background-image: linear-gradient(135deg, #5A6B5C 0%, #C9B896 100%); animation: ph-shimmer 2s ease-in-out infinite; }
@keyframes ph-shimmer { 0%,100% { opacity: 0.85; } 50% { opacity: 1; } }
[data-mode="dark"] .ph { background-color: #1A1F1A; }
.ph .photo-label { display: none; }

/* Hero media · no overlay layer needed since photo bg has its own */
.hero-media.ph::after { background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.1) 30%, rgba(0,0,0,0.55) 100%); opacity: 1; }


.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 50; padding: 18px 0; transition: background-color .3s ease, padding .3s ease, border-color .3s ease; }
.site-header.scrolled { background: var(--bg); border-bottom: 1px solid var(--line); padding: 12px 0; }

/* over-hero · sayfa en üstündeyken header arka planı şeffaf, fotoğraf üzerinde
   beyaz metin. scrolled olunca .scrolled kuralı bg'yi cream yapar, metin
   tekrar koyu (default) olur. */
.site-header.over-hero {
  background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0) 100%);
  border-bottom: none;
}
.site-header.over-hero.scrolled {
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.site-header.over-hero:not(.scrolled) .logo-name,
.site-header.over-hero:not(.scrolled) .logo-sub,
.site-header.over-hero:not(.scrolled) .logo-mark,
.site-header.over-hero:not(.scrolled) .primary-nav a,
.site-header.over-hero:not(.scrolled) .lang-toggle {
  color: rgba(250, 246, 238, 0.96);
}
.site-header.over-hero:not(.scrolled) .logo-mark {
  border-color: rgba(250, 246, 238, 0.7);
}
.site-header.over-hero:not(.scrolled) .lang-toggle { color: rgba(250, 246, 238, 0.85); }
.site-header.over-hero:not(.scrolled) .lang-toggle span { color: rgba(250, 246, 238, 0.5); }
.site-header.over-hero:not(.scrolled) .menu-toggle span { background: rgba(250, 246, 238, 0.95); }
.site-header.over-hero:not(.scrolled) .primary-nav a:hover { color: var(--accent-sand); }
/* CTA over-hero · backdrop blur + light border */
.site-header.over-hero:not(.scrolled) .btn-primary {
  background: rgba(250, 246, 238, 0.96);
  color: var(--ink);
}
.site-header.over-hero:not(.scrolled) .btn-primary:hover {
  background: var(--bg);
  color: var(--accent);
}

/* Floating view toggle · tüm sayfalarda mobil/desktop simulasyonu */
.view-toggle-fab {
  position: fixed;
  bottom: 16px;
  right: 16px;
  z-index: 9999;
  display: inline-flex;
  background: rgba(20, 22, 15, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 4px;
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  user-select: none;
}
.view-toggle-fab button {
  padding: 8px 14px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.6);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}
.view-toggle-fab button.on {
  background: var(--bg);
  color: var(--ink);
}
.view-toggle-fab button:hover:not(.on) { color: rgba(255, 255, 255, 0.95); }

/* Body view-mobile · tüm body'i 414 px max-width ile sarar (canvas yerine) */
body.view-mobile { max-width: 414px; margin: 0 auto; box-shadow: 0 0 60px rgba(0, 0, 0, 0.18); min-height: 100vh; background: var(--bg); }
body.view-mobile .site-header { position: absolute; left: auto; right: auto; width: inherit; max-width: 414px; }
@media (max-width: 480px) {
  body.view-mobile { box-shadow: none; max-width: 100%; }
  body.view-mobile .site-header { max-width: 100%; }
}
.header-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.logo { display: flex; align-items: center; gap: 12px; }
.logo-mark { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--ink); display: grid; place-items: center; font-family: var(--serif); font-size: 18px; font-style: italic; }
.logo-word { display: flex; flex-direction: column; line-height: 1; }
.logo-name { font-family: var(--serif); font-size: 20px; letter-spacing: 0.06em; }
.logo-sub { font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em; color: var(--ink-muted); margin-top: 4px; }
.primary-nav { display: flex; gap: 32px; }
.primary-nav a { font-size: 14px; color: var(--ink); position: relative; }
.primary-nav a:hover { color: var(--accent); }
.header-cta { display: flex; align-items: center; gap: 16px; }
.lang-toggle { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; color: var(--ink-muted); }
.lang-toggle span { margin: 0 4px; }
.btn-sm { padding: 10px 18px; font-size: 12px; }
/* Mobile menu toggle · 44x44 touch target, premium hairline frame */
.menu-toggle {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background-color 0.25s ease, border-color 0.25s ease;
  cursor: pointer;
}
.menu-toggle:hover { background: var(--bg); border-color: var(--ink); }
.menu-toggle span {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--ink);
  border-radius: 1px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.menu-toggle.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
/* Over-hero: dark hero photo'da menu-toggle beyaz frame + beyaz çizgi */
.site-header.over-hero:not(.scrolled) .menu-toggle {
  background: rgba(20, 22, 15, 0.35);
  border-color: rgba(250, 246, 238, 0.5);
}
.site-header.over-hero:not(.scrolled) .menu-toggle:hover {
  background: rgba(20, 22, 15, 0.55);
  border-color: rgba(250, 246, 238, 0.85);
}
.site-header.over-hero:not(.scrolled) .menu-toggle span { background: rgba(250, 246, 238, 0.95); }

.mobile-menu { display: none; }

/* Hero · Cinematic — booking bar above-the-fold */
.hero-cinematic { position: relative; min-height: 64vh; padding: 0; display: flex; flex-direction: column; justify-content: flex-end; padding-bottom: 130px; overflow: hidden; }
.hero-media { position: absolute; inset: 0; }
.hero-media::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.40) 0%, rgba(0,0,0,0.10) 35%, rgba(0,0,0,0.62) 100%); }
.hero-overlay { position: absolute; inset: 0; }
.hero-content { position: relative; z-index: 2; color: #FAF6EE; padding-top: 7vh; padding-bottom: 32px; }
.hero-eyebrow { color: rgba(250,246,238,0.9); font-size: 12px; letter-spacing: 0.26em; }
.hero-title { font-size: clamp(46px, 6.4vw, 92px); line-height: 0.98; max-width: 16ch; margin: 18px 0 18px; }
.hero-title em { font-style: italic; opacity: 0.94; }
.hero-sub { max-width: 56ch; font-size: clamp(15px, 1.15vw, 17px); line-height: 1.55; color: rgba(250,246,238,0.92); }
.hero-meta { display: flex; gap: 56px; margin-top: 24px; flex-wrap: wrap; }
.hero-meta > div { display: flex; flex-direction: column; gap: 4px; }
/* Sans-serif tabular numerals — net, oturmuş rakamlar */
.hero-meta strong { font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; font-size: 28px; font-weight: 300; letter-spacing: -0.01em; line-height: 1; color: #FAF6EE; }
.hero-meta strong span { font-size: 13px; opacity: 0.65; margin-left: 3px; font-weight: 400; }
.hero-meta .eyebrow { color: rgba(250,246,238,0.72); font-size: 11px; }

/* Booking Bar — ortalı, kompakt, premium */
.booking-bar { position: absolute; left: 0; right: 0; bottom: 24px; z-index: 3; }
.booking-bar .booking-row { max-width: 1040px; margin: 0 auto; }
.booking-row {
  background: var(--bg);
  border-radius: 14px;
  padding: 6px 6px 6px 28px;
  display: flex;
  align-items: center;
  gap: 0;
  box-shadow: 0 30px 90px rgba(0,0,0,0.22);
  border: 1px solid var(--line-soft);
}
.booking-field { flex: 1; padding: 12px 20px; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.booking-field .eyebrow { font-size: 10px; letter-spacing: 0.24em; line-height: 1; }
.booking-val { font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; font-size: 17px; font-weight: 500; color: var(--ink); letter-spacing: -0.005em; line-height: 1.2; }
.booking-divider { width: 1px; height: 38px; background: var(--line); }
.booking-cta {
  padding: 18px 28px;
  flex-shrink: 0;
  font-size: 12px;
  letter-spacing: 0.08em;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s ease;
}
.booking-cta:hover { transform: translateY(-1px); box-shadow: 0 14px 30px rgba(26,31,26,0.35); }
.booking-cta span { font-size: 16px; margin-left: 6px; }
.booking-perks {
  max-width: 1040px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 32px;
  padding-top: 14px;
  flex-wrap: wrap;
  font-size: 12.5px;
  color: rgba(250,246,238,0.92);
  font-family: var(--sans-body);
  letter-spacing: 0;
  font-weight: 400;
  text-align: center;
}
.booking-perks span { white-space: nowrap; }

/* Hero · Split */
.hero-split { padding-top: 140px; padding-bottom: 180px; }
.hero-split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.hero-split-text h1 { font-size: clamp(48px, 7vw, 96px); margin: 20px 0 28px; }
.hero-split-text h1 em { font-style: italic; }
.hero-split-text > p { font-size: 18px; color: var(--ink-muted); max-width: 40ch; }
.hero-split-actions { display: flex; gap: 16px; margin: 32px 0 48px; flex-wrap: wrap; }
.hero-meta-vertical { flex-direction: column; gap: 16px; margin-top: 40px; }
.hero-meta-vertical > div { flex-direction: row; align-items: baseline; gap: 16px; border-top: 1px solid var(--line); padding-top: 16px; }
.hero-meta-vertical .eyebrow { font-family: var(--serif); font-size: 32px; font-style: italic; color: var(--ink); letter-spacing: 0; text-transform: none; }
.hero-split-media { position: relative; aspect-ratio: 4/5; }
.hero-split-img { position: absolute; inset: 0; width: 75%; height: 100%; border-radius: var(--r-lg); }
.hero-split-img-2 { position: absolute; right: 0; bottom: -40px; width: 50%; aspect-ratio: 1; border-radius: var(--r-lg); border: 8px solid var(--bg); }

/* Hero · Editorial */
.hero-editorial { padding-top: 140px; padding-bottom: 100px; }
.hero-edi-top { display: flex; justify-content: space-between; padding-bottom: 32px; border-bottom: 1px solid var(--line); }
.hero-edi-title { font-size: clamp(72px, 13vw, 200px); line-height: 0.92; display: flex; flex-direction: column; padding: 48px 0; }
.hero-edi-title span:nth-child(2) { align-self: center; }
.hero-edi-title span:nth-child(3) { align-self: flex-end; }
.hero-edi-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 24px; min-height: 480px; }
.hero-edi-img-lg { grid-row: span 2; border-radius: var(--r-lg); }
.hero-edi-text { background: var(--bg-alt); border-radius: var(--r-lg); padding: 32px; display: flex; flex-direction: column; justify-content: space-between; font-size: 16px; }
.hero-edi-img-sm, .hero-edi-img-sm-2 { border-radius: var(--r-lg); }

/* Destination · warm-sand bg for rhythmic break after Promise Band */
.destination {
  background: var(--bg-alt);
  position: relative;
}
.destination::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 64px; height: 1px;
  background: var(--accent);
  opacity: 0.45;
}
.dest-grid { display: grid; grid-template-columns: minmax(0, 5fr) minmax(0, 4fr); gap: clamp(48px, 6vw, 80px); align-items: stretch; }
.dest-text h2 { font-size: clamp(34px, 4.2vw, 56px); font-weight: 300; margin: 14px 0 24px; line-height: 1.06; letter-spacing: -0.015em; }
.dest-text h2 em { font-style: italic; }
.dest-lede { font-size: clamp(15px, 1.1vw, 17px); line-height: 1.65; color: var(--ink-soft); max-width: 46ch; margin-bottom: 44px; }
.dest-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 32px; }
.dest-stats > div { border-top: 1px solid var(--line); padding-top: 18px; }
.dest-stats strong { display: flex; align-items: baseline; gap: 4px; font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; font-size: 32px; font-weight: 400; line-height: 1; margin-bottom: 10px; letter-spacing: -0.015em; color: var(--ink); }
.dest-stats strong .unit { color: var(--ink-muted); }
.dest-stats > div > span { font-size: 14px; color: var(--ink-muted); line-height: 1.4; display: block; }
/* Destination map · text yüksekliğine uyum sağlasın diye aspect-ratio'yu
   kaldırdık; min-height ile minimum boyut, max-height ile üst sınır.
   align-items: stretch ile metin yüksekliğine eşitlenir. */
.dest-map { position: relative; min-height: 440px; max-height: 600px; height: 100%; }
.dest-map-img { position: absolute; inset: 0; border-radius: var(--r-lg); background-position: center; }
.dest-pin { position: absolute; bottom: 24px; left: 24px; right: 24px; background: var(--bg); padding: 16px 20px; border-radius: var(--r-md); display: flex; align-items: center; gap: 16px; }
.pin-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--accent); position: relative; flex-shrink: 0; }
.pin-dot::after { content: ''; position: absolute; inset: -8px; border-radius: 50%; border: 1px solid var(--accent); animation: pulse 2s infinite; }
@keyframes pulse { 0% { transform: scale(1); opacity: 1; } 100% { transform: scale(1.5); opacity: 0; } }
.dest-pin > div { display: flex; flex-direction: column; gap: 2px; }
.dest-pin strong { font-family: var(--serif); font-size: 18px; }

/* Rooms · default cream bg (was bg-alt) — alternation with destination */
.rooms { background: var(--bg); border-top: 1px solid var(--line-soft); }
.rooms-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.room-card { position: relative; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.room-card:hover { transform: translateY(-4px); }
.room-card:hover .room-img { transform: scale(1.02); }
.room-img { aspect-ratio: 3/4; border-radius: var(--r-md); margin-bottom: 20px; transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1); will-change: transform; }
.room-tag { position: absolute; top: 14px; left: 14px; background: var(--bg); padding: 7px 13px; border-radius: 999px; font-family: var(--sans); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; box-shadow: 0 2px 12px rgba(0,0,0,0.08); }
.room-type { font-family: var(--sans); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-muted); }
.room-meta h3 { font-size: 22px; margin-top: 8px; line-height: 1.2; font-weight: 400; }
.room-foot { display: flex; justify-content: space-between; align-items: baseline; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); gap: 12px; }
.room-price { font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; font-size: 16px; font-weight: 500; color: var(--ink); letter-spacing: -0.005em; display: inline-flex; align-items: baseline; gap: 4px; }
.rooms-foot { text-align: center; margin-top: 56px; }

/* Spa */
.spa { background: var(--ink); color: var(--bg); }
.spa .eyebrow { color: rgba(250,246,238,0.6); }
.spa-hero { display: grid; grid-template-columns: minmax(0, 5fr) minmax(0, 4fr); gap: clamp(40px, 5vw, 80px); align-items: end; margin-bottom: clamp(48px, 7vh, 80px); }
.spa-hero-text { display: flex; flex-direction: column; gap: 14px; }
.spa-hero h2 { font-size: clamp(34px, 4.4vw, 56px); font-weight: 300; line-height: 1.06; letter-spacing: -0.015em; margin-top: 4px; color: var(--bg); }
.spa-hero h2 em { font-style: italic; color: var(--accent-sand); }
.spa-hero-lede { font-size: clamp(15px, 1.05vw, 17px); line-height: 1.65; color: rgba(250,246,238,0.78); max-width: 44ch; padding-bottom: 6px; }
.spa-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; margin-bottom: 80px; align-items: stretch; }
.spa-feature { aspect-ratio: 16/10; border-radius: var(--r-lg); }
.spa-numbers { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-content: center; }
.spa-numbers > div { border-top: 1px solid rgba(245,241,232,0.18); padding-top: 18px; }
.spa-numbers strong { display: flex; align-items: baseline; gap: 4px; font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; font-size: 38px; font-weight: 400; line-height: 1.05; color: var(--accent-sand); margin-bottom: 10px; letter-spacing: -0.015em; white-space: nowrap; }
.spa-numbers strong .unit { font-size: 0.5em; opacity: 0.75; font-weight: 400; letter-spacing: 0; }
.spa-numbers > div > span { color: rgba(250,246,238,0.72); font-size: 13.5px; line-height: 1.45; display: block; }
.rituals-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; }
.rituals-head h3 { font-size: 26px; color: var(--bg); font-weight: 400; }
.rituals-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.ritual-img { aspect-ratio: 4/5; border-radius: var(--r-md); margin-bottom: 16px; }
.ritual-meta h4 { font-family: var(--serif); font-size: 19px; margin-bottom: 8px; font-weight: 400; line-height: 1.3; color: var(--bg); }
.ritual-foot { display: flex; gap: 10px; align-items: baseline; font-size: 13px; color: rgba(250,246,238,0.72); font-family: var(--sans-body); font-feature-settings: "tnum" 1, "lnum" 1; }
.ritual-foot strong, .ritual-foot span:last-child { font-weight: 500; color: rgba(250,246,238,0.9); }

/* Gastronomy */
.gastro-grid { display: grid; grid-template-columns: 1fr 1.2fr 0.8fr; gap: 32px; align-items: center; }
.gastro-img-1 { aspect-ratio: 3/4; border-radius: var(--r-lg); }
.gastro-img-2 { aspect-ratio: 3/4; border-radius: var(--r-lg); margin-top: 60px; }
.gastro-text h2 { font-size: clamp(36px, 4.5vw, 60px); font-weight: 300; line-height: 1.06; letter-spacing: -0.015em; margin: 16px 0 22px; }
.gastro-text h2 em { font-style: italic; }
.gastro-text > p { color: var(--ink-soft); font-size: 16px; line-height: 1.65; margin-bottom: 32px; max-width: 44ch; }
.gastro-list { display: flex; flex-direction: column; gap: 0; margin-bottom: 32px; }
.gastro-list > div { display: flex; justify-content: space-between; padding: 16px 0; border-top: 1px solid var(--line); align-items: baseline; gap: 16px; }
.gastro-list > div:last-child { border-bottom: 1px solid var(--line); }
.gastro-list .eyebrow { font-size: 10px; letter-spacing: 0.18em; }

/* Offers */
.offers { background: var(--bg-alt); }
.offers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.offer-card { background: var(--bg); border-radius: var(--r-lg); overflow: hidden; position: relative; transition: transform .35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow .35s ease; box-shadow: 0 1px 0 rgba(26,31,26,0.04); }
.offer-card:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -16px rgba(26,31,26,0.18); }
.offer-img { aspect-ratio: 16/10; }
.offer-tag { position: absolute; top: 16px; left: 16px; background: var(--ink); color: var(--bg); padding: 6px 12px; border-radius: 999px; font-family: var(--sans-body); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500; }
.offer-body { padding: 28px; }
.offer-body h3 { font-size: 24px; font-weight: 400; line-height: 1.2; margin-bottom: 10px; letter-spacing: -0.01em; }
.offer-body p { color: var(--ink-muted); margin-bottom: 24px; font-size: 14px; line-height: 1.55; }
.offer-foot { display: flex; justify-content: space-between; align-items: flex-end; padding-top: 20px; border-top: 1px solid var(--line); gap: 16px; }
.offer-foot > div { display: flex; flex-direction: column; gap: 6px; }
.offer-foot .eyebrow { font-size: 10px; letter-spacing: 0.18em; }

/* Reviews — orantı: skor karta dengeli, açıklamalar okunaklı */
.reviews-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  margin-bottom: 56px;
  gap: 24px;
}
.reviews-head .eyebrow { grid-row: 1; grid-column: 1; align-self: end; padding-bottom: 6px; }
.reviews-head h2 {
  grid-row: 1;
  grid-column: 2;
  font-family: var(--sans-body);
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.02em;
}
.reviews-head h2 .reviews-meta {
  display: block;
  font-family: var(--sans-body);
  font-size: 13px;
  font-weight: 400;
  color: var(--ink-muted);
  letter-spacing: 0.04em;
  margin-top: 6px;
}
.reviews-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 48px; align-items: start; }
.reviews-scores { display: flex; flex-direction: column; gap: 18px; }
.score-row { display: grid; grid-template-columns: 88px 1fr 32px; gap: 16px; align-items: center; font-size: 14px; color: var(--ink-soft); }
.score-bar { height: 5px; background: var(--line); border-radius: 999px; overflow: hidden; }
.score-bar > div { height: 100%; background: var(--accent); transition: width 0.8s cubic-bezier(0.16, 1, 0.3, 1); }
.score-row strong {
  font-family: var(--sans-body);
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-size: 15px;
  font-weight: 500;
  text-align: right;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.review-quote { font-family: var(--serif); font-style: italic; font-size: 19px; line-height: 1.5; color: var(--ink-soft); }
.review-quote p::before { content: '\201C'; }
.review-quote p::after { content: '\201D'; }
.review-quote footer { font-family: var(--sans); font-style: normal; font-size: 12px; color: var(--ink-muted); margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--line); letter-spacing: 0.04em; }
.awards { margin-top: 72px; padding-top: 28px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 18px; }
.awards-row { display: flex; gap: 16px; flex-wrap: wrap; font-family: var(--sans); font-size: 12px; color: var(--ink-muted); letter-spacing: 0.06em; }

/* Journal */
.journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.journal-img { aspect-ratio: 4/3; border-radius: var(--r-md); margin-bottom: 20px; }
.journal-meta h3 { font-size: 22px; margin: 8px 0 16px; }

/* Footer */
.site-footer { background: var(--ink); color: var(--bg); padding: 80px 0 32px; }
.footer-cta { display: flex; justify-content: space-between; align-items: center; padding-bottom: 64px; border-bottom: 1px solid rgba(245,241,232,0.15); margin-bottom: 56px; flex-wrap: wrap; gap: 24px; }
.footer-cta h2 { font-size: clamp(40px, 5vw, 72px); color: var(--bg); }
.footer-cta h2 em { font-style: italic; color: var(--accent-sand); }
.footer-cta .btn-primary { background: var(--bg); color: var(--ink); }
.footer-cta .btn-primary:hover { background: var(--accent-sand); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 56px; }
.footer-grid > div { display: flex; flex-direction: column; gap: 12px; font-size: 14px; }
.footer-grid .eyebrow { color: rgba(245,241,232,0.5); margin-bottom: 8px; }
.footer-grid .logo-name { font-size: 28px; margin-bottom: 12px; }
.footer-grid p { color: rgba(245,241,232,0.7); line-height: 1.7; }
.footer-grid a { color: rgba(245,241,232,0.85); }
.footer-grid a:hover { color: var(--accent-sand); }
.footer-bot { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; border-top: 1px solid rgba(245,241,232,0.15); font-family: var(--mono); font-size: 11px; color: rgba(245,241,232,0.5); letter-spacing: 0.06em; flex-wrap: wrap; gap: 16px; }
.footer-langs { display: flex; gap: 12px; }
.footer-langs span:hover { color: var(--bg); cursor: pointer; }

/* Responsive */
@media (max-width: 960px) {
  .primary-nav { display: none; }
  .menu-toggle { display: flex; }
  .lang-toggle { display: none; }
  /* REZERVASYON CTA mobile'da kalmalı (en kritik conversion) — sadece daha
     kompakt boyuta inelim */
  .header-cta { gap: 10px; }
  .header-cta .btn-primary { padding: 9px 14px; font-size: 11px; letter-spacing: 0.06em; }
  .mobile-menu {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 20px var(--gutter) 28px;
    background: var(--bg);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  }
  .mobile-menu a { font-family: var(--serif); font-size: 20px; padding: 10px 0; border-bottom: 1px solid var(--line-soft); }
  .mobile-menu a:last-of-type { border-bottom: none; }
  .mobile-menu .btn { margin-top: 8px; padding: 14px; font-size: 12px; letter-spacing: 0.08em; justify-content: center; }
  .hero-cinematic { min-height: 88vh; padding-bottom: 280px; }
  .hero-content { padding-top: 22vh; }
  .hero-meta { gap: 24px; }
  .hero-meta strong { font-size: 22px; }
  .booking-row { flex-wrap: wrap; flex-direction: column; align-items: stretch; padding: 14px; }
  .booking-divider { display: none; }
  .booking-field { padding: 14px; border-bottom: 1px solid var(--line); }
  .booking-cta { width: 100%; justify-content: center; margin-top: 6px; }
  .booking-perks { gap: 14px; font-size: 11px; }
  .hero-split-grid { grid-template-columns: 1fr; gap: 48px; }
  .hero-edi-grid { grid-template-columns: 1fr 1fr; }
  .hero-edi-img-lg { grid-row: auto; aspect-ratio: 4/3; }
  .dest-grid { grid-template-columns: 1fr; gap: 48px; }
  .rooms-grid { grid-template-columns: repeat(2, 1fr); }
  .spa-hero { grid-template-columns: 1fr; gap: 24px; }
  .spa-grid { grid-template-columns: 1fr; }
  .rituals-grid { grid-template-columns: repeat(2, 1fr); }
  .gastro-grid { grid-template-columns: 1fr; }
  .gastro-img-2 { display: none; }
  .offers-grid { grid-template-columns: 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }
  .journal-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-cta { flex-direction: column; align-items: flex-start; }
  .section-head { grid-template-columns: 1fr; gap: 18px; align-items: flex-start; }
  .spa-hero { grid-template-columns: 1fr; gap: 24px; align-items: flex-start; }
}

@media (max-width: 520px) {
  .rooms-grid, .rituals-grid, .footer-grid { grid-template-columns: 1fr; }
  .dest-stats { grid-template-columns: 1fr; }
  .spa-numbers { grid-template-columns: 1fr; }
  .hero-edi-grid { grid-template-columns: 1fr; }
  .awards { flex-direction: column; align-items: flex-start; }
}

/* ===========================================================
   Mobile preview wrapper · when user clicks "Mobile" in the
   view switch, .view-mobile applies these rules regardless of
   actual viewport size, so the design renders mobile-correct.
   =========================================================== */
.view-mobile .frame { font-size: 15px; }
.view-mobile .container { padding-left: 20px; padding-right: 20px; }
.view-mobile section { padding-top: 56px; padding-bottom: 56px; }

/* Header · mobile */
.view-mobile .primary-nav,
.view-mobile .lang-toggle,
.view-mobile .header-cta .btn-primary { display: none; }
.view-mobile .menu-toggle { display: flex; }
.view-mobile .site-header { padding: 14px 0; }
.view-mobile .logo-mark { width: 32px; height: 32px; font-size: 15px; }
.view-mobile .logo-name { font-size: 16px; }
.view-mobile .logo-sub { font-size: 8px; }

/* Hero Cinematic · mobile */
.view-mobile .hero-cinematic { min-height: 88vh; padding-bottom: 320px; }
.view-mobile .hero-content { padding-top: 120px; padding-bottom: 32px; }
.view-mobile .hero-title { font-size: 56px; line-height: 0.98; max-width: 100%; margin: 14px 0 18px; }
.view-mobile .hero-sub { font-size: 15px; max-width: 100%; }
.view-mobile .hero-meta { gap: 22px; margin-top: 32px; }
.view-mobile .hero-meta > div { flex: 1 1 40%; min-width: 120px; }
.view-mobile .hero-meta strong { font-size: 22px; }
.view-mobile .hero-meta strong span { font-size: 12px; }
.view-mobile .hero-eyebrow,
.view-mobile .eyebrow { font-size: 10px; }

/* Booking Bar · mobile */
.view-mobile .booking-bar { bottom: 16px; }
.view-mobile .booking-row { flex-direction: column; align-items: stretch; padding: 6px; gap: 0; border-radius: 14px; }
.view-mobile .booking-divider { display: none; }
.view-mobile .booking-field { padding: 12px 14px; border-bottom: 1px solid var(--line); flex-direction: row; justify-content: space-between; align-items: center; }
.view-mobile .booking-field:last-of-type { border-bottom: none; }
.view-mobile .booking-val { font-size: 15px; }
.view-mobile .booking-cta { width: 100%; justify-content: center; margin-top: 6px; padding: 14px; font-size: 13px; }
.view-mobile .booking-perks { gap: 10px; padding: 14px 0 0; font-size: 10px; flex-direction: column; }

/* Hero Split / Editorial · mobile */
.view-mobile .hero-split { padding-top: 100px; padding-bottom: 140px; }
.view-mobile .hero-split-grid { grid-template-columns: 1fr; gap: 36px; }
.view-mobile .hero-split-text h1 { font-size: 48px; }
.view-mobile .hero-editorial { padding-top: 96px; padding-bottom: 60px; }
.view-mobile .hero-edi-top { flex-direction: column; gap: 6px; padding-bottom: 18px; }
.view-mobile .hero-edi-title { font-size: 64px; padding: 28px 0; }
.view-mobile .hero-edi-grid { grid-template-columns: 1fr; grid-template-rows: auto; min-height: 0; gap: 14px; }
.view-mobile .hero-edi-img-lg { grid-row: auto; aspect-ratio: 4/3; }

/* Destination · mobile */
.view-mobile .dest-grid { grid-template-columns: 1fr; gap: 36px; }
.view-mobile .dest-text h2 { font-size: 32px; }
.view-mobile .dest-lede { font-size: 14px; margin-bottom: 28px; }
.view-mobile .dest-stats { grid-template-columns: 1fr 1fr; gap: 16px; }
.view-mobile .dest-stats strong { font-size: 26px; }
.view-mobile .dest-stats span { font-size: 11px; }
.view-mobile .dest-map { aspect-ratio: 4/5; height: auto; min-height: 0; max-height: none; }
.view-mobile .dest-pin { padding: 12px 14px; }
.view-mobile .dest-pin strong { font-size: 14px; }

/* Rooms · mobile */
.view-mobile .rooms-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
.view-mobile .room-img { aspect-ratio: 3/4; margin-bottom: 12px; border-radius: 10px; }
.view-mobile .room-tag { top: 8px; left: 8px; padding: 4px 8px; font-size: 8px; }
.view-mobile .room-meta h3 { font-size: 15px; line-height: 1.2; }
.view-mobile .room-meta .eyebrow { font-size: 9px; }
.view-mobile .room-foot { flex-direction: column; align-items: flex-start; gap: 6px; padding-top: 8px; margin-top: 8px; }
.view-mobile .room-price { font-size: 15px; }
.view-mobile .rooms-foot { margin-top: 32px; }

/* Section heads · mobile */
.view-mobile .section-head { grid-template-columns: 1fr; gap: 16px; align-items: flex-start; }
.view-mobile .section-head h2 { font-size: 32px !important; line-height: 1.06; max-width: 100%; }
.view-mobile .section-head p { font-size: 14px; max-width: 100%; }
.view-mobile h2 { line-height: 1.06; }

/* Promise Band · mobile */
.view-mobile .promise-band { padding: 56px 0 32px; }
.view-mobile .promise-band-grid { grid-template-columns: 1fr; gap: 32px; }
.view-mobile .promise-band-grid::before,
.view-mobile .promise-band-grid::after { display: none; }
.view-mobile .promise-card { padding: 18px 0; border-bottom: 1px solid var(--line-soft); }
.view-mobile .promise-card:last-child { border-bottom: none; }
.view-mobile .promise-headline { font-size: 28px; }
.view-mobile .promise-title { font-size: 24px; }
.view-mobile .promise-desc { font-size: 14px; }
.view-mobile .promise-eyebrow { font-size: 10px; letter-spacing: 0.28em; }

/* Spa · mobile */
.view-mobile .spa-hero { grid-template-columns: 1fr; gap: 18px; margin-bottom: 36px; }
.view-mobile .spa-hero h2 { font-size: 32px; }
.view-mobile .spa-hero-lede { font-size: 14px; max-width: 100%; }
.view-mobile .spa-grid { grid-template-columns: 1fr; gap: 18px; margin-bottom: 48px; }
.view-mobile .spa-numbers { grid-template-columns: 1fr 1fr; gap: 16px; }
.view-mobile .spa-numbers strong { font-size: 32px; }
.view-mobile .rituals-head { flex-direction: column; gap: 12px; align-items: flex-start; }
.view-mobile .rituals-head h3 { font-size: 22px; }
.view-mobile .rituals-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
.view-mobile .ritual-img { aspect-ratio: 4/5; margin-bottom: 10px; border-radius: 10px; }
.view-mobile .ritual-meta h4 { font-size: 14px; }
.view-mobile .ritual-foot { font-size: 11px; }

/* Gastronomy · mobile */
.view-mobile .gastro-grid { grid-template-columns: 1fr; gap: 24px; }
.view-mobile .gastro-img-2 { display: none; }
.view-mobile .gastro-img-1 { aspect-ratio: 4/3; }
.view-mobile .gastro-text h2 { font-size: 36px; margin: 14px 0 18px; }
.view-mobile .gastro-list { gap: 12px; }

/* Offers · mobile */
.view-mobile .offers-grid { grid-template-columns: 1fr; gap: 18px; }
.view-mobile .offer-body { padding: 20px; }
.view-mobile .offer-body h3 { font-size: 21px; }
.view-mobile .offer-body p { font-size: 13px; }
.view-mobile .offer-foot { flex-direction: column; align-items: flex-start; gap: 14px; }
.view-mobile .offer-price { font-size: 16px !important; }
.view-mobile .offer-tag { font-size: 9px; padding: 5px 10px; }

/* Reviews · mobile */
.view-mobile .reviews-head h2 { font-size: 30px !important; }
.view-mobile .reviews-grid { grid-template-columns: 1fr; gap: 24px; }
.view-mobile .reviews-meta { font-size: 14px; }
.view-mobile .review-quote p { font-size: 18px; }
.view-mobile .awards { flex-direction: column; align-items: flex-start; gap: 12px; }
.view-mobile .awards-row { flex-wrap: wrap; gap: 6px; font-size: 11px; }

/* Journal · mobile */
.view-mobile .journal-grid { grid-template-columns: 1fr; gap: 28px; }
.view-mobile .journal-img { aspect-ratio: 4/3; }
.view-mobile .journal-meta h3 { font-size: 18px; }

/* Footer · mobile */
.view-mobile .footer-cta { flex-direction: column; align-items: flex-start; gap: 18px; padding-bottom: 36px; }
.view-mobile .footer-cta h2 { font-size: 32px !important; }
.view-mobile .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
.view-mobile .footer-grid > div:first-child { grid-column: 1 / -1; }
.view-mobile .footer-bot { flex-direction: column; gap: 14px; align-items: flex-start; font-size: 11px; }

/* Smooth-but-tight buttons */
.view-mobile .btn { padding: 12px 18px; font-size: 13px; }
.view-mobile .btn-link { font-size: 13px; }

/* ==========================================================
   Premium polish · Spa numbers, gastro list, offer pricing,
   reviews section. Late cascade so values win cleanly.
   ========================================================== */

/* Spa numbers: hero-grade type, daha düz hizalama */
.spa-numbers strong {
  align-items: baseline;
}
.spa-numbers strong .unit {
  color: rgba(245,241,232,0.55);
  margin-left: 4px;
}
.spa-numbers strong.time-strong { gap: 8px; align-items: baseline; }
.spa-numbers strong.time-strong .unit {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-left: 6px;
  opacity: 0.6;
}

/* Gastro list — premium row interaction */
.gastro-list > div {
  transition: padding-left 0.3s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.3s ease;
}
.gastro-list > div:hover {
  padding-left: 8px;
  border-top-color: var(--accent);
}
.gastro-list .eyebrow {
  color: var(--accent);
}
.gastro-list strong .num {
  color: var(--ink);
}

/* Offer card · premium price + hover pop */
.offer-card {
  isolation: isolate;
}
.offer-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, transparent 50%, rgba(61,74,58,0.04) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: 0;
}
.offer-card:hover::before { opacity: 1; }
.offer-card > * { position: relative; z-index: 1; }
.offer-foot { padding-top: 22px; }
.offer-foot strong .num,
.offer-price .num { color: var(--ink); font-weight: 600; }
.offer-foot .eyebrow { color: var(--accent); }

/* Reviews · daha dramatik headline + büyük italic alıntılar */
.reviews-head h2 {
  font-size: clamp(48px, 6vw, 80px) !important;
  letter-spacing: -0.025em !important;
}
.reviews-head h2 .num {
  letter-spacing: -0.025em;
}
.review-quote {
  font-size: clamp(20px, 1.6vw, 24px);
  line-height: 1.45;
}
.review-quote p {
  position: relative;
  padding-left: 28px;
}
.review-quote p::before {
  content: '\201C';
  position: absolute;
  left: -4px; top: -8px;
  font-size: 56px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.45;
  font-style: normal;
}
.review-quote p::after { content: ''; }

/* Journal cards · subtle premium hover */
.journal-card { transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.journal-card:hover { transform: translateY(-3px); }
.journal-card:hover .journal-img { transform: scale(1.015); }
.journal-img { transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1); will-change: transform; }
.journal-card .btn-link { color: var(--accent); border-bottom-color: var(--accent); }

/* Booking flow · extras price hizalama (font-family override tokens.css'te) */
.bk-extra-price strong { font-size: 22px !important; font-weight: 500; letter-spacing: -0.005em; }

/* Room detail · quick stats premium */
.rd-quick strong { font-weight: 500; letter-spacing: -0.005em; }
.rd-price-row strong { font-size: 28px !important; font-weight: 500; letter-spacing: -0.015em; }

/* Mobile: spa-numbers ve offer-foot tightened */
@media (max-width: 720px) {
  .spa-numbers strong { font-size: 30px; }
  .spa-numbers strong .unit { font-size: 14px; }
  .offer-foot { flex-direction: column; align-items: flex-start; gap: 16px; }
  .offer-foot strong, .offer-price { font-size: 20px !important; }
  .reviews-head h2 { font-size: 38px !important; }
  .review-quote { font-size: 17px; }
  .review-quote p::before { font-size: 40px; top: -4px; }
}
