/* v2.css — Auto-generated by v2-bundle.mjs. DO NOT EDIT. */
/* --- tailwind/themes/tourism/default.css --- */
/* ═══════════════════════════════════════════════════════════════════
   TOURISM — Default Theme — Grand Resort
   V2 tokens per /design-spec-v2.md §1.3–1.5

   FONT NOTES (2026-06 Resort Revamp — editorial serif system):
   - Türkiye resort referansları (NG Hotels: Lora serif başlık + Archivo gövde;
     Regnum: petersburg serif) ortak deseni: SERIF DISPLAY + SANS BODY.
   - Heading → Cormorant Garamond (editorial serif, Aman/Six Senses karakteri).
     Body/UI → Montserrat (netlik). Mono → IBM Plex Mono.
   - Cormorant Garamond + DM Serif Display zaten _Layout.cshtml'de yüklü.
   - Launcher theme-generator DEFAULT_FONTS da serif başlık (Fraunces) yönünde —
     bu sistem onunla hizalı. Kompozisyon token-bağımlı: grand-resort.css
     var(--font-heading)/var(--font-body) kullanır, aile değişse de düzen korunur.
   ═══════════════════════════════════════════════════════════════════ */

/* Font loading: handled via _Layout.cshtml Google Fonts link tag (Cormorant Garamond, DM Serif Display, Montserrat, IBM Plex Mono) */

[data-sector="tourism"] {
  /* ── Color tokens — §1.5 ── */
  --color-bg:            245 240 228;   /* #f5f0e4 warm limestone page bg */
  --color-surface:       238 231 215;   /* #eee7d7 card, elevated section */
  --color-surface-alt:   228 218 198;   /* #e4dac6 section contrast, dune */
  --color-text:           28  24  18;   /* #1c1812 primary body text */
  --color-text-muted:    108  96  72;   /* #6c6048 captions, aged oak */
  --color-heading:        20  18  12;   /* #14120c heading, deeper ink */
  --color-primary:       111  78  31;   /* #6f4e1f deeper bronze — AAA 7.01:1+ on #f5f0e4 bg */
  --color-primary-fg:    245 240 228;   /* #f5f0e4 text on primary */
  --color-accent:         78  95  60;   /* #4e5f3c deep forest ornament */
  --color-border:        210 202 183;   /* #d2cab7 subtle hairline */
  --color-border-strong: 168 155 130;   /* #a89b82 visible border */
  --color-overlay:        20  18  12;   /* scrim base — use /0.45 in usage */
  --color-brass:         168 130  74;   /* #a8824a brass ornament — hairline + frame border */

  /* ── Semantic state tokens — §1.5 ── */
  --color-success:  72 104 58;          /* #486a3a */
  --color-warning: 176 118 28;          /* #b0761c */
  --color-error:   168  48 36;          /* #a83024 */
  --color-info:     52  80 112;         /* #345070 */

  /* ── Font stacks — §1.3 — Editorial serif heading + sans body ──
     Heading: Lora (NG Hotels referansı, okunaklı/dolu serif). Fallback Cormorant. */
  --font-heading: 'Lora', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body:    'Montserrat', 'Inter', -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'IBM Plex Mono', 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --font-accent:  var(--font-mono);
  /* Sans display token — UI yerlerinde serif istenmeyen başlıklar için (nav, ribbon, label) */
  --font-display-sans: 'Montserrat', 'Inter', -apple-system, system-ui, sans-serif;

  /* ── Motion tokens — §1.8 ── */
  --ease-slow:    cubic-bezier(0.22, 1, 0.36, 1);
  --dur-glacier:  2000ms;
  --dur-smooth:   600ms;
  --dur-snap:     180ms;

  /* ── V1-compat aliases ── */
  --color-primary-light:  158 122  62;
  --color-primary-dark:    98  68  24;
  --color-secondary:       78  95  60;
  --color-secondary-light: 108 128  84;
  --color-secondary-dark:   52  64  38;
  --color-accent-light:    108 128  84;
  --color-accent-dark:      52  64  38;
  --color-surface-dark:     20  18  12;
  --color-text-light:      108  96  72;
  --color-text-inverse:    245 240 228;

  --transition-fast:   var(--dur-snap)    var(--ease-slow);
  --transition-base:   var(--dur-smooth)  var(--ease-slow);
  --transition-slow:   var(--dur-glacier) var(--ease-slow);
  --transition-smooth: var(--dur-glacier) var(--ease-slow);

  --radius-sm:   0;
  --radius-md:   0;
  --radius-lg:   0;
  --radius-xl:   0;
  --radius-full: 9999px;

  --shadow-sm: 0 1px 3px rgb(var(--color-primary) / 0.04);
  --shadow-md: 0 8px 30px rgb(var(--color-primary) / 0.07);
  --shadow-lg: 0 16px 48px rgb(var(--color-primary) / 0.09);
  --shadow-xl: 0 24px 64px rgb(var(--color-primary) / 0.11);

  --space-section: 9rem;
  --space-block:   4rem;
  --space-element: 1.25rem;
}


/* --- tailwind/themes/tourism/brand-override.css --- */
/* Auto-generated constrained brand override for Hotel Pia Bella */
/* Overrides ONLY primary/accent/heading; Lumina neutrals preserved. Source: intake brand extraction. */
[data-sector="tourism"] {
  --color-primary:       190 157 16;
  --color-primary-light: 202 175 59;
  --color-primary-dark:  148 122 12;
  --color-primary-fg:    245 240 228;
  --color-accent:        166 149 105;
  --color-accent-light:  182 168 132;
  --color-accent-dark:   129 116 82;
  --font-heading: 'Playfair Display', 'Lora', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
}


/* --- tailwind/themes/tourism/yasmin-bodrum.css --- */
/* ═══════════════════════════════════════════════════════════════════
   TOURISM — Yasmin Bodrum Theme — Mediterranean Blue + Coral
   Logo-aligned palette: slate blue (logo wordmark) + coral (asterisk + BODRUM text).
   Kullanım: Site Settings → theme: "yasmin" (or "yasmin-bodrum")
   Sarman pilot tourism/default ile çalışır, etkilenmez.
   ═══════════════════════════════════════════════════════════════════ */

[data-site-slug="yasminbodrum"][data-sector="tourism"],
[data-theme="yasmin"][data-sector="tourism"] {
  /* ── Page surface — warm limestone korunur (Aman lobby tone) ── */
  --color-bg:            245 240 228;   /* #f5f0e4 page bg */
  --color-surface:       238 231 215;   /* #eee7d7 card */
  --color-surface-alt:   228 218 198;   /* #e4dac6 dune */
  --color-text:           28  24  18;   /* #1c1812 body */
  --color-text-muted:    108  96  72;   /* #6c6048 caption */
  --color-heading:        20  18  12;   /* #14120c ink */

  /* ── PRIMARY — Logo mavisi (Aegean deep blue) ── */
  --color-primary:        47  71  94;   /* #2F475E deep teal slate */
  --color-primary-fg:    245 240 228;   /* #f5f0e4 cream on primary */
  --color-primary-light:  93 110 138;   /* #5D6E8A logo wordmark */
  --color-primary-dark:   25  41  60;   /* #19293C deep navy (hero) */

  /* ── ACCENT — Logo korali (Akdeniz gün batımı) ── */
  --color-accent:        216 104  64;   /* #D86840 coral */
  --color-accent-light:  236 144  96;   /* #ec9060 soft coral */
  --color-accent-dark:   180  80  44;   /* #b4502c deep terracotta */

  /* ── Secondary aliases ── */
  --color-secondary:       47  71  94;
  --color-secondary-light:  93 110 138;
  --color-secondary-dark:   25  41  60;

  /* ── Borders ── */
  --color-border:        210 202 183;   /* #d2cab7 hairline */
  --color-border-strong: 168 155 130;   /* #a89b82 visible border */
  --color-brass:         216 104  64;   /* coral hairline accent */

  /* ── Scrim / overlay (deep navy) ── */
  --color-overlay:        20  30  44;   /* #141e2c navy overlay base */
  --color-surface-dark:   20  30  44;   /* #141e2c hero/footer dark */

  /* ── Semantic states (mavi info) ── */
  --color-success:  72 104  58;
  --color-warning: 216 144  44;   /* coral warning */
  --color-error:   168  48  36;
  --color-info:     93 110 138;   /* logo blue info */

  /* ── Text aliases ── */
  --color-text-light:    108  96  72;
  --color-text-inverse:  245 240 228;

  /* ── Shadows — blue tinted ── */
  --shadow-sm: 0 1px 3px rgb(var(--color-primary) / 0.06);
  --shadow-md: 0 8px 30px rgb(var(--color-primary) / 0.10);
  --shadow-lg: 0 16px 48px rgb(var(--color-primary) / 0.14);
  --shadow-xl: 0 24px 64px rgb(var(--color-primary) / 0.18);
}

/* ── Hero scrim güçlendirme — açık görsel üstünde navbar+logo okunmalı ── */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-hero-scrim,
[data-theme="yasmin"][data-template="grand-resort"] .resort-hero-scrim {
  background:
    /* Top → bottom: darker top for nav, lighter middle, dark bottom for text */
    linear-gradient(180deg,
      rgb(20 30 44 / 0.55) 0%,
      rgb(20 30 44 / 0.20) 18%,
      rgb(20 30 44 / 0.08) 38%,
      rgb(20 30 44 / 0.35) 70%,
      rgb(20 30 44 / 0.75) 100%
    ),
    /* Left → right: dark text overlay zone */
    linear-gradient(90deg,
      rgb(20 30 44 / 0.62) 0%,
      rgb(20 30 44 / 0.28) 30%,
      rgb(20 30 44 / 0.05) 60%,
      rgb(20 30 44 / 0.18) 100%
    );
}

/* ═══════════════════════════════════════════════════════════════════
   NAVBAR — Yasmin için her zaman okunabilir dark glass backdrop
   Hero üzerinde: rgba(navy, 0.42) + blur 10px → her görsel üzerinde net okuma
   Scroll sonrası: rgba(navy, 0.96) + blur 14px → solid karakteri korur
   ═══════════════════════════════════════════════════════════════════ */
[data-site-slug="yasminbodrum"] #site-navbar,
[data-theme="yasmin"] #site-navbar {
  background-color: rgba(20, 30, 44, 0.42) !important;
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  transition: background-color 300ms ease, backdrop-filter 300ms ease;
}

[data-site-slug="yasminbodrum"] #site-navbar.navbar-scrolled,
[data-theme="yasmin"] #site-navbar.navbar-scrolled {
  background-color: rgba(20, 30, 44, 0.96) !important;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

/* Logo + nav text — HER ZAMAN beyaz/cream (scrim'e bağlı değil) */
[data-site-slug="yasminbodrum"] #site-navbar img,
[data-theme="yasmin"] #site-navbar img {
  filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.35));
}

[data-site-slug="yasminbodrum"] #site-navbar .nav-link,
[data-site-slug="yasminbodrum"] #site-navbar .lang-switch-trigger,
[data-site-slug="yasminbodrum"] #site-navbar .nav-brand-text,
[data-site-slug="yasminbodrum"] #site-navbar #menu-toggle span,
[data-theme="yasmin"] #site-navbar .nav-link,
[data-theme="yasmin"] #site-navbar .lang-switch-trigger,
[data-theme="yasmin"] #site-navbar .nav-brand-text {
  color: rgb(245 240 228) !important;          /* cream — high contrast on navy */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  letter-spacing: 0.06em;
  font-weight: 500;
}

/* Nav link hover/active — coral accent */
[data-site-slug="yasminbodrum"] #site-navbar .nav-link:hover,
[data-site-slug="yasminbodrum"] #site-navbar .nav-link.is-active,
[data-theme="yasmin"] #site-navbar .nav-link:hover,
[data-theme="yasmin"] #site-navbar .nav-link.is-active {
  color: rgb(236 144 96) !important;           /* coral light hover */
  text-shadow: 0 1px 4px rgba(216, 104, 64, 0.4);
}

/* Override grand-resort default navbar-scrolled hardcoded green */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-link,
[data-site-slug="yasminbodrum"][data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-brand-text,
[data-site-slug="yasminbodrum"][data-template="grand-resort"] #site-navbar.navbar-scrolled .lang-switch-trigger,
[data-site-slug="yasminbodrum"][data-template="grand-resort"] #site-navbar.navbar-scrolled #menu-toggle {
  color: rgb(245 240 228) !important;          /* cream on dark, override default green */
}

/* ── CTA section ("Tatilinizi Şimdi Planlayın") — hardcoded olive override ── */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-cta .inner-cta-content,
[data-theme="yasmin"][data-template="grand-resort"] .resort-cta .inner-cta-content {
  background: linear-gradient(135deg, rgb(25 41 60) 0%, rgb(20 30 44) 100%);
  border-color: rgb(255 255 255 / 0.12);
}

/* ── btn-primary (Müsaitlik Ara + rezervasyon button) — mavi tonu ── */
[data-site-slug="yasminbodrum"] .btn-primary,
[data-theme="yasmin"] .btn-primary {
  background-color: rgb(47 71 94);
  border-color: rgb(47 71 94);
  color: rgb(245 240 228);
}
[data-site-slug="yasminbodrum"] .btn-primary:hover,
[data-theme="yasmin"] .btn-primary:hover {
  background-color: rgb(25 41 60);
  border-color: rgb(25 41 60);
}

/* ── Resort booking widget (MÜSAİTLİK ARA button vs.) — mavi tonu ── */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-booking-submit,
[data-theme="yasmin"][data-template="grand-resort"] .resort-booking-submit {
  background-color: rgb(47 71 94);
  color: rgb(245 240 228);
}
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-booking-submit:hover,
[data-theme="yasmin"][data-template="grand-resort"] .resort-booking-submit:hover {
  background-color: rgb(25 41 60);
}

/* ── Footer dark band — mavi navy yerine forest green olabilir ── */
[data-site-slug="yasminbodrum"] footer.resort-footer-shell,
[data-theme="yasmin"] footer.resort-footer-shell {
  background-color: rgb(20 30 44) !important;
}

/* ── Hero background fallback (image yokken) ── */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-hero,
[data-theme="yasmin"][data-template="grand-resort"] .resort-hero {
  background: linear-gradient(135deg,
    rgb(25 41 60) 0%,
    rgb(47 71 94) 50%,
    rgb(20 30 44) 100%
  );
}

/* ── H1 text-wrap fix — uzun TR başlık (31ch) 22ch'a sığmıyor ── */
/* "Ege'nin Saklı Koyunda Bir Tatil" → 2 satır temiz (3 satır asla) */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-hero-title,
[data-theme="yasmin"][data-template="grand-resort"] .resort-hero-title {
  max-width: 32ch;                 /* TR uzun başlığa elbow room */
  text-wrap: pretty;               /* balance yerine pretty — orphan kontrol */
}

/* Subtitle eyebrow — kicker uppercase yerine sentence case, Yasmin'in editorial karakteri */
[data-site-slug="yasminbodrum"][data-template="grand-resort"] .resort-hero-kicker,
[data-theme="yasmin"][data-template="grand-resort"] .resort-hero-kicker {
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;        /* eyebrow ironide tutarlı */
  color: rgb(245 240 228 / 0.85);
  font-weight: 500;
}

/* ── Listing card hover — coral bordering + lift ── */
[data-site-slug="yasminbodrum"] .listing-card:hover .listing-card-title,
[data-theme="yasmin"] .listing-card:hover .listing-card-title {
  color: rgb(216 104 64);           /* coral accent */
}

[data-site-slug="yasminbodrum"] .listing-card-link,
[data-theme="yasmin"] .listing-card-link {
  color: rgb(47 71 94);             /* deep blue link */
}

[data-site-slug="yasminbodrum"] .listing-card:hover .listing-card-link,
[data-theme="yasmin"] .listing-card:hover .listing-card-link {
  color: rgb(216 104 64);           /* coral on hover */
}


/* --- tailwind/templates/_base-components.css --- */
/* =============================================================================
   Base Components — Shared across all templates
   All colors via rgb(var(--color-X)) pattern.
   Design reference: McKinsey.com · Aman.com · Linear.app
   Templates override individual properties; they never duplicate these rules.
   ============================================================================= */

/* ---------------------------------------------------------------------------
   1. HERO SECTION  — Aman-style: content anchored to bottom, dramatic overlay
   --------------------------------------------------------------------------- */

.hero-section {
  position: relative;
  overflow: hidden;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  background-color: rgb(var(--color-surface-dark));
  color: rgb(var(--color-text-inverse));
}

/* Multi-stop cinematic gradient — transparent top, heavy at bottom */
.hero-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to bottom,
      transparent 0%,
      rgb(var(--color-surface-dark) / 0.05) 15%,
      rgb(var(--color-surface-dark) / 0.15) 35%,
      rgb(var(--color-surface-dark) / 0.60) 65%,
      rgb(var(--color-surface-dark) / 0.88) 85%,
      rgb(var(--color-surface-dark) / 0.96) 100%
    ),
    radial-gradient(
      ellipse at center,
      transparent 40%,
      rgb(var(--color-surface-dark) / 0.35) 100%
    );
  pointer-events: none;
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-bottom: 12vh;
  width: 100%;
}

.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: rgb(var(--color-text-inverse));
  text-shadow: 0 2px 24px rgb(0 0 0 / 0.25);
}

.hero-subtitle {
  font-family: var(--font-accent, var(--font-body));
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: rgb(var(--color-text-inverse) / 0.80);
  margin-bottom: 1.5rem;
}

/* ---------------------------------------------------------------------------
   2. BUTTONS  — minimal, typographic, editorial
   --------------------------------------------------------------------------- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  font-family: var(--font-accent, var(--font-body));
  font-weight: 500;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.875rem 2rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary {
  background-color: rgb(var(--color-primary));
  color: rgb(var(--color-text-inverse));
  border-color: rgb(var(--color-primary));
}

.btn-primary:hover {
  background-color: rgb(var(--color-primary-dark));
  border-color: rgb(var(--color-primary-dark));
  transform: translateY(-1px) scale(1.01);
  box-shadow: 0 8px 28px rgb(var(--color-primary) / 0.30), var(--shadow-md);
}

/* For dark/image backgrounds */
.btn-outline {
  background-color: transparent;
  color: rgb(var(--color-text-inverse));
  border-color: rgb(var(--color-text-inverse) / 0.30);
}

.btn-outline:hover {
  background-color: rgb(var(--color-text-inverse) / 0.10);
  border-color: rgb(var(--color-text-inverse) / 0.60);
}

/* For light backgrounds */
.btn-outline-light {
  background-color: transparent;
  color: rgb(var(--color-primary));
  border-color: rgb(var(--color-primary));
}

.btn-outline-light:hover {
  background-color: rgb(var(--color-primary));
  color: rgb(var(--color-text-inverse));
  transform: translateY(-1px);
}

/* ---------------------------------------------------------------------------
   3. CARDS  — borderless, shadow-led, slow elegant hover
   --------------------------------------------------------------------------- */

.card {
  background-color: rgb(var(--color-surface));
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition:
    transform 0.5s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover {
  transform: translateY(-8px) scale(1.01);
  box-shadow: var(--shadow-xl);
}

.card img {
  width: 100%;
  display: block;
  object-fit: cover;
  transition: transform 1.2s ease-out;
}

.card:hover img {
  transform: scale(1.04);
}

.card-content {
  padding: 1.5rem;
}

@media (min-width: 1024px) {
  .card-content {
    padding: 2rem;
  }
}

/* ---------------------------------------------------------------------------
   4. SECTIONS  — generous vertical rhythm, centered editorial headings
   --------------------------------------------------------------------------- */

.section {
  padding-top: var(--space-section);
  padding-bottom: var(--space-section);
}

.section-heading {
  text-align: center;
  margin-bottom: 4rem;
}

.section-heading h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 300;
  letter-spacing: -0.01em;
  color: rgb(var(--color-text));
  line-height: 1.15;
}

.section-heading p {
  max-width: 600px;
  margin-inline: auto;
  margin-top: 1.25rem;
  color: rgb(var(--color-text-light));
  font-size: 1rem;
  line-height: 1.8;
}

/* Centered accent rule beneath heading block */
.section-heading::after {
  content: "";
  display: block;
  width: 48px;
  height: 1px;
  background-color: rgb(var(--color-accent));
  margin: 2rem auto 0;
}

/* ---------------------------------------------------------------------------
   5. NAVIGATION  — micro-typography, centered underline animation
   --------------------------------------------------------------------------- */

.nav-link {
  position: relative;
  font-family: var(--font-accent, var(--font-body));
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: inherit;
  text-decoration: none;
  padding: 0.5rem 0;
  transition: color var(--transition-base);
}

.nav-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 1px;
  background-color: rgb(var(--color-accent));
  transition:
    width var(--transition-base),
    left var(--transition-base);
}

.nav-link:hover::after,
.nav-link.active::after {
  width: 100%;
  left: 0;
}

/* ---------------------------------------------------------------------------
   6. STATS  — ultra-light numerals, vertical dividers
   --------------------------------------------------------------------------- */

.stats-section {
  background-color: rgb(var(--color-primary-dark));
  color: rgb(var(--color-text-inverse));
  text-align: center;
  padding-top: var(--space-section);
  padding-bottom: var(--space-section);
}

.stat-value {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 200;
  line-height: 1;
  color: rgb(var(--color-accent));
  font-variant-numeric: tabular-nums;
}

.stat-label {
  font-family: var(--font-accent, var(--font-body));
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(var(--color-text-inverse) / 0.60);
  margin-top: 0.75rem;
}

/* Vertical divider between stat columns */
.stat-divider {
  width: 1px;
  height: 60px;
  background-color: rgb(var(--color-text-inverse) / 0.10);
  align-self: center;
}

/* ---------------------------------------------------------------------------
   7. TESTIMONIALS  — large ghost quote mark, italic editorial quote
   --------------------------------------------------------------------------- */

.testimonial-card {
  position: relative;
  text-align: center;
  padding: 3rem 2.5rem;
  background-color: rgb(var(--color-surface));
  border-radius: var(--radius-xl);
  overflow: hidden;
}

/* Ghost opening quote mark */
.testimonial-card::before {
  content: '\201C';
  position: absolute;
  top: -0.25rem;
  left: 1.5rem;
  font-family: var(--font-heading);
  font-size: 5rem;
  line-height: 1;
  color: rgb(var(--color-accent) / 0.08);
  pointer-events: none;
  user-select: none;
}

.testimonial-card blockquote {
  position: relative;
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-style: italic;
  font-weight: 300;
  line-height: 1.9;
  color: rgb(var(--color-text));
  margin: 0;
}

.testimonial-card .author {
  display: block;
  font-family: var(--font-accent, var(--font-body));
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgb(var(--color-accent));
  margin-top: 2rem;
}

/* ---------------------------------------------------------------------------
   8. CTA BLOCK  — full-bleed gradient, restrained type
   --------------------------------------------------------------------------- */

.cta-section {
  background: linear-gradient(
    135deg,
    rgb(var(--color-primary-dark)) 0%,
    rgb(var(--color-primary)) 100%
  );
  color: rgb(var(--color-text-inverse));
  text-align: center;
  padding: 7rem 2rem;
}

.cta-section h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3.5vw, 2.75rem);
  font-weight: 300;
  letter-spacing: -0.01em;
  color: rgb(var(--color-text-inverse));
}

.cta-section p {
  max-width: 500px;
  margin-inline: auto;
  margin-top: 1.25rem;
  color: rgb(var(--color-text-inverse) / 0.80);
  font-size: 1rem;
  line-height: 1.75;
}

/* ---------------------------------------------------------------------------
   9. GALLERY  — slow-zoom hover, no crop artifacts
   --------------------------------------------------------------------------- */

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background-color: rgb(var(--color-surface-alt));
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1.2s ease-out;
}

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

/* Subtle gradient reveal on hover */
.gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgb(var(--color-surface-dark) / 0.50) 0%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity var(--transition-base);
  pointer-events: none;
}

.gallery-item:hover::after {
  opacity: 1;
}

/* ---------------------------------------------------------------------------
   10. FOOTER  — dark, editorial column headers, restrained links
   --------------------------------------------------------------------------- */

footer {
  /* Virgüllü rgb + var yedeği: inline style yokken bile geçerli değer */
  background-color: rgb(var(--color-primary-dark, 8 47 73));
  color: rgb(var(--color-text-inverse, 253 250 245) / 0.80);
  font-family: var(--font-body);
  font-size: 0.875rem;
  line-height: 1.75;
  padding-top: 5rem;
  padding-bottom: 2rem;
}

footer h3,
footer h4 {
  font-family: var(--font-accent, var(--font-body));
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(var(--color-accent));
  margin-bottom: 1.5rem;
}

footer a {
  color: rgb(var(--color-text-inverse, 253 250 245) / 0.50);
  text-decoration: none;
  transition: color var(--transition-fast);
}

footer a:hover {
  /* İç içe var() rgb() içinde geçersiz sayılabiliyor; üçlü yedek kullan */
  color: rgb(var(--color-accent-light, 236 130 108));
}

.footer-bottom {
  border-top: 1px solid rgb(var(--color-text-inverse, 253 250 245) / 0.08);
  padding-top: 2rem;
  margin-top: 3rem;
  font-size: 0.75rem;
  color: rgb(var(--color-text-inverse, 253 250 245) / 0.40);
}

/* ---------------------------------------------------------------------------
   11. PROSE / RICH TEXT  — reading-optimized, light headings
   --------------------------------------------------------------------------- */

.prose h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 300;
  letter-spacing: -0.01em;
  color: rgb(var(--color-text));
  margin-top: 2.5rem;
  margin-bottom: 1.5rem;
}

.prose p {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.9;
  color: rgb(var(--color-text-light));
  margin-bottom: 1.25rem;
}

.prose strong {
  font-weight: 500;
  color: rgb(var(--color-text));
}

/* ---------------------------------------------------------------------------
   12. UTILITY CLASSES
   --------------------------------------------------------------------------- */

/* Site-wide max-width container */
.container-site {
  max-width: 1400px;
  margin-inline: auto;
  padding-inline: 1.25rem;
}

@media (min-width: 640px) {
  .container-site {
    padding-inline: 2rem;
  }
}

@media (min-width: 1024px) {
  .container-site {
    padding-inline: 3rem;
  }
}

/* Narrow reading container */
.container-narrow {
  max-width: 720px;
  margin-inline: auto;
}

/* Micro-label — category, eyebrow text */
.label {
  font-family: var(--font-accent, var(--font-heading));
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

/* Scroll-reveal animation */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.9s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.9s cubic-bezier(0.4, 0, 0.2, 1);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ---------------------------------------------------------------------------
   Footer — sütun menü linkleri (KEŞFET / DAHA FAZLA)
   Başlıklar <p> üzerinde text-white/* ile görünür; <a> ise çoğunlukla footer a +
   --color-text-inverse ile boyanıyordu. Panel temasında inverse koyu seçilince veya
   Tailwind opacity utility pakette yoksa linkler arka planla aynı tona düşüyordu.
   Özgüllük: footer a.cw-footer-nav-link, tek sınıflı color utility’lerini geçer.
   --------------------------------------------------------------------------- */

footer a.cw-footer-nav-link {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  transition: color 0.2s ease;
}

footer a.cw-footer-nav-link:hover {
  color: rgb(var(--color-accent-light, 236 130 108));
}

footer a.cw-footer-legal-link {
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
}

footer a.cw-footer-legal-link:hover {
  color: rgba(255, 255, 255, 0.92);
}


/* --- tailwind/templates/sector-signatures.css --- */
/* =============================================
   Sector Signature Design System
   Her sektörün kendine özgü atmosferi — token tabanlı, sabit hex minimum
   ============================================= */

/* ---- Shared cinematic helpers ---- */
[data-sector] .spotlight-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  mix-blend-mode: screen;
}

[data-sector] .hero-grid-noise {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.18;
  background-image:
    linear-gradient(to right, rgb(255 255 255 / 0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgb(255 255 255 / 0.06) 1px, transparent 1px);
  background-size: 56px 56px;
}

[data-sector] .section-glass {
  background: rgb(255 255 255 / 0.05);
  border: 1px solid rgb(255 255 255 / 0.14);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ---- Tourism: kıyı editoryal, sıcak–soğuk gradient mesh ---- */
[data-sector="tourism"] body {
  background:
    radial-gradient(1200px 520px at 8% 0%, rgb(var(--color-accent) / 0.14), transparent 58%),
    radial-gradient(1000px 480px at 92% 4%, rgb(var(--color-primary) / 0.12), transparent 55%),
    radial-gradient(900px 400px at 50% 100%, rgb(var(--color-secondary) / 0.06), transparent 60%),
    rgb(var(--color-surface));
}

[data-sector="tourism"] #site-navbar {
  border-bottom: 1px solid rgb(255 255 255 / 0.12);
}

[data-sector="tourism"] #site-navbar.navbar-scrolled {
  /* Parchment (light) scrolled navbar — green nav-link text needs a light bg.
     Sets the --nav-scroll-bg token consumed by the layered base rule in site.css.
     (Token override crosses @layers; a direct !important here would be out-cascaded.) */
  --nav-scroll-bg: 245 240 228;
  box-shadow: 0 16px 40px rgb(var(--color-primary-dark) / 0.12);
}

[data-sector="tourism"] .overlay {
  background:
    linear-gradient(178deg, rgb(var(--color-surface-dark) / 0.12) 0%, rgb(var(--color-surface-dark) / 0.45) 52%, rgb(var(--color-surface-dark) / 0.78) 100%),
    radial-gradient(720px 340px at 50% 100%, rgb(var(--color-accent) / 0.2), transparent 72%);
}

[data-sector="tourism"] .reservation-widget {
  border-radius: 14px;
  border: 1px solid rgb(255 255 255 / 0.22);
  background: linear-gradient(150deg, rgb(255 255 255 / 0.14), rgb(255 255 255 / 0.04));
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 24px 48px rgb(var(--color-primary-dark) / 0.32);
  overflow: hidden;
  gap: 0;
}

[data-sector="tourism"] .reservation-field {
  background: rgb(255 255 255 / 0.05);
  border-right: 1px solid rgb(255 255 255 / 0.12);
  border-bottom: 1px solid rgb(255 255 255 / 0.08);
  min-height: 92px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

[data-sector="tourism"] .reservation-field label {
  color: rgb(255 255 255 / 0.65);
  letter-spacing: 0.14em;
}

[data-sector="tourism"] .reservation-field input,
[data-sector="tourism"] .reservation-field select {
  color: rgb(255 255 255 / 0.96);
  font-size: 15px;
  font-weight: 450;
}

[data-sector="tourism"] .reservation-field input::placeholder {
  color: rgb(255 255 255 / 0.55);
}

[data-sector="tourism"] .reservation-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.7)' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
}

[data-sector="tourism"] .reservation-btn {
  border-radius: 0;
  box-shadow: none;
  min-height: 100%;
  border-left: 1px solid rgb(255 255 255 / 0.14);
  padding-inline: 26px;
}

@media (max-width: 767px) {
  [data-sector="tourism"] .reservation-field {
    border-right: none;
  }

  [data-sector="tourism"] .reservation-btn {
    border-left: none;
    border-top: 1px solid rgb(255 255 255 / 0.14);
    min-height: 60px;
  }
}

[data-sector="tourism"] .menu-nav-link {
  font-size: clamp(18px, 2.1vw, 30px);
  letter-spacing: 0.01em;
}

/* ---- Corporate: kağıt üzerinde ızgara, mürekkep navbar ---- */
[data-sector="corporate"] body {
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0.92), rgb(250 250 249)),
    rgb(var(--color-surface));
}

[data-sector="corporate"] .section,
[data-sector="corporate"] .section-lg {
  position: relative;
}

[data-sector="corporate"] .section::before,
[data-sector="corporate"] .section-lg::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgb(24 24 27 / 0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgb(24 24 27 / 0.04) 1px, transparent 1px);
  background-size: 48px 48px;
}

[data-sector="corporate"] #site-navbar {
  border-bottom: 1px solid rgb(228 228 231 / 0.35);
  background: linear-gradient(180deg, rgb(var(--color-surface-dark) / 0.94), rgb(39 39 42 / 0.88));
}

[data-sector="corporate"] #site-navbar.navbar-scrolled {
  background: linear-gradient(180deg, rgb(var(--color-surface-dark) / 0.98), rgb(39 39 42 / 0.96)) !important;
  box-shadow: 0 14px 36px rgb(0 0 0 / 0.22);
}

[data-sector="corporate"] .overlay {
  background:
    linear-gradient(180deg, rgb(var(--color-surface-dark) / 0.38), rgb(var(--color-surface-dark) / 0.78)),
    radial-gradient(820px 320px at 58% 12%, rgb(var(--color-accent) / 0.22), transparent 72%);
}

[data-sector="corporate"] .nav-link {
  font-weight: 600;
  letter-spacing: 0.08em;
}

[data-sector="corporate"] .btn {
  border-radius: var(--radius-md);
  font-weight: 600;
  letter-spacing: 0.04em;
}

[data-sector="corporate"] .btn-outline-white {
  border-color: rgb(255 255 255 / 0.65);
  color: white !important;
}

[data-sector="corporate"] .btn-outline-white:hover {
  background: white;
  color: rgb(var(--color-text)) !important;
}

[data-sector="corporate"] .card,
[data-sector="corporate"] .feature-card {
  border-radius: var(--radius-lg);
  border: 1px solid rgb(var(--color-border));
  background: linear-gradient(180deg, rgb(255 255 255), rgb(250 250 249));
  box-shadow: 0 16px 40px rgb(24 24 27 / 0.08);
}

[data-sector="corporate"] .card:hover,
[data-sector="corporate"] .feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 52px rgb(24 24 27 / 0.12);
}

[data-sector="corporate"] .section-heading h2 {
  font-weight: 600;
}

[data-sector="corporate"] .inner-cta::before {
  background:
    linear-gradient(125deg, rgb(var(--color-surface-dark) / 0.86), rgb(var(--color-primary) / 0.55)),
    radial-gradient(680px 280px at 82% 18%, rgb(var(--color-accent) / 0.28), transparent 76%);
}

[data-sector="corporate"] .inner-cta-content .label {
  color: rgb(255 255 255 / 0.72) !important;
}

[data-sector="corporate"] .inner-cta-content p {
  color: rgb(255 255 255 / 0.9);
}

[data-sector="corporate"] .form-label {
  color: rgb(var(--color-text-light));
}

[data-sector="corporate"] .form-input {
  border-bottom: 1px solid rgb(var(--color-border));
  color: rgb(var(--color-text));
  background: rgb(255 255 255 / 0.75);
  padding-inline: 10px;
  border-radius: 8px 8px 0 0;
}

[data-sector="corporate"] .form-input::placeholder {
  color: rgb(var(--color-text-light) / 0.85);
}

[data-sector="corporate"] .form-input:focus {
  border-bottom-color: rgb(var(--color-accent));
  background: rgb(255 255 255 / 0.95);
}

[data-sector="corporate"] .footer-newsletter-input {
  background: rgb(255 255 255 / 0.1);
  border-color: rgb(255 255 255 / 0.22);
  color: rgb(255 255 255 / 0.95);
}

[data-sector="corporate"] .footer-newsletter-input::placeholder {
  color: rgb(255 255 255 / 0.65);
}

[data-sector="corporate"] .footer-newsletter-input:focus {
  border-color: rgb(var(--color-accent) / 0.65);
}

[data-sector="corporate"] .footer-newsletter-btn {
  border-radius: var(--radius-md);
  min-height: 52px;
  min-width: 164px;
  box-shadow: 0 10px 24px rgb(0 0 0 / 0.2);
}

/* ---- Landing: koyu funnel (varsayılan tema) ---- */
[data-sector="landing"] body {
  color: rgb(var(--color-text));
  background:
    radial-gradient(1100px 520px at 4% -6%, rgb(var(--color-primary) / 0.16), transparent 56%),
    radial-gradient(980px 460px at 98% 2%, rgb(var(--color-accent) / 0.09), transparent 58%),
    radial-gradient(880px 400px at 50% 112%, rgb(var(--color-primary) / 0.05), transparent 64%),
    rgb(var(--color-surface-dark));
}

[data-sector="landing"] #site-navbar {
  border-bottom: 1px solid rgb(63 63 70 / 0.35);
}

[data-sector="landing"] #site-navbar.navbar-scrolled {
  background: linear-gradient(
    180deg,
    rgb(var(--color-surface-dark) / 0.96),
    rgb(var(--color-surface) / 0.94)
  ) !important;
  box-shadow: 0 18px 44px rgb(0 0 0 / 0.45);
}

[data-sector="landing"] .overlay {
  background:
    linear-gradient(
      180deg,
      rgb(var(--color-surface-dark) / 0.12),
      rgb(var(--color-surface-dark) / 0.78)
    ),
    radial-gradient(560px 280px at 72% 8%, rgb(var(--color-primary) / 0.16), transparent 72%);
}

[data-sector="landing"] h1,
[data-sector="landing"] h2 {
  letter-spacing: -0.03em;
  font-weight: 600;
}

[data-sector="landing"] .btn {
  border-radius: var(--radius-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: 0 10px 28px rgb(var(--color-primary) / 0.22);
}

[data-sector="landing"] .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgb(var(--color-primary) / 0.28);
}

[data-sector="landing"] .stats-bar,
[data-sector="landing"] .feature-card,
[data-sector="landing"] .countdown-item {
  border: 1px solid rgb(63 63 70 / 0.35);
  background: linear-gradient(145deg, rgb(var(--color-surface-alt) / 0.92), rgb(var(--color-surface) / 0.75));
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

[data-sector="landing"] .menu-nav-link {
  font-size: clamp(22px, 2.8vw, 40px);
  letter-spacing: 0.01em;
}

[data-sector="landing"] .home-cinematic {
  border-top: 1px solid rgb(63 63 70 / 0.3);
  border-bottom: 1px solid rgb(63 63 70 / 0.3);
}

/* Landing + açık tema: gövde ve tipografi luxury-light tokenlarına döner */
[data-sector="landing"][data-theme="luxury-light"] body {
  color: rgb(var(--color-text));
  background:
    radial-gradient(900px 420px at 12% -6%, rgb(var(--color-primary) / 0.08), transparent 55%),
    radial-gradient(800px 380px at 88% 4%, rgb(var(--color-accent) / 0.06), transparent 58%),
    rgb(var(--color-surface));
}

[data-sector="landing"][data-theme="luxury-light"] #site-navbar {
  border-bottom: 1px solid rgb(var(--color-border));
  background: rgb(255 255 255 / 0.88);
}

[data-sector="landing"][data-theme="luxury-light"] #site-navbar.navbar-scrolled {
  background: rgb(255 255 255 / 0.95) !important;
  box-shadow: 0 12px 32px rgb(15 23 42 / 0.08);
}

[data-sector="landing"][data-theme="luxury-light"] .stats-bar,
[data-sector="landing"][data-theme="luxury-light"] .feature-card,
[data-sector="landing"][data-theme="luxury-light"] .countdown-item {
  border: 1px solid rgb(var(--color-border));
  background: rgb(var(--color-surface));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

[data-sector="landing"][data-theme="luxury-light"] .overlay {
  background:
    linear-gradient(180deg, rgb(15 23 42 / 0.2), rgb(15 23 42 / 0.55)),
    radial-gradient(520px 260px at 70% 10%, rgb(var(--color-primary) / 0.15), transparent 70%);
}


/* --- tailwind/templates/_blockgrid-tuning.css --- */
/* =============================================================================
   Block grid & sayfa bileşenleri — ince ayar (token uyumu, ritim, hover)
   ============================================================================= */

/* Ortak blok başlığı — alt çizgi section-heading kadar baskın değil */
@layer components {
  .block-heading-wrap {
    @apply text-center mb-12 md:mb-14;
  }

  .block-overline {
    font-family: var(--font-heading);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgb(var(--color-text-light));
    margin-bottom: 0.75rem;
  }

  .block-heading-wrap h2,
  .block-heading-wrap h3 {
    font-family: var(--font-heading);
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.12;
    color: rgb(var(--color-text));
    text-wrap: balance;
  }

  .block-heading-wrap h2::after {
    content: "";
    display: block;
    width: 2.5rem;
    height: 2px;
    margin: 1.25rem auto 0;
    background: linear-gradient(
      90deg,
      transparent,
      rgb(var(--color-accent)),
      transparent
    );
    border-radius: 1px;
  }

  /* CTA: görsel yokken düz renk (inner-cta ::before çakışmasın) */
  .cw-cta-solid {
    position: relative;
    overflow: hidden;
    background: linear-gradient(
      125deg,
      rgb(var(--color-primary-dark)) 0%,
      rgb(var(--color-primary)) 48%,
      rgb(var(--color-accent) / 0.85) 100%
    );
    color: rgb(var(--color-text-inverse));
  }

  .cw-cta-solid::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.12;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 180px 180px;
  }

  /* Testimonial grid — büyük tırnak (::before) olmadan temiz panel */
  .block-testimonial-panel {
    position: relative;
    height: 100%;
    padding: 2rem 1.75rem;
    background: rgb(var(--color-surface));
    border: 1px solid rgb(var(--color-border));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition:
      box-shadow var(--transition-base),
      border-color var(--transition-base),
      transform var(--transition-base);
  }

  .block-testimonial-panel:hover {
    border-color: rgb(var(--color-accent) / 0.35);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
  }

  .block-testimonial-panel .block-quote {
    font-family: var(--font-heading);
    font-size: 1.0625rem;
    line-height: 1.65;
    color: rgb(var(--color-text));
    margin: 0 0 1.5rem;
  }

  @media (min-width: 768px) {
    .block-testimonial-panel .block-quote {
      font-size: 1.125rem;
    }
  }

  .block-testimonial-panel .block-author-row {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgb(var(--color-border));
  }

  .block-testimonial-panel .block-avatar {
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: 600;
    color: rgb(var(--color-text-inverse));
    background: linear-gradient(
      145deg,
      rgb(var(--color-primary)),
      rgb(var(--color-accent))
    );
    border-radius: var(--radius-md);
    flex-shrink: 0;
  }

  /* Inline CTA kartı */
  .cw-cta-inline {
    border-radius: var(--radius-xl);
    border: 1px solid rgb(var(--color-border));
    background: linear-gradient(
      180deg,
      rgb(var(--color-surface)),
      rgb(var(--color-surface-alt) / 0.85)
    );
    box-shadow: var(--shadow-sm);
  }

  /* Floating CTA — kontrastlı çerçeve */
  .cw-cta-floating {
    border-radius: var(--radius-xl);
    background: linear-gradient(
      135deg,
      rgb(var(--color-primary)) 0%,
      rgb(var(--color-primary-dark)) 100%
    );
    color: rgb(var(--color-text-inverse));
    box-shadow:
      var(--shadow-lg),
      0 0 0 1px rgb(255 255 255 / 0.08) inset;
  }

  /* Güven rozetleri — tüm şablonlarda yumuşak hover */
  .trust-badges {
    opacity: 0.48;
    filter: grayscale(1);
    transition:
      opacity var(--transition-base),
      filter var(--transition-slow);
  }

  .trust-badges:hover {
    opacity: 0.82;
    filter: grayscale(0);
  }

  /* Hero scroll göstergesi */
  .hero-scroll-hint {
    border: 1px solid rgb(255 255 255 / 0.35);
    border-radius: 9999px;
    opacity: 0.85;
    transition: opacity var(--transition-base);
  }

  .hero-scroll-hint:hover {
    opacity: 1;
  }

  /* =========================================================================
     Umbraco BlockGrid — layout primitives
     Umbraco sadece DOM iskeletini ve inline custom property'leri yayar
     (--umb-block-grid--grid-columns, --umb-block-grid--item-column-span).
     CSS grid kurallarını biz sağlamalıyız. Bu olmadan tüm blok'lar tek sütun
     (full width) olarak stack olur — stats/pricing/feature grid'leri kırılır.
     ========================================================================= */
  .umb-block-grid {
    display: block;
  }

  .umb-block-grid__layout-container {
    display: grid;
    grid-template-columns: repeat(
      var(--umb-block-grid--grid-columns, 12),
      minmax(0, 1fr)
    );
    gap: 1.5rem;
    width: 100%;
  }

  .umb-block-grid__layout-item {
    min-width: 0;
    grid-column: span
      min(
        var(--umb-block-grid--item-column-span, 12),
        var(--umb-block-grid--grid-columns, 12)
      );
    grid-row: span var(--umb-block-grid--item-row-span, 1);
  }

  /* İç area'lar (nested blockgrid) */
  .umb-block-grid__area-container {
    display: grid;
    grid-template-columns: repeat(
      var(--umb-block-grid--area-grid-columns, 1),
      minmax(0, 1fr)
    );
    gap: 1.25rem;
  }

  .umb-block-grid__area {
    min-width: 0;
    grid-column: span var(--umb-block-grid--area-column-span, 1);
    grid-row: span var(--umb-block-grid--area-row-span, 1);
  }

  /* Mobilde 6 sütundan küçük olmayan blok'lar full-width'e iner */
  @media (max-width: 768px) {
    .umb-block-grid__layout-container {
      gap: 1.25rem;
    }
    .umb-block-grid__layout-item {
      grid-column: 1 / -1;
    }
  }

  /* Tablet: 3 veya 4 sütunluk kartlar 2'li düzene iner, 6+ full-width */
  @media (min-width: 769px) and (max-width: 1023px) {
    .umb-block-grid__layout-item {
      grid-column: span
        min(
          calc(var(--umb-block-grid--item-column-span, 12) * 2),
          var(--umb-block-grid--grid-columns, 12)
        );
    }
  }
}

/* Sektör bazlı ince dokunuşlar */
[data-sector="tourism"] .block-testimonial-panel .block-quote {
  font-style: italic;
  font-weight: 400;
}

.block-heading-wrap.text-left {
  text-align: left;
}

.block-heading-wrap.text-left h2::after {
  margin-left: 0;
  margin-right: auto;
}

[data-sector="landing"] .block-testimonial-panel {
  background: linear-gradient(
    165deg,
    rgb(var(--color-surface-alt) / 0.95),
    rgb(var(--color-surface) / 0.88)
  );
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

[data-sector="landing"][data-theme="luxury-light"] .block-testimonial-panel {
  background: rgb(var(--color-surface));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}


/* --- tailwind/templates/tourism/grand-resort.css --- */
/* =============================================================================
   GRAND RESORT — "A private letter from a place that does not need to advertise itself."
   Reference: Aman Venice · Blackberry Farm
   Spec: /design-spec-v2.md §1.6–1.13
   All colors via rgb(var(--token)) — theme override compatible.
   ============================================================================= */

/* ============ TEMPLATE DESIGN TOKENS ============ */

[data-template="grand-resort"] {
  background-color: rgb(var(--color-bg));
  color:            rgb(var(--color-text));
  font-family:      var(--font-body);

  /* Sharp, no radius */
  --tpl-radius-sm:   0;
  --tpl-radius-md:   0;
  --tpl-radius-lg:   0;
  --tpl-radius-full: 9999px;  /* only for pill utility if ever needed */

  /* Lumina is flat — no elevation shadows on content (radius 0 + hairline borders).
     Floating chrome (booking popover) carries its own explicit shadow. */
  --tpl-shadow-sm: none;
  --tpl-shadow-md: none;
  --tpl-shadow-lg: none;
}

/* ============ LAYOUT PRIMITIVES ============ */

/* Container: 90rem max, desktop 5rem margin */
[data-template="grand-resort"] .container-page {
  max-width:      90rem;
  margin-inline:  auto;
  padding-inline: 5rem;
}

/* Full-bleed breakout */
[data-template="grand-resort"] .full-bleed {
  margin-inline: calc(50% - 50vw);
}

/* Section rhythm — §1.7 */
[data-template="grand-resort"] .section {
  padding-top:    9rem;
  padding-bottom: 9rem;
}

[data-template="grand-resort"] .section-sm {
  padding-top:    6rem;
  padding-bottom: 6rem;
}

/* Block gap — §1.7 */
[data-template="grand-resort"] .block-gap > * + * {
  margin-top: 4rem;
}

/* Element gap */
[data-template="grand-resort"] .element-gap > * + * {
  margin-top: 1.25rem;
}

/* Paragraph gap */
[data-template="grand-resort"] .prose p + p {
  margin-top: 1.75rem;
}

/* ============ TYPOGRAPHY — §1.4 ============ */

[data-template="grand-resort"] h1,
[data-template="grand-resort"] .h1 {
  font-family:              var(--font-heading);
  font-size:                clamp(2.75rem, 1.8rem + 4.6vw, 5.4rem);
  line-height:              0.98;
  letter-spacing:           -0.025em;
  font-weight:              600;
  font-style:               normal;  /* §1.3: general H1 normal; hero-headline class carries italic */
  font-variation-settings:  "opsz" 144;
  font-optical-sizing:      auto;
  color:                    rgb(var(--color-heading));
}

/* Hero headline italic — letter-opening character only */
[data-template="grand-resort"] .hero-headline,
[data-template="grand-resort"] .hero-title {
  font-style: italic;
}

[data-template="grand-resort"] h2,
[data-template="grand-resort"] .h2 {
  font-family:             var(--font-heading);
  font-size:               clamp(1.95rem, 1.3rem + 2.4vw, 3.35rem);
  line-height:             1.1;
  letter-spacing:          -0.02em;
  font-weight:             500;
  font-variation-settings: "opsz" 96;
  font-optical-sizing:     auto;
  color:                   rgb(var(--color-heading));
}

[data-template="grand-resort"] h3,
[data-template="grand-resort"] .h3 {
  font-family:    var(--font-heading);
  font-size:      clamp(1.35rem, 0.95rem + 1.3vw, 2rem);
  line-height:    1.28;
  letter-spacing: -0.01em;
  font-weight:    400;
  color:          rgb(var(--color-heading));
}

[data-template="grand-resort"] h4,
[data-template="grand-resort"] .h4 {
  font-family:    var(--font-body);
  font-size:      clamp(1.125rem, 0.9rem + 1vw, 1.5rem);
  line-height:    1.35;
  letter-spacing: 0em;
  font-weight:    500;
  color:          rgb(var(--color-heading));
}

[data-template="grand-resort"] p,
[data-template="grand-resort"] .body-text {
  font-family:    var(--font-body);
  font-size:      clamp(0.96rem, 0.9rem + 0.18vw, 1.04rem);
  line-height:    1.8;
  letter-spacing: 0.005em;
  font-weight:    400;
  color:          rgb(var(--color-text));
}

[data-template="grand-resort"] .text-small {
  font-family:    var(--font-body);
  font-size:      clamp(0.8125rem, 0.75rem + 0.3vw, 0.9375rem);
  line-height:    1.6;
  letter-spacing: 0.01em;
  font-weight:    400;
  color:          rgb(var(--color-text-muted));
}

[data-template="grand-resort"] .eyebrow,
[data-template="grand-resort"] .overline {
  font-family:    var(--font-mono);
  font-size:      clamp(0.6875rem, 0.65rem + 0.2vw, 0.75rem);
  line-height:    1.4;
  letter-spacing: 0.18em;
  font-weight:    500;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
}

[data-template="grand-resort"] .caption {
  font-family:    var(--font-mono);
  font-size:      clamp(0.6875rem, 0.65rem + 0.2vw, 0.75rem);
  line-height:    1.5;
  letter-spacing: 0.04em;
  font-weight:    400;
  color:          rgb(var(--color-text-muted));
  font-style:     italic;
}

/* ============ NAVBAR ============ */

[data-template="grand-resort"] #site-navbar {
  position:         fixed;
  top:              0;
  left:             0;
  right:            0;
  z-index:          100;
  background:       transparent;
  transition:       background var(--dur-smooth) var(--ease-slow),
                    border-color var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] #site-navbar.navbar-scrolled {
  background:     rgb(var(--color-bg) / 0.94);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom:  1px solid rgb(var(--color-border));
}

[data-template="grand-resort"] #site-navbar .nav-inner {
  height:         80px;
  max-width:      90rem;
  margin-inline:  auto;
  padding-inline: 5rem;
  display:        flex;
  align-items:    center;
  justify-content: space-between;
  transition:     height var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-inner {
  height: 60px;
}

[data-template="grand-resort"] .nav-link {
  font-family:     var(--font-heading);
  font-size:       0.875rem;
  font-weight:     400;
  letter-spacing:  0.04em;
  color:           rgb(var(--color-heading));
  text-decoration: none;
  position:        relative;
  transition:      color var(--dur-snap) var(--ease-slow);
  padding-block:   0.75rem;  /* ~44px vertical hit area — a11y §2.4.5 */
}

/* Underline slides scaleX 0→1 from left — §1.9 */
[data-template="grand-resort"] .nav-link::after {
  content:          '';
  position:         absolute;
  bottom:           -2px;
  left:             0;
  width:            100%;
  height:           1px;
  background:       rgb(var(--color-accent));
  transform:        scaleX(0);
  transform-origin: left center;
  transition:       transform var(--dur-snap) var(--ease-slow);
}

[data-template="grand-resort"] .nav-link:hover::after,
[data-template="grand-resort"] .nav-link.active::after {
  transform: scaleX(1);
}

[data-template="grand-resort"] .nav-link:focus-visible {
  outline:        2.5px solid currentColor;
  outline-offset: 4px;
}

/* ============ HERO COMPOSITION — §1.6 ============ */

/* 100vh full-bleed, stacked layered (image absolute, content overlay) */
[data-template="grand-resort"] .hero-section {
  position:   relative;
  min-height: 100vh;
  min-height: 100dvh;
  overflow:   hidden;
  display:    flex;
  align-items: flex-end;
  padding-top: 80px; /* navbar height offset */
}

[data-template="grand-resort"] .hero-section::after {
  display: none;
}

/* Image — right 70%, bleeds edge */
[data-template="grand-resort"] .hero-image-side {
  position: relative;
  overflow: hidden;
}

[data-template="grand-resort"] .hero-image-side img {
  position:   absolute;
  inset:      0;
  width:      100%;
  height:     100%;
  object-fit: cover;
  object-position: center;
  transform:  none;
  will-change: auto;
  transition: none;
}

/* Remove grain/filter on live hero for cleaner readability */
[data-template="grand-resort"] .hero-image-side::after {
  display: none;
}

/* Keep image largely clean; contrast handled by local text panel */
[data-template="grand-resort"] .hero-image-side::before {
  display: none;
}

/* Text — left 30%, bottom-anchored, 10% overlap with image */
[data-template="grand-resort"] .hero-text-side {
  position:       relative;
  z-index:        3;
  display:        flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 5rem;
  padding-left:   5rem;
  padding-right:  2rem;
  /* 10% overlap via negative margin-right */
  margin-right:   -10%;
}

[data-template="grand-resort"] .hero-text-side::before {
  display: none;
}

[data-template="grand-resort"] .hero-chapter {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
  margin-bottom:  0.5rem;
}

[data-template="grand-resort"] .hero-title {
  font-family:    var(--font-heading);
  font-size:      clamp(3.5rem, 11vw, 7.5rem);
  line-height:    0.95;
  letter-spacing: -0.035em;
  font-weight:    400;
  font-style:     normal;
  color:          rgb(255 255 255 / 0.96);
  text-shadow:    0 2px 12px rgb(0 0 0 / 0.12);
}

[data-template="grand-resort"] .hero-caption {
  font-family:    var(--font-body);
  font-size:      0.9rem;
  font-weight:    400;
  letter-spacing: 0.01em;
  color:          rgb(255 255 255 / 0.9);
  max-width:      44ch;
  margin-top:     1rem;
  font-style:     normal;
  line-height:    1.65;
  opacity:        1;
}

[data-template="grand-resort"] .hero-text-side .eyebrow {
  color: rgb(255 255 255 / 0.84);
  max-width: 30rem;
}

[data-template="grand-resort"] .editorial-page-hero {
  position: relative;
  min-height: 58vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

[data-template="grand-resort"] .editorial-page-hero__content {
  position: relative;
  z-index: 10;
  width: 100%;
  color: white;
  padding: 10rem 0 4.5rem;
}

[data-template="grand-resort"] .editorial-page-copy {
  max-width: 56rem;
}

[data-template="grand-resort"] .editorial-page-copy .eyebrow {
  color: rgb(255 255 255 / 0.86);
  margin-bottom: 1rem;
}

[data-template="grand-resort"] .editorial-page-title {
  color: rgb(255 255 255 / 0.96);
  text-shadow: 0 2px 12px rgb(0 0 0 / 0.12);
}

[data-template="grand-resort"] .editorial-intro {
  max-width: 46rem;
}

[data-template="grand-resort"] .listing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
}

[data-template="grand-resort"] .listing-card {
  display: block;
}

[data-template="grand-resort"] .listing-card-media {
  box-shadow: var(--tpl-shadow-sm);
}

[data-template="grand-resort"] .listing-card-body {
  padding: 1.25rem 0 1.5rem;
  border-bottom: 1px solid rgb(var(--color-border));
}

[data-template="grand-resort"] .listing-card-title {
  margin-bottom: 0.5rem;
  color: rgb(var(--color-heading));
}

[data-template="grand-resort"] .listing-card:hover .listing-card-title {
  color: rgb(var(--color-primary));
}

[data-template="grand-resort"] .listing-card-link {
  color: rgb(var(--color-primary));
}

[data-template="grand-resort"] .listing-card:hover .listing-card-link {
  letter-spacing: 0.2em;
}

[data-template="grand-resort"] .listing-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

[data-template="grand-resort"] .listing-meta-items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 1rem;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(var(--color-text-muted));
}

[data-template="grand-resort"] .listing-price {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 500;
  color: rgb(var(--color-heading));
}

[data-template="grand-resort"] .inner-cta .h2 {
  color: rgb(255 255 255 / 0.96);
}

[data-template="grand-resort"] .inner-cta .body-text {
  max-width: 42rem;
  margin-inline: auto;
}

/* Scroll indicator — §1.6, slow pulse */
[data-template="grand-resort"] .scroll-indicator {
  display:     block;
  width:       24px;
  height:      24px;
  color:       rgb(var(--color-primary));
  margin-top:  2rem;
  animation:   scroll-chevron 3s ease-in-out infinite;
}

@keyframes scroll-chevron {
  0%, 100% { opacity: 0.4; transform: translateY(0); }
  50%       { opacity: 1;   transform: translateY(4px); }
}

/* ============ SIGNATURE ELEMENTS — §1.10 ============ */

/* 1. Roman Numeral Chapter Eyebrow — CSS counter */
[data-template="grand-resort"] main {
  counter-reset: chapter;
}

[data-template="grand-resort"] section.chapter {
  counter-increment: chapter;
}

[data-template="grand-resort"] section.chapter > .chapter-eyebrow::before {
  content:        counter(chapter, upper-roman) " — ";
  font-family:    var(--font-mono);
  font-size:      0.625rem;
  font-weight:    500;
  letter-spacing: 0.30em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
}

[data-template="grand-resort"] .chapter-eyebrow {
  font-family:    var(--font-mono);
  font-size:      0.625rem;
  font-weight:    500;
  letter-spacing: 0.30em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
  display:        flex;
  align-items:    center;
  gap:            1rem;
  margin-bottom:  0.5rem;
}

/* Hairline rule after eyebrow */
[data-template="grand-resort"] .chapter-eyebrow::after {
  content:    '';
  display:    inline-block;
  width:      24px;
  height:     1px;
  background: rgb(var(--color-primary) / 0.6);
  flex-shrink: 0;
}

/* 2. Brass Hairline System — §1.10 */
[data-template="grand-resort"] hr,
[data-template="grand-resort"] .brass-hairline {
  border:         none;
  border-top:     1px solid rgb(var(--color-brass) / 0.6);
  width:          7.5rem;
  margin-inline:  0;   /* indented, never full-width */
  margin-block:   2.5rem;
}

/* 3. Serif Drop-Cap Intro — §1.10 */
[data-template="grand-resort"] p.lede::first-letter {
  float:       left;
  font-family: var(--font-heading);
  font-size:   5.5rem;
  font-weight: 600;
  font-style:  italic;
  line-height: 0.85;
  padding:     0.5rem 0.75rem 0 0;
  color:       rgb(var(--color-primary));
}

/* 4. Embossed Logo Marks — §1.10 */
[data-template="grand-resort"] .logo-mark img,
[data-template="grand-resort"] .partner-logo img,
[data-template="grand-resort"] .press-logo img {
  filter:    grayscale(1) brightness(0.7) sepia(0.15);
  opacity:   0.8;
  transition: opacity var(--dur-snap) var(--ease-slow),
              filter  var(--dur-snap) var(--ease-slow);
}

[data-template="grand-resort"] .logo-mark:hover img,
[data-template="grand-resort"] .partner-logo:hover img,
[data-template="grand-resort"] .press-logo:hover img {
  opacity: 1;
  filter:  grayscale(0.3) brightness(0.85) sepia(0.1);
}

[data-template="grand-resort"] .logo-bar {
  display:  flex;
  gap:      6rem;
  align-items: center;
}

[data-template="grand-resort"] .logo-bar-item:not(:last-child) {
  padding-right:  6rem;
  border-right:   1px solid rgb(var(--color-border));
}

/* 5. Frame-Within-Frame Image Border — §1.10 */
[data-template="grand-resort"] .framed-image {
  position:      relative;
  padding:       0.75rem;
  border:        1px solid rgb(var(--color-brass) / 0.5);  /* bronze outline */
  background:    rgb(var(--color-surface));          /* cream paper frame */
}

[data-template="grand-resort"] .framed-image img {
  display:  block;
  width:    100%;
  height:   100%;
  object-fit: cover;
}

/* ============ CTA PATTERNS — §1.11 ============ */

/* Primary: sharp rectangle, 1px bronze border, serif small-caps */
[data-template="grand-resort"] .btn-primary {
  display:         inline-block;
  background:      transparent;
  color:           rgb(var(--color-primary));
  font-family:     var(--font-heading);
  font-size:       0.75rem;
  font-variant:    small-caps;
  font-weight:     500;
  letter-spacing:  0.15em;
  text-transform:  lowercase;  /* small-caps via font-variant */
  padding:         0.875rem 2rem;
  border:          1px solid rgb(var(--color-primary));
  border-radius:   0;
  text-decoration: none;
  cursor:          pointer;
  position:        relative;
  overflow:        hidden;
  transition:      color var(--dur-smooth) var(--ease-slow);
}

/* Hover: bg fills bronze top-down, label flips cream — §1.11 */
[data-template="grand-resort"] .btn-primary::before {
  content:        '';
  position:       absolute;
  inset:          0;
  background:     rgb(var(--color-primary));
  transform:      scaleY(0);
  transform-origin: top center;
  transition:     transform 400ms var(--ease-slow);
  z-index:        -1;
}

[data-template="grand-resort"] .btn-primary:hover {
  color: rgb(var(--color-primary-fg));
}

[data-template="grand-resort"] .btn-primary:hover::before {
  transform: scaleY(1);
}

[data-template="grand-resort"] .btn-primary:focus-visible {
  outline:        2.5px solid currentColor;
  outline-offset: 4px;
}

[data-template="grand-resort"] .btn-primary:disabled {
  opacity: 0.45;
  cursor:  not-allowed;
}

/* Secondary: text-only small-caps + trailing hairline that extends on hover — §1.11 */
[data-template="grand-resort"] .btn-secondary {
  display:         inline-flex;
  align-items:     center;
  gap:             1rem;
  background:      none;
  border:          none;
  color:           rgb(var(--color-text));
  font-family:     var(--font-heading);
  font-size:       0.75rem;
  font-variant:    small-caps;
  font-weight:     500;
  letter-spacing:  0.15em;
  text-decoration: none;
  cursor:          pointer;
  padding:         0;
}

[data-template="grand-resort"] .btn-secondary::after {
  content:    '';
  display:    inline-block;
  width:      16px;
  height:     1px;
  background: rgb(var(--color-primary));
  transition: width 300ms var(--ease-slow);
  flex-shrink: 0;
}

[data-template="grand-resort"] .btn-secondary:hover::after {
  width: 32px;
}

[data-template="grand-resort"] .btn-secondary:focus-visible {
  outline:        2.5px solid currentColor;
  outline-offset: 4px;
}

/* Tertiary: serif italic link, underline thickens on hover — §1.11 */
[data-template="grand-resort"] .btn-tertiary,
[data-template="grand-resort"] a.link-reserve {
  font-family:         var(--font-heading);
  font-size:           1rem;
  font-style:          italic;
  font-weight:         400;
  color:               rgb(var(--color-text));
  text-decoration:     underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  transition:          text-decoration-thickness var(--dur-snap) var(--ease-slow);
}

[data-template="grand-resort"] .btn-tertiary:hover,
[data-template="grand-resort"] a.link-reserve:hover {
  text-decoration-thickness: 2px;
}

[data-template="grand-resort"] .btn-tertiary:focus-visible,
[data-template="grand-resort"] a.link-reserve:focus-visible {
  outline:        2.5px solid currentColor;
  outline-offset: 4px;
}

/* ============ IMAGE TREATMENT — §1.12 ============ */

[data-template="grand-resort"] .image-wrap {
  overflow:     hidden;
  border-radius: 0;
  position:     relative;
}

[data-template="grand-resort"] .image-wrap img {
  display:      block;
  width:        100%;
  height:       100%;
  object-fit:   cover;
  border-radius: 0;
  transition:   transform var(--dur-glacier) var(--ease-slow),
                filter    var(--dur-glacier) var(--ease-slow);
}

/* Circle cursor on image hover — §1.9 */
[data-template="grand-resort"] .image-hover-gallery:hover {
  cursor: none;
}

[data-template="grand-resort"] .image-hover-gallery:hover img {
  transform: scale(1.03);
  filter:    brightness(1.08);
}

/* Aspect ratios — §1.12: 4:5, 3:2, 1:1. No 16:9. */
[data-template="grand-resort"] .aspect-portrait    { aspect-ratio: 4/5; }
[data-template="grand-resort"] .aspect-landscape   { aspect-ratio: 3/2; }
[data-template="grand-resort"] .aspect-detail      { aspect-ratio: 1/1; }

/* Image caption — serif italic, Roman numeral prefix */
[data-template="grand-resort"] .image-caption {
  font-family:  var(--font-mono);
  font-size:    0.6875rem;
  font-weight:  400;
  letter-spacing: 0.04em;
  font-style:   italic;
  color:        rgb(var(--color-text-muted));
  margin-top:   0.75rem;
}

/* ============ CARDS ============ */

/* A11y: card h3/h4 must use ink token for AA contrast on any card bg — §4.1
   !important required: Tailwind arbitrary-value utility (specificity 0,1,0) needs
   to be overridden reliably without relying on cascade order alone. */
[data-template="grand-resort"] .card h3,
[data-template="grand-resort"] .card h4,
[data-template="grand-resort"] .lp-card-grid h3,
[data-template="grand-resort"] .lp-card-grid h4 {
  color: rgb(var(--color-heading)) !important;
}

[data-template="grand-resort"] .card {
  border:        1px solid rgb(var(--color-border));  /* Lumina flat: hairline, no elevation */
  border-radius: 0;
  box-shadow:    none;
  overflow:      hidden;
  background:    rgb(var(--color-surface));
  transition:    border-color var(--dur-smooth) var(--ease-slow),
                 transform  var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] .card:hover {
  transform:    translateY(-2px);
  border-color: rgb(var(--color-border-strong));  /* affordance via hairline, not shadow */
}

[data-template="grand-resort"] .card img {
  transition: transform var(--dur-glacier) var(--ease-slow);
}

[data-template="grand-resort"] .card:hover img {
  transform: scale(1.03);
}

/* ============ STATS ============ */

[data-template="grand-resort"] .stat-value {
  font-family:         var(--font-heading);
  font-size:           clamp(2.5rem, 5vw, 4rem);
  font-weight:         300;
  line-height:         1;
  letter-spacing:      -0.02em;
  font-variant-numeric: tabular-nums;
  color:               rgb(var(--color-primary));
}

[data-template="grand-resort"] .stat-label {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
  margin-top:     0.5rem;
}

[data-template="grand-resort"] .stat-item:not(:last-child) {
  border-right: 1px solid rgb(var(--color-accent) / 0.2);
}

/* ============ TESTIMONIALS ============ */

[data-template="grand-resort"] blockquote {
  font-family:  var(--font-heading);
  font-style:   italic;
  font-weight:  400;
  font-size:    clamp(1.125rem, 2.5vw, 1.375rem);
  line-height:  1.75;
  letter-spacing: 0.005em;
  border-left:  2px solid rgb(var(--color-primary));
  padding-left: 1.5rem;
  color:        rgb(var(--color-text));
}

/* ============ GALLERY ============ */

[data-template="grand-resort"] .gallery-item {
  overflow:     hidden;
  border-radius: 0;
  position:     relative;
}

[data-template="grand-resort"] .gallery-item img {
  transition: transform var(--dur-glacier) var(--ease-slow);
  display:    block;
  width:      100%;
}

[data-template="grand-resort"] .gallery-item:hover img {
  transform: scale(1.03);  /* Consistent with image-hover-gallery spec */
}

[data-template="grand-resort"] .gallery-item:focus-visible {
  outline:        2.5px solid rgb(var(--color-primary));
  outline-offset: 3px;
}

/* Vignette on hover */
[data-template="grand-resort"] .gallery-item::after {
  content:    '';
  position:   absolute;
  inset:      0;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 55%, rgb(0 0 0 / 0.15) 100%);
  opacity:    0;
  transition: opacity var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] .gallery-item:hover::after {
  opacity: 1;
}

/* ============ FOOTER — 4col ============ */

[data-template="grand-resort"] footer {
  background:  rgb(var(--color-surface-dark));
  border-top:  1px solid rgb(var(--color-primary) / 0.15);
  padding-top: 5rem;
}

[data-template="grand-resort"] footer .footer-grid {
  max-width:      90rem;
  margin-inline:  auto;
  padding-inline: 5rem;
  display:        grid;
  grid-template-columns: repeat(4, 1fr);
  gap:            3rem;
}

[data-template="grand-resort"] footer h3,
[data-template="grand-resort"] footer h4 {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
  margin-bottom:  1rem;
}

[data-template="grand-resort"] footer a {
  font-size:    0.875rem;
  font-weight:  300;
  color:        rgb(var(--color-text-inverse) / 0.62);
  transition:   color var(--dur-snap) var(--ease-slow);
  text-decoration: none;
}

[data-template="grand-resort"] footer a:hover {
  color: rgb(var(--color-primary));
}

[data-template="grand-resort"] footer a:focus-visible {
  outline:        2.5px solid rgb(var(--color-primary));
  outline-offset: 3px;
}

[data-template="grand-resort"] footer a.cw-footer-nav-link {
  color: rgb(255 255 255 / 0.82);
}

[data-template="grand-resort"] footer a.cw-footer-nav-link:hover {
  color: rgb(var(--color-primary));
}

[data-template="grand-resort"] footer a.cw-footer-legal-link {
  color: rgb(255 255 255 / 0.5);
}

[data-template="grand-resort"] footer a.cw-footer-legal-link:hover {
  color: rgb(255 255 255 / 0.88);
}

[data-template="grand-resort"] .footer-bottom {
  max-width:        90rem;
  margin-inline:    auto;
  padding-inline:   5rem;
  padding-block:    1.5rem;
  border-top:       1px solid rgb(255 255 255 / 0.06);
  margin-top:       4rem;
  display:          flex;
  justify-content:  space-between;
  align-items:      center;
  font-family:      var(--font-mono);
  font-size:        0.6875rem;
  letter-spacing:   0.06em;
  color:            rgb(255 255 255 / 0.72);
}

/* ============ FORM ============ */

[data-template="grand-resort"] .form-input {
  border-radius:   0;
  border:          none;
  border-bottom:   1px solid rgb(var(--color-primary) / 0.30);
  background:      transparent;
  color:           rgb(var(--color-text));
  font-family:     var(--font-body);
  padding:         0.75rem 0.25rem;
  transition:      border-color var(--dur-snap) var(--ease-slow);
  width:           100%;
}

[data-template="grand-resort"] .form-input:focus {
  outline:       none;
  border-bottom-color: rgb(var(--color-primary));
}

[data-template="grand-resort"] .form-input:focus-visible {
  outline:        2.5px solid rgb(var(--color-primary));
  outline-offset: 2px;
}

/* ============ MOTION — §1.8 ============ */

/* Hero text: line-by-line stagger via --delay CSS var on each line */
[data-template="grand-resort"] .reveal-line {
  opacity:    0;
  transform:  translateY(1.5rem);
  transition: opacity   var(--dur-smooth) var(--ease-slow),
              transform var(--dur-smooth) var(--ease-slow);
  transition-delay: var(--delay, 0ms);
}

[data-template="grand-resort"] .reveal-line.is-visible {
  opacity:   1;
  transform: translateY(0);
}

/* Image reveal: clip-path glacier — §1.8 */
[data-template="grand-resort"] .reveal-clip {
  clip-path:  inset(0 100% 0 0);
  transition: clip-path var(--dur-glacier) var(--ease-slow);
}

[data-template="grand-resort"] .reveal-clip.is-visible {
  clip-path: inset(0 0% 0 0);
}

/* General scroll reveal */
[data-template="grand-resort"] .reveal-on-scroll {
  opacity:    0;
  transform:  translateY(1.5rem);
  transition: opacity   var(--dur-smooth) var(--ease-slow),
              transform var(--dur-smooth) var(--ease-slow);
  transition-delay: var(--delay, 0ms);
}

[data-template="grand-resort"] .reveal-on-scroll.is-visible {
  opacity:   1;
  transform: translateY(0);
}

/* Legacy .reveal compatibility */
[data-template="grand-resort"] .reveal {
  opacity:    0;
  transform:  translateY(2.25rem);
  transition: opacity   var(--dur-smooth) var(--ease-slow),
              transform var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] .reveal.is-visible {
  opacity:   1;
  transform: translateY(0);
}

/* ============ GLOBAL FOCUS VISIBLE ============ */

[data-template="grand-resort"] *:focus-visible {
  outline:        2.5px solid currentColor;
  outline-offset: 4px;
}

/* ============ REDUCED MOTION — §1.8 + §4.2 ============ */

@media (prefers-reduced-motion: reduce) {
  [data-template="grand-resort"] .reveal-line,
  [data-template="grand-resort"] .reveal-on-scroll,
  [data-template="grand-resort"] .reveal {
    opacity:    1;
    transform:  none;
    transition: none;
  }

  /* Image clip → instant opacity */
  [data-template="grand-resort"] .reveal-clip {
    clip-path:  none;
    opacity:    0;
    transition: opacity 200ms ease;
  }

  [data-template="grand-resort"] .reveal-clip.is-visible {
    clip-path: none;
    opacity:   1;
  }

  /* Parallax disabled */
  [data-template="grand-resort"] .hero-image-side img {
    transform:   none !important;
    will-change: auto;
  }

  /* Scroll indicator: no pulse */
  [data-template="grand-resort"] .scroll-indicator {
    animation: none;
    opacity:   0.7;
  }

  /* Image hover: no scale */
  [data-template="grand-resort"] .image-hover-gallery:hover img,
  [data-template="grand-resort"] .card:hover img,
  [data-template="grand-resort"] .gallery-item:hover img {
    transform: none;
  }

  /* CTA fill animation off */
  [data-template="grand-resort"] .btn-primary::before {
    transition: none;
  }

  /* Nav underline: no transition */
  [data-template="grand-resort"] .nav-link::after {
    transition: none;
  }

  [data-template="grand-resort"] * {
    animation-duration:       0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration:       200ms !important;
  }
}

/* ============ RESPONSIVE — §1.13 ============ */

/* Tablet: 768–1279px */
@media (max-width: 1279px) {
  [data-template="grand-resort"] .container-page,
  [data-template="grand-resort"] #site-navbar .nav-inner,
  [data-template="grand-resort"] footer .footer-grid,
  [data-template="grand-resort"] .footer-bottom {
    padding-inline: 2.5rem;
  }

  [data-template="grand-resort"] .hero-section {
    grid-template-columns: 1fr;  /* stack */
    grid-template-rows:    60vh auto;
  }

  [data-template="grand-resort"] .hero-image-side {
    grid-row:   1;
    min-height: 60vh;
  }

  [data-template="grand-resort"] .hero-text-side {
    grid-row:    2;
    padding:     3rem 2.5rem;
    margin-right: 0;
  }

  [data-template="grand-resort"] .listing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  [data-template="grand-resort"] .section {
    padding-top:    6rem;
    padding-bottom: 6rem;
  }

  [data-template="grand-resort"] footer .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Parallax depth halved at tablet — §1.13 */
}

/* Mobile: <768px */
@media (max-width: 767px) {
  [data-template="grand-resort"] .container-page,
  [data-template="grand-resort"] #site-navbar .nav-inner,
  [data-template="grand-resort"] footer .footer-grid,
  [data-template="grand-resort"] .footer-bottom {
    padding-inline: 1.25rem;
  }

  [data-template="grand-resort"] .hero-section {
    grid-template-rows: 45vh auto;  /* image 45vh top */
  }

  [data-template="grand-resort"] .hero-text-side {
    padding: 2.5rem 1.25rem;
  }

  [data-template="grand-resort"] .editorial-page-hero__content {
    padding: 8rem 0 3rem;
  }

  [data-template="grand-resort"] .listing-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  [data-template="grand-resort"] .listing-meta {
    flex-direction: column;
    align-items: flex-start;
  }

  [data-template="grand-resort"] .scroll-indicator {
    display: none;  /* scroll indicator hidden — §1.13 */
  }

  /* Grain disabled on mobile — §1.13 */
  [data-template="grand-resort"] .hero-image-side::after {
    display: none;
  }

  [data-template="grand-resort"] .section {
    padding-top:    4rem;
    padding-bottom: 4rem;
  }

  [data-template="grand-resort"] footer .footer-grid {
    grid-template-columns: 1fr;
    gap:                   2rem;
  }

  [data-template="grand-resort"] .stat-item:not(:last-child) {
    border-right:  none;
    border-bottom: 1px solid rgb(var(--color-accent) / 0.2);
    padding-bottom: 1.5rem;
  }

  [data-template="grand-resort"] .logo-bar {
    flex-wrap: wrap;
    gap:       3rem;
  }

  [data-template="grand-resort"] .logo-bar-item:not(:last-child) {
    border-right: none;
    padding-right: 0;
  }

  [data-template="grand-resort"] .btn-primary,
  [data-template="grand-resort"] .btn-secondary {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  [data-template="grand-resort"] footer .footer-bottom {
    flex-direction: column;
    gap:            0.75rem;
    text-align:     center;
  }
}

/* ============ 2026 REGNUM BENCHMARK RESET ============ */

[data-template="grand-resort"] {
  /* Lumina flat: shadows neutralised; depth comes from imagery + dark bands + hairlines. */
  --tpl-shadow-sm: none;
  --tpl-shadow-md: none;
  --tpl-shadow-lg: none;
}

[data-template="grand-resort"] #site-navbar .nav-inner {
  height: 88px;
}

[data-template="grand-resort"] .nav-brand-text {
  font-family: var(--font-body);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: rgb(255 255 255 / 0.98);
}

[data-template="grand-resort"] #site-navbar.navbar-scrolled {
  background: rgb(245 240 228 / 0.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

[data-template="grand-resort"] .nav-link {
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.92);
  white-space: nowrap;
  text-decoration: none;
}

[data-template="grand-resort"] #site-navbar #desktop-nav {
  gap: 1.5rem;
}

@media (min-width: 1280px) {
  [data-template="grand-resort"] #site-navbar #desktop-nav {
    gap: 1.75rem;
  }
}

[data-template="grand-resort"] #site-navbar .nav-brand-text,
[data-template="grand-resort"] #site-navbar a[href="/"] > span {
  font-size: 1rem;
  letter-spacing: 0.04em;
  margin-right: 1rem;
}

@media (min-width: 1280px) {
  [data-template="grand-resort"] #site-navbar .nav-brand-text,
  [data-template="grand-resort"] #site-navbar a[href="/"] > span {
    font-size: 1.05rem;
  }
}

/* Menu overlay (full-screen) — dark forest green for grand-resort
   FIX: brand-kit data-theme override --color-surface-dark to a beige value,
   causing cream-on-cream illegible text. Hardcoded RGB beats variables. */
[data-template="grand-resort"] .menu-overlay {
  background-color: rgb(20 18 12) !important; /* Lumina ink (was forest green) */
}

[data-template="grand-resort"] .menu-overlay .menu-nav-link {
  color: rgb(245 240 228 / 0.94);
  border-bottom-color: rgb(255 255 255 / 0.08);
  font-family: var(--font-heading);
}

[data-template="grand-resort"] .menu-overlay .menu-nav-link:hover {
  color: rgb(168 130 74);
  padding-left: 12px;
}

[data-template="grand-resort"] .menu-overlay .menu-close-btn {
  color: rgb(245 240 228);
  opacity: 0.78;
}

[data-template="grand-resort"] .menu-overlay .menu-close-btn:hover {
  opacity: 1;
}

[data-template="grand-resort"] .menu-overlay .menu-secondary,
[data-template="grand-resort"] .menu-overlay .menu-secondary p,
[data-template="grand-resort"] .menu-overlay .menu-secondary a {
  color: rgb(245 240 228 / 0.7);
}

[data-template="grand-resort"] .menu-overlay .menu-secondary a:hover {
  color: rgb(255 255 255);
}

/* ============ LUMINA OVERLAY MENU (grand-resort) ============ */

/* Overlay = flex column: topbar (top) + body (fills, centered).
   z-index above navbar (z:100) so the header utility strip (TR|EN) does NOT
   show over the open menu — fixes duplicate language control. */
[data-template="grand-resort"] .resort-menu-overlay {
  display: flex;
  flex-direction: column;
  z-index: 150;
}

/* Topbar: brand (left) + Kapat (right), container-aligned */
[data-template="grand-resort"] .resort-menu-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 90rem;
  margin: 0 auto;
  padding: 1.75rem clamp(1.5rem, 5vw, 5rem);
}

[data-template="grand-resort"] .resort-menu-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

[data-template="grand-resort"] .resort-menu-brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

[data-template="grand-resort"] .resort-menu-brand-name {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgb(245 240 228 / 0.96);
}

[data-template="grand-resort"] .resort-menu-brand-sub {
  margin-top: 2px;
  font-family: var(--font-mono);
  font-size: 0.52rem;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.6);
}

[data-template="grand-resort"] .resort-menu-close {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.85);
  transition: color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-menu-close:hover {
  color: rgb(var(--color-brass));
}

[data-template="grand-resort"] .resort-menu-close svg {
  width: 26px;
  height: 26px;
}

/* Body: nav (left) + aside (right) */
[data-template="grand-resort"] .resort-menu-body {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-content: center;
  width: 100%;
  max-width: 90rem;
  margin: 0 auto;
  padding: 1.5rem clamp(1.5rem, 5vw, 5rem) 2.5rem;
}

@media (min-width: 1024px) {
  [data-template="grand-resort"] .resort-menu-body {
    grid-template-columns: 1.4fr 0.9fr;
    gap: 6rem;
    align-items: center;
  }
}

/* Nav — flex column of roman + serif links */
[data-template="grand-resort"] .resort-menu-nav {
  display: flex;
  flex-direction: column;
}

/* Roman numeral + big serif label (overrides generic .menu-nav-link typography) */
[data-template="grand-resort"] .resort-menu-overlay .menu-nav-link.resort-menu-link {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  padding: 0.4rem 0;
  border-bottom: 1px solid rgb(245 240 228 / 0.14);
  font-family: var(--font-heading);
}

[data-template="grand-resort"] .resort-menu-num {
  flex-shrink: 0;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: rgb(var(--color-brass));
}

[data-template="grand-resort"] .resort-menu-label {
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: clamp(1.4rem, 2.5vw, 2.2rem);
  line-height: 1.12;
  color: rgb(245 240 228 / 0.96);
  transition: color 500ms var(--ease-slow), transform 500ms var(--ease-slow);
}

/* Override generic hover (green + padding-left) → label brass + translate */
[data-template="grand-resort"] .resort-menu-overlay .menu-nav-link.resort-menu-link:hover {
  padding-left: 0;
  color: inherit;
}

[data-template="grand-resort"] .resort-menu-link:hover .resort-menu-label {
  color: rgb(var(--color-brass));
  transform: translateX(12px);
}

/* Aside — own fade-in (no .menu-secondary class → no generic colour clash) */
[data-template="grand-resort"] .resort-menu-aside {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s var(--ease-slow) 0.3s, transform 0.6s var(--ease-slow) 0.3s;
}

[data-template="grand-resort"] .menu-overlay.is-open .resort-menu-aside {
  opacity: 1;
  transform: translateY(0);
}

[data-template="grand-resort"] .resort-menu-aside-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(var(--color-brass));
  margin: 0 0 1.1rem;
}

[data-template="grand-resort"] .resort-menu-contact {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
}

[data-template="grand-resort"] .resort-menu-contact span,
[data-template="grand-resort"] .resort-menu-contact a {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: rgb(245 240 228 / 0.8);
  transition: color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-menu-contact a:hover {
  color: rgb(245 240 228);
}

[data-template="grand-resort"] .resort-menu-contact svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

[data-template="grand-resort"] .resort-menu-social {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

[data-template="grand-resort"] .resort-menu-social-pill {
  padding: 0.5rem 1rem;
  border: 1px solid rgb(245 240 228 / 0.25);
  border-radius: 9999px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.85);
  transition: border-color 220ms var(--ease-slow), color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-menu-social-pill:hover {
  border-color: rgb(var(--color-brass));
  color: rgb(245 240 228 / 0.98);
}

[data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-link,
[data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-brand-text,
[data-template="grand-resort"] #site-navbar.navbar-scrolled .lang-switch-trigger,
[data-template="grand-resort"] #site-navbar.navbar-scrolled #menu-toggle {
  color: rgb(31 84 62 / 0.94);
}

/* ============ Lumina two-tier header — utility strip + brand sublabel ============ */
/* Utility strip: top tier, collapses on scroll (mirrors .navbar-scrolled). */
[data-template="grand-resort"] .resort-util-strip {
  overflow:       hidden;
  max-height:     46px;
  opacity:        1;
  border-bottom:  1px solid rgb(245 240 228 / 0.16);
  transition:     max-height var(--dur-smooth) var(--ease-slow),
                  opacity var(--dur-snap) var(--ease-slow),
                  border-color var(--dur-smooth) var(--ease-slow);
}
[data-template="grand-resort"] .resort-util-inner {
  padding-block:  0.625rem;
}
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-strip {
  max-height:     0;
  opacity:        0;
  border-bottom-color: transparent;
}
/* Utility text/links follow the two-state navbar coloring (light → muted ink). */
[data-template="grand-resort"] .resort-util-link,
[data-template="grand-resort"] .resort-util-lang-active,
[data-template="grand-resort"] .resort-util-lang-sep {
  color:          rgb(255 255 255 / 0.86);
}
[data-template="grand-resort"] .resort-util-lang-active {
  color:          rgb(255 255 255 / 0.98);
  font-weight:    600;
}
[data-template="grand-resort"] .resort-util-link {
  transition:     color var(--dur-snap) var(--ease-slow), opacity var(--dur-snap) var(--ease-slow);
}
[data-template="grand-resort"] .resort-util-link:hover {
  color:          rgb(var(--color-brass));
}
[data-template="grand-resort"] .resort-util-divider {
  background:     rgb(255 255 255 / 0.32);
}
/* Solid (scrolled) state — muted ink, brass divider, dark active lang. */
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-link,
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-lang-sep {
  color:          rgb(var(--color-text-muted));
}
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-lang-active {
  color:          rgb(var(--color-heading));
}
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-divider {
  background:     rgb(var(--color-border-strong));
}
/* .resort-util-text (utility location line + brand sublabel) — muted two-state variant. */
[data-template="grand-resort"] #site-navbar .resort-util-text {
  color:          rgb(255 255 255 / 0.72);
}
[data-template="grand-resort"] #site-navbar.navbar-scrolled .resort-util-text {
  color:          rgb(var(--color-text-muted));
}

[data-template="grand-resort"] .resort-hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  background: rgb(22 38 29);
}

[data-template="grand-resort"] .resort-hero-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

[data-template="grand-resort"] .resort-hero-scrim {
  position: absolute;
  inset: 0;
  /* Lumina cinematic scrim — lighter mid so the coastal image stays visible,
     darker bottom keeps the copy legible. */
  background: linear-gradient(180deg, rgba(16, 14, 9, 0.52) 0%, rgba(16, 14, 9, 0.14) 40%, rgba(16, 14, 9, 0.74) 100%);
}

[data-template="grand-resort"] .resort-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  align-self: flex-end;
  padding-top: 11rem;
  padding-bottom: 2.75rem;
  display: grid;
  gap: 2.5rem;
}

[data-template="grand-resort"] .resort-hero-copy {
  max-width: min(42rem, 100%);
  padding: 2.5rem 0 0;
}

[data-template="grand-resort"] .resort-hero-brand {
  display: block;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.86);
}

/* Subtitle/kicker — sentence case, refined narrow tracking (UI/UX Polish 2026-05-26).
   Eski: uppercase + 0.18em tracking → okunaksız + body text ile çift gösterim.
   Yeni: sentence case, 0.02em tracking, biraz büyük font — Aman/Six Senses tarzı. */
/* Lumina overline: brass mono eyebrow + leading rule line (w-12), high contrast over scrim */
[data-template="grand-resort"] .resort-hero-kicker {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 0;
  margin-bottom: 1.75rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(var(--color-brass));
}

[data-template="grand-resort"] .resort-hero-kicker::before {
  content: "";
  display: block;
  width: 3rem;
  height: 1px;
  flex-shrink: 0;
  background: rgb(var(--color-brass));
}

[data-template="grand-resort"] .resort-hero-title {
  max-width: 22ch;
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(3.3rem, 2.2rem + 4.1vw, 6rem);
  font-weight: 500;
  line-height: 0.94;
  letter-spacing: -0.05em;
  color: rgb(255 255 255 / 0.98);
  text-shadow: none;
}

[data-template="grand-resort"] .resort-hero-summary {
  max-width: 34rem;
  margin-top: 1.35rem;
  margin-bottom: 0;
  font-family: var(--font-body);
  font-size: clamp(0.98rem, 0.92rem + 0.22vw, 1.08rem);
  line-height: 1.72;
  letter-spacing: 0.01em;
  color: rgb(255 255 255 / 0.92);
}

[data-template="grand-resort"] .resort-hero-actions {
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
}

[data-template="grand-resort"] .resort-hero-actions .btn-primary {
  min-width: 13rem;
  justify-content: center;
  border-color: rgb(255 255 255 / 0.22);
  background: rgb(255 255 255 / 0.12);
  color: rgb(255 255 255 / 0.98);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

[data-template="grand-resort"] .resort-hero-actions .btn-primary:hover {
  background: rgb(255 255 255 / 0.2);
}

/* Lumina dual-CTA: secondary "Explore the Stay" pill — transparent outline on the image */
[data-template="grand-resort"] .resort-hero-actions .btn-outline {
  min-width: 13rem;
  justify-content: center;
  border-color: rgb(255 255 255 / 0.32);
  background: transparent;
  color: rgb(255 255 255 / 0.92);
}

[data-template="grand-resort"] .resort-hero-actions .btn-outline:hover {
  border-color: rgb(255 255 255 / 0.6);
  background: rgb(255 255 255 / 0.08);
  color: rgb(255 255 255 / 0.98);
}

[data-template="grand-resort"] .resort-hero-ribbon {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid rgb(255 255 255 / 0.22);
  border-bottom: 1px solid rgb(255 255 255 / 0.12);
  background: rgb(12 24 17 / 0.18);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

[data-template="grand-resort"] .resort-hero-ribbon span {
  padding: 1rem 1.2rem;
  font-family: var(--font-body);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.86);
  border-right: 1px solid rgb(255 255 255 / 0.14);
}

[data-template="grand-resort"] .resort-hero-ribbon span:last-child {
  border-right: 0;
}

[data-template="grand-resort"] .hero-section,
[data-template="grand-resort"] .hero-image-side,
[data-template="grand-resort"] .hero-text-side,
[data-template="grand-resort"] .scroll-indicator {
  display: none;
}

[data-template="grand-resort"] .resort-page-hero {
  min-height: clamp(24rem, 54vh, 34rem);
}

[data-template="grand-resort"] .resort-page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgb(12 24 17 / 0.12) 0%, rgb(12 24 17 / 0.18) 42%, rgb(12 24 17 / 0.46) 100%);
  z-index: 1;
}

[data-template="grand-resort"] .resort-page-hero__content {
  padding: 10rem 0 3rem;
}

[data-template="grand-resort"] .resort-page-copy {
  position: relative;
  z-index: 2;
  max-width: 48rem;
}

[data-template="grand-resort"] .resort-page-copy .eyebrow {
  margin-bottom: 0.9rem;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: rgb(255 255 255 / 0.84);
}

[data-template="grand-resort"] .resort-page-copy .editorial-page-title {
  max-width: 12ch;
  font-family: var(--font-heading);
  font-size: clamp(2.4rem, 1.6rem + 2.3vw, 4.2rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.045em;
  color: rgb(255 255 255 / 0.98);
  text-shadow: none;
}

[data-template="grand-resort"] .editorial-intro,
[data-template="grand-resort"] .resort-page-intro {
  max-width: 52rem;
}

[data-template="grand-resort"] .listing-grid {
  gap: 2.2rem;
}

[data-template="grand-resort"] .listing-card {
  border: 1px solid rgb(var(--color-border) / 0.8);
  background: rgb(255 255 255 / 0.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform var(--dur-smooth) var(--ease-slow), box-shadow var(--dur-smooth) var(--ease-slow), border-color var(--dur-snap) var(--ease-slow);
}

[data-template="grand-resort"] .listing-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--tpl-shadow-md);
  border-color: rgb(var(--color-border-strong));
}

[data-template="grand-resort"] .listing-card-media {
  box-shadow: none;
}

[data-template="grand-resort"] .listing-card-body {
  padding: 1.3rem 1.35rem 1.45rem;
  border-bottom: 0;
}

[data-template="grand-resort"] .listing-card-title {
  margin-bottom: 0.4rem;
  font-family: var(--font-heading);
  font-size: 1.12rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

[data-template="grand-resort"] .listing-card .text-small,
[data-template="grand-resort"] .listing-meta,
[data-template="grand-resort"] .listing-meta-items,
[data-template="grand-resort"] .listing-price {
  font-family: var(--font-body);
}

[data-template="grand-resort"] .listing-meta-items {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
}

[data-template="grand-resort"] .listing-price {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgb(var(--color-primary));
}

[data-template="grand-resort"] .listing-card-link {
  font-family: var(--font-body);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

[data-template="grand-resort"] .resort-cta {
  margin-top: 1rem;
}

[data-template="grand-resort"] .resort-cta .inner-cta-content {
  background: linear-gradient(135deg, rgb(28 52 39) 0%, rgb(21 39 29) 100%);
  border: 1px solid rgb(255 255 255 / 0.08);
  box-shadow: var(--tpl-shadow-lg);
}

[data-template="grand-resort"] .resort-cta .label {
  font-family: var(--font-body);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

[data-template="grand-resort"] .resort-cta .btn-outline-white {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

@media (max-width: 1279px) {
  [data-template="grand-resort"] .resort-hero-inner {
    padding-top: 9.5rem;
  }

  [data-template="grand-resort"] .resort-hero-title {
    max-width: 14ch;
  }
}

@media (max-width: 767px) {
  [data-template="grand-resort"] .resort-hero-inner {
    padding-top: 8.5rem;
    padding-bottom: 1.5rem;
    gap: 1.5rem;
  }

  [data-template="grand-resort"] .resort-hero-copy {
    padding-top: 1.5rem;
  }

  [data-template="grand-resort"] .resort-hero-title {
    max-width: 14ch;
    font-size: clamp(2.5rem, 2rem + 3.3vw, 3.8rem);
  }

  [data-template="grand-resort"] .resort-hero-summary {
    font-size: 0.96rem;
    line-height: 1.65;
  }

  [data-template="grand-resort"] .resort-hero-ribbon {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  [data-template="grand-resort"] .resort-hero-ribbon span:nth-child(2) {
    border-right: 0;
  }

  [data-template="grand-resort"] .resort-page-hero__content {
    padding: 8rem 0 2.5rem;
  }

  [data-template="grand-resort"] .resort-page-copy .editorial-page-title {
    font-size: clamp(2rem, 1.65rem + 2vw, 3rem);
  }
}

/* ============ HERO SLIDESHOW — Z3-01e ============ */

[data-template="grand-resort"] .hero-slideshow {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}

[data-template="grand-resort"] .hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
  will-change: opacity;
}

[data-template="grand-resort"] .hero-slide.is-active {
  opacity: 1;
}

[data-template="grand-resort"] .hero-slide img,
[data-template="grand-resort"] .hero-slide video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

@media (prefers-reduced-motion: reduce) {
  [data-template="grand-resort"] .hero-slide {
    transition: none;
  }
}

/* ============ HERO SLIDESHOW CONTROLS — Z3-01-MEGA ============ */

[data-template="grand-resort"] .hero-slideshow {
  outline: none;
}

[data-template="grand-resort"] .hero-slideshow:focus-visible {
  outline: 2px solid rgb(255 255 255 / 0.45);
  outline-offset: -4px;
}

/* Lumina hero controls row — scroll cue (left) + indicators/arrows (right),
   container-aligned (matches .container-page max-width 90rem / padding 5rem). */
[data-template="grand-resort"] .hero-slideshow-controls {
  position: absolute;
  left: 0;
  right: 0;
  /* Booking widget overlaps hero bottom (margin-top negative). Sit above the overlap. */
  bottom: 5.25rem;
  z-index: 5; /* Above .resort-hero-inner (z:2) — JS appends to .resort-hero, escape stacking */
  display: flex;
  align-items: flex-end;
  /* Scroll cue (sol) kaldırıldı → grup (oklar+indikatör) sağda kalmalı.
     space-between tek çocuğu sola iterdi (Rezervasyon Yap üstüne biner) → flex-end. */
  justify-content: flex-end;
  gap: 1.5rem;
  width: 100%;
  max-width: 90rem;
  margin: 0 auto;
  padding-inline: clamp(1.5rem, 5vw, 5rem);
  pointer-events: none;
}

[data-template="grand-resort"] .hero-slideshow-controls > *,
[data-template="grand-resort"] .hero-slideshow-controls button {
  pointer-events: auto;
}

/* Scroll cue (left) */
[data-template="grand-resort"] .hero-slideshow-cue {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.6);
  white-space: nowrap;
}

/* Indicators + arrows group (right) */
[data-template="grand-resort"] .hero-slideshow-group {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

[data-template="grand-resort"] .hero-slideshow-arrows {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Square arrows (Lumina) — no fill, brass hover */
[data-template="grand-resort"] .hero-slideshow-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgb(245 240 228 / 0.32);
  border-radius: 0;
  background: transparent;
  color: rgb(245 240 228 / 0.92);
  cursor: pointer;
  transition: background 220ms var(--ease-slow), border-color 220ms var(--ease-slow), color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .hero-slideshow-arrow:hover {
  background: rgb(245 240 228 / 0.1);
  border-color: rgb(var(--color-brass));
  color: rgb(245 240 228);
}

[data-template="grand-resort"] .hero-slideshow-arrow:focus-visible {
  outline: 2px solid rgb(var(--color-brass));
  outline-offset: 2px;
}

[data-template="grand-resort"] .hero-slideshow-dots {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* Line-tab indicator (Lumina): thin rule widens + turns brass when active */
[data-template="grand-resort"] .hero-slideshow-dot {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  height: 16px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

[data-template="grand-resort"] .hero-slideshow-dot::before {
  content: "";
  display: block;
  height: 1px;
  width: 20px;
  background: rgb(245 240 228 / 0.45);
  transition: width 500ms var(--ease-slow), background 500ms var(--ease-slow);
}

[data-template="grand-resort"] .hero-slideshow-dot:hover::before {
  background: rgb(245 240 228 / 0.7);
}

[data-template="grand-resort"] .hero-slideshow-dot.is-active::before {
  width: 40px;
  background: rgb(var(--color-brass));
}

/* "video" label on the video slide's indicator */
[data-template="grand-resort"] .hero-slideshow-dot__label {
  font-family: var(--font-mono);
  font-size: 0.5rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.5);
  transition: color 500ms var(--ease-slow);
}

[data-template="grand-resort"] .hero-slideshow-dot.is-active .hero-slideshow-dot__label {
  color: rgb(var(--color-brass));
}

[data-template="grand-resort"] .hero-slideshow-dot:focus-visible {
  outline: 2px solid rgb(var(--color-brass));
  outline-offset: 3px;
}

@media (max-width: 767px) {
  [data-template="grand-resort"] .hero-slideshow-controls {
    bottom: 3rem;
    gap: 0.85rem;
  }
  /* Arrows hidden on mobile (design: hidden sm:flex) — line-tab dots remain swipeable affordance */
  [data-template="grand-resort"] .hero-slideshow-arrow {
    display: none;
  }
}

/* ============ FOOTER RESORT-STYLE (Z3-01-MEGA Faz 4-E redesign) ============ */

/* Footer shell — Lumina ink tone (gradient yok, sade tek ton) */
[data-template="grand-resort"] .resort-footer-shell {
  background: rgb(20 18 12) !important;
  color: rgb(245 240 228 / 0.78);
}

/* === Newsletter + Concierge band === */
[data-template="grand-resort"] .resort-footer-band {
  display: grid;
  grid-template-columns: 1fr;
  background: rgb(28 24 18);
  border-bottom: 1px solid rgb(168 130 74 / 0.18);
}

@media (min-width: 1024px) {
  [data-template="grand-resort"] .resort-footer-band {
    grid-template-columns: 1.7fr 1fr;
  }
}

[data-template="grand-resort"] .resort-footer-band-inner {
  display: grid;
  gap: 2.25rem;
  padding: clamp(3rem, 2rem + 3vw, 4.5rem) clamp(1.75rem, 1rem + 3vw, 4rem);
  align-content: center;
}

@media (min-width: 768px) {
  [data-template="grand-resort"] .resort-footer-band-inner {
    grid-template-columns: 1.05fr 0.95fr;
    gap: 3rem;
    align-items: center;
  }
}

[data-template="grand-resort"] .resort-footer-band-eyebrow {
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(168 130 74 / 0.85);
  margin: 0 0 0.9rem;
}

[data-template="grand-resort"] .resort-footer-band-title {
  font-family: var(--font-heading);
  font-size: clamp(1.45rem, 1.1rem + 1.4vw, 2.05rem);
  font-weight: 400;
  line-height: 1.16;
  letter-spacing: -0.02em;
  color: rgb(245 240 228 / 0.96);
  margin: 0 0 0.85rem;
  max-width: 22ch;
}

[data-template="grand-resort"] .resort-footer-band-body {
  font-family: var(--font-body);
  font-size: 0.88rem;
  line-height: 1.68;
  color: rgb(245 240 228 / 0.62);
  margin: 0;
  max-width: 30rem;
}

[data-template="grand-resort"] .resort-footer-newsletter {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-bottom: 1px solid rgb(168 130 74 / 0.32);
  align-items: stretch;
}

@media (min-width: 480px) {
  [data-template="grand-resort"] .resort-footer-newsletter {
    grid-template-columns: 1fr auto;
  }
}

[data-template="grand-resort"] .resort-footer-newsletter-input {
  width: 100%;
  padding: 0.85rem 0;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: rgb(245 240 228 / 0.96);
  background: transparent;
  border: 0;
  outline: none;
}

[data-template="grand-resort"] .resort-footer-newsletter-input::placeholder {
  color: rgb(245 240 228 / 0.4);
  font-family: var(--font-body);
  font-style: normal;
}

[data-template="grand-resort"] .resort-footer-newsletter-input:focus-visible {
  outline: none;
}

[data-template="grand-resort"] .resort-footer-newsletter:focus-within {
  border-bottom-color: rgb(168 130 74 / 0.85);
}

[data-template="grand-resort"] .resort-footer-newsletter-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.85rem 0.25rem 0.85rem 1rem;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(168 130 74);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: color 220ms var(--ease-slow), gap 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-footer-newsletter-submit:hover {
  color: rgb(245 240 228);
  gap: 0.85rem;
}

[data-template="grand-resort"] .resort-footer-newsletter-submit:focus-visible {
  outline: 2px solid rgb(168 130 74 / 0.5);
  outline-offset: 2px;
}

/* Concierge tarafı — Lumina ink tonu, sadece sol border ile ayrılır */
[data-template="grand-resort"] .resort-footer-band-concierge {
  display: flex;
  align-items: center;
  background: rgb(28 24 18);
  padding: clamp(2.5rem, 1.5rem + 3vw, 4rem) clamp(1.75rem, 1rem + 3vw, 4rem);
  position: relative;
}

@media (min-width: 1024px) {
  [data-template="grand-resort"] .resort-footer-band-concierge::before {
    content: "";
    position: absolute;
    left: 0;
    top: 25%;
    bottom: 25%;
    width: 1px;
    background: rgb(168 130 74 / 0.28);
  }
}

[data-template="grand-resort"] .resort-footer-band-concierge-inner {
  display: grid;
  gap: 0.85rem;
}

[data-template="grand-resort"] .resort-footer-band-concierge-label {
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(168 130 74 / 0.85);
  margin: 0;
}

[data-template="grand-resort"] .resort-footer-band-concierge-body {
  font-family: var(--font-heading);
  font-size: clamp(1.05rem, 0.95rem + 0.4vw, 1.2rem);
  font-weight: 400;
  line-height: 1.34;
  letter-spacing: -0.012em;
  color: rgb(245 240 228 / 0.94);
  margin: 0;
  max-width: 24ch;
}

[data-template="grand-resort"] .resort-footer-band-concierge-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 500;
  color: rgb(245 240 228);
  text-decoration: none;
  padding: 0.65rem 0;
  border-bottom: 1px solid rgb(168 130 74 / 0.5);
  transition: gap 220ms var(--ease-slow), border-color 220ms var(--ease-slow);
  width: fit-content;
  margin-top: 0.25rem;
}

[data-template="grand-resort"] .resort-footer-band-concierge-cta:hover {
  gap: 0.85rem;
  border-color: rgb(168 130 74);
}

/* === Main footer body — refined === */
[data-template="grand-resort"] .resort-footer-shell .footer-grid {
  gap: 3rem 2.5rem;
}

@media (min-width: 1024px) {
  [data-template="grand-resort"] .resort-footer-shell .footer-grid {
    gap: 3rem 4rem;
  }
}

/* Brand column — bigger logo / brand text */
[data-template="grand-resort"] .resort-footer-shell .footer-grid > *:first-child a span,
[data-template="grand-resort"] .resort-footer-shell .footer-grid > *:first-child a {
  font-family: var(--font-heading) !important;
  font-size: 1.3rem !important;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: rgb(245 240 228 / 0.96);
}

[data-template="grand-resort"] .resort-footer-shell .footer-grid p {
  font-family: var(--font-body);
  color: rgb(245 240 228 / 0.62) !important;
  line-height: 1.74;
}

/* Footer column headings — sade, küçük, mütevazi (brass değil cream low opacity) */
[data-template="grand-resort"] .resort-footer-shell .footer-grid p.font-heading,
[data-template="grand-resort"] .resort-footer-shell h3,
[data-template="grand-resort"] .resort-footer-shell h4 {
  font-family: var(--font-body) !important;
  font-size: 0.6rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.5) !important;
  margin-bottom: 1.5rem !important;
}

/* Footer nav links — Lumina: body (sans) font, refined size, cream tone */
[data-template="grand-resort"] .resort-footer-shell .cw-footer-nav-link {
  font-family: var(--font-body) !important;
  font-size: 0.92rem !important;
  font-weight: 400 !important;
  letter-spacing: 0;
  color: rgb(245 240 228 / 0.74) !important;
  transition: color 220ms var(--ease-slow), padding-left 220ms var(--ease-slow);
  padding: 0.15rem 0;
}

[data-template="grand-resort"] .resort-footer-shell .cw-footer-nav-link:hover {
  color: rgb(245 240 228) !important;
  padding-left: 4px;
}

/* Lumina footer columns — social pills hover (border + text brighten). */
[data-template="grand-resort"] .resort-footer-cols a[style*="radius-full"]:hover {
  border-color: rgb(168 130 74 / 0.7) !important;
  color: rgb(245 240 228 / 0.95) !important;
}

/* Contact info — quieter */
[data-template="grand-resort"] .resort-footer-shell .footer-grid > *:last-child .space-y-3 p,
[data-template="grand-resort"] .resort-footer-shell .footer-grid > *:last-child .space-y-3 a {
  font-family: var(--font-body);
  font-size: 0.88rem !important;
  color: rgb(245 240 228 / 0.62) !important;
  line-height: 1.7;
}

/* Social icons — kutu yok, sade SVG, brass hover */
[data-template="grand-resort"] .resort-footer-shell .footer-socials {
  gap: 1.25rem;
  margin-top: 2rem;
}

[data-template="grand-resort"] .resort-footer-shell .footer-socials a {
  width: auto;
  height: auto;
  border: 0 !important;
  background: transparent;
  color: rgb(245 240 228 / 0.5) !important;
  padding: 0.25rem;
  transition: color 220ms var(--ease-slow), transform 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-footer-shell .footer-socials a:hover {
  color: rgb(168 130 74) !important;
  transform: translateY(-2px);
}

[data-template="grand-resort"] .resort-footer-shell .footer-socials a svg {
  width: 18px;
  height: 18px;
}

/* Bottom bar — minimal hairline, brass accent */
[data-template="grand-resort"] .resort-footer-shell .border-t {
  border-top-color: rgb(168 130 74 / 0.18) !important;
}

[data-template="grand-resort"] .resort-footer-shell .footer-bottom {
  padding: 0.5rem 0 1.5rem;
}

[data-template="grand-resort"] .resort-footer-shell .footer-bottom p {
  font-family: var(--font-mono);
  font-size: 0.66rem !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.5) !important;
}

[data-template="grand-resort"] .resort-footer-shell .cw-footer-legal-link {
  font-family: var(--font-mono) !important;
  font-size: 0.66rem !important;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(245 240 228 / 0.5) !important;
  transition: color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-footer-shell .cw-footer-legal-link:hover {
  color: rgb(168 130 74) !important;
}

/* Footer main padding — partial'da Tailwind ile (pt-24 pb-16).
   NOT: eski `> div:nth-child(2)` positional kuralı band kaldırılınca
   alt-bar'a kayıp yüksekliği şişiriyordu → kaldırıldı (Lumina footer fix). */

/* ============ MEGA MENU (Z3-01-MEGA Faz 4-B) ============ */

[data-template="grand-resort"] .nav-mega-trigger {
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
}

[data-template="grand-resort"] .resort-mega-menu {
  position: fixed;
  top: 88px;
  left: 0;
  right: 0;
  z-index: 49;
  pointer-events: none;
}

[data-template="grand-resort"] .resort-mega-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: rgb(245 240 228 / 0.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgb(168 130 74 / 0.18);
  box-shadow: 0 24px 48px rgb(18 28 20 / 0.08);
  padding: 2.5rem 0 3rem;
  opacity: 0;
  transform: translateY(-12px);
  visibility: hidden;
  pointer-events: none;
  transition: opacity 280ms var(--ease-slow), transform 320ms var(--ease-slow), visibility 0s 320ms;
}

[data-template="grand-resort"] .resort-mega-panel.is-open {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
  pointer-events: auto;
  transition: opacity 280ms var(--ease-slow), transform 320ms var(--ease-slow), visibility 0s 0s;
}

[data-template="grand-resort"] .resort-mega-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

[data-template="grand-resort"] .resort-mega-grid--4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

[data-template="grand-resort"] .resort-mega-card {
  display: flex;
  gap: 1.1rem;
  padding: 0.5rem;
  text-decoration: none;
  color: inherit;
  border-radius: 2px;
  transition: background 240ms var(--ease-slow), transform 240ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-mega-card:hover {
  background: rgb(255 255 255 / 0.7);
  transform: translateY(-2px);
}

[data-template="grand-resort"] .resort-mega-card-media {
  flex-shrink: 0;
  width: 88px;
  height: 88px;
  overflow: hidden;
  background: rgb(28 24 18 / 0.06);
}

[data-template="grand-resort"] .resort-mega-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 600ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-mega-card:hover .resort-mega-card-media img {
  transform: scale(1.05);
}

[data-template="grand-resort"] .resort-mega-card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding: 0.15rem 0;
}

[data-template="grand-resort"] .resort-mega-card-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.78);
}

[data-template="grand-resort"] .resort-mega-card-title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: rgb(28 24 18);
  margin: 0;
  line-height: 1.18;
}

[data-template="grand-resort"] .resort-mega-card-body p {
  font-family: var(--font-body);
  font-size: 0.82rem;
  line-height: 1.55;
  color: rgb(28 24 18 / 0.7);
  margin: 0;
}

/* Trigger active state when its panel is open */
[data-template="grand-resort"] .nav-mega-trigger[aria-expanded="true"] {
  color: rgb(255 255 255);
}

[data-template="grand-resort"] #site-navbar.navbar-scrolled .nav-mega-trigger[aria-expanded="true"] {
  color: rgb(31 84 62);
}

/* Hide on tablet/mobile (mega menu is desktop-only) */
@media (max-width: 1023px) {
  [data-template="grand-resort"] .resort-mega-menu {
    display: none;
  }
}

/* When navbar is solid (.navbar-scrolled), shift panel down to match */
[data-template="grand-resort"] #site-navbar.navbar-scrolled ~ .resort-mega-menu {
  top: 88px;
}

/* ============ KURUMSAL NAV DROPDOWN (#6 — corporate pages) ============ */
/* grand-resort desktop nav "Kurumsal" dropdown. CSS-only hover + :focus-within reveal (JS yok,
   resort-mega-menu.js'e dokunulmadı). Sadece corporateItems varsa render edilir (navbar data-driven).
   Cream panel + ink linkler → navbar transparent/solid state'inden bağımsız okunur. */

[data-template="grand-resort"] .resort-nav-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}

[data-template="grand-resort"] .resort-nav-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  background: transparent;
  border: 0;
  padding-block: 0.75rem;  /* .nav-link ile aynı dikey hit-area */
  padding-inline: 0;        /* buton UA yatay padding'ini sıfırla */
  cursor: pointer;
  /* Tipografi (font-family/size/weight/letter-spacing/text-transform/color)
     .nav-link sınıfından gelir — ÖVERRİDE ETME (font:inherit eski hata: body font'u ezip
     heading font'a düşürüyordu → diğer item'lardan farklı görünüyordu). */
}

[data-template="grand-resort"] .resort-nav-dropdown__chevron {
  transition: transform 260ms var(--ease-slow);
  opacity: 0.7;
}

[data-template="grand-resort"] .resort-nav-dropdown:hover .resort-nav-dropdown__chevron,
[data-template="grand-resort"] .resort-nav-dropdown:focus-within .resort-nav-dropdown__chevron {
  transform: rotate(180deg);
  opacity: 1;
}

[data-template="grand-resort"] .resort-nav-dropdown__menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, -8px);
  min-width: 13rem;
  margin-top: 0.85rem;
  display: flex;
  flex-direction: column;
  background: rgb(245 240 228 / 0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgb(168 130 74 / 0.18);
  box-shadow: 0 24px 48px rgb(18 28 20 / 0.12);
  padding: 0.6rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 240ms var(--ease-slow), transform 280ms var(--ease-slow), visibility 0s 280ms;
  z-index: 60;
}

/* Hover köprüsü — trigger ile menü arasındaki boşlukta hover düşmesin */
[data-template="grand-resort"] .resort-nav-dropdown__menu::before {
  content: "";
  position: absolute;
  top: -0.85rem;
  left: 0;
  right: 0;
  height: 0.85rem;
}

[data-template="grand-resort"] .resort-nav-dropdown:hover .resort-nav-dropdown__menu,
[data-template="grand-resort"] .resort-nav-dropdown:focus-within .resort-nav-dropdown__menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate(-50%, 0);
  transition: opacity 240ms var(--ease-slow), transform 280ms var(--ease-slow), visibility 0s 0s;
}

[data-template="grand-resort"] .resort-nav-dropdown__link {
  font-family: var(--font-heading);
  font-size: 0.92rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: rgb(28 24 18 / 0.82);
  text-decoration: none;
  padding: 0.6rem 0.85rem;
  white-space: nowrap;
  transition: background 200ms var(--ease-slow), color 200ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-nav-dropdown__link:hover {
  background: rgb(255 255 255 / 0.7);
  color: rgb(111 78 31);
}

/* Dropdown desktop-only (mobil/tablet tam ekran overlay menüyü kullanır) */
@media (max-width: 1023px) {
  [data-template="grand-resort"] .resort-nav-dropdown {
    display: none;
  }
}

/* ============ BOOKING WIDGET (Z3-01-MEGA Faz 4-A) ============ */

[data-template="grand-resort"] .resort-booking {
  position: sticky;
  top: clamp(54px, 7vw, 64px);
  background: rgb(245 240 228);
  padding: 0;
  margin-top: -3.75rem;
  z-index: 20;
}

[data-template="grand-resort"] .resort-booking-form {
  display: grid;
  grid-template-columns: 1fr;
  background: rgb(255 255 255);
  box-shadow: var(--tpl-shadow-md);
  border: 1px solid rgb(168 130 74 / 0.22);
}

@media (min-width: 768px) {
  [data-template="grand-resort"] .resort-booking-form {
    grid-template-columns: 1fr 1fr 1fr 1.2fr;
  }
}

[data-template="grand-resort"] .resort-booking-field {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 1.1rem 1.4rem 1.15rem;
  background: rgb(255 255 255);
  border-bottom: 1px solid rgb(168 130 74 / 0.18);
}

@media (min-width: 768px) {
  [data-template="grand-resort"] .resort-booking-field {
    border-right: 1px solid rgb(168 130 74 / 0.18);
    border-bottom: 0;
  }
  [data-template="grand-resort"] .resort-booking-field:last-child {
    border-right: 0;
  }
}

[data-template="grand-resort"] .resort-booking-label {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.78);
}

[data-template="grand-resort"] .resort-booking-input {
  width: 100%;
  padding: 0.25rem 0;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: rgb(28 24 18);
  background: transparent;
  border: 0;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
}

[data-template="grand-resort"] .resort-booking-input:focus-visible {
  outline: 2px solid rgb(111 78 31 / 0.4);
  outline-offset: 4px;
}

[data-template="grand-resort"] .resort-booking-counter {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.1rem;
}

[data-template="grand-resort"] .resort-booking-counter-btn {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgb(168 130 74 / 0.42);
  border-radius: 9999px;
  background: transparent;
  color: rgb(111 78 31);
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1;
  padding: 0;
  cursor: pointer;
  transition: background 180ms var(--ease-slow), border-color 180ms var(--ease-slow), color 180ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-booking-counter-btn:hover:not(:disabled) {
  background: rgb(111 78 31 / 0.08);
  border-color: rgb(111 78 31);
}

[data-template="grand-resort"] .resort-booking-counter-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

[data-template="grand-resort"] .resort-booking-counter-btn:focus-visible {
  outline: 2px solid rgb(111 78 31 / 0.5);
  outline-offset: 2px;
}

[data-template="grand-resort"] .resort-booking-counter-value {
  width: 2ch;
  text-align: center;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: rgb(28 24 18);
  background: transparent;
  border: 0;
  outline: none;
  padding: 0;
  appearance: none;
  -moz-appearance: textfield;
}

[data-template="grand-resort"] .resort-booking-counter-value::-webkit-outer-spin-button,
[data-template="grand-resort"] .resort-booking-counter-value::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Guests popover (Lumina fidelity — single Misafir cell + stepper popover) */
[data-template="grand-resort"] .resort-booking-guests {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  margin-top: 0.1rem;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: rgb(28 24 18);
  text-align: left;
}

[data-template="grand-resort"] .resort-booking-guests svg {
  flex-shrink: 0;
  color: rgb(111 78 31);
  transition: transform 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-booking-guests[aria-expanded="true"] svg {
  transform: rotate(45deg);
}

[data-template="grand-resort"] .resort-booking-guests:focus-visible {
  outline: 2px solid rgb(111 78 31 / 0.4);
  outline-offset: 4px;
}

[data-template="grand-resort"] .resort-booking-popover {
  position: absolute;
  left: 0;
  top: 100%;
  z-index: 40;
  min-width: 16rem;
  margin-top: 1px;
  padding: 0.25rem 1.4rem 0.75rem;
  background: rgb(245 240 228);
  border: 1px solid rgb(168 130 74 / 0.5);
  box-shadow: 0 24px 50px -24px rgb(16 14 9 / 0.5);
  display: none;
}

[data-template="grand-resort"] .resort-booking-popover.is-open {
  display: block;
}

[data-template="grand-resort"] .resort-booking-popover-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 0.8rem 0;
}

[data-template="grand-resort"] .resort-booking-popover-row + .resort-booking-popover-row {
  border-top: 1px solid rgb(168 130 74 / 0.18);
}

[data-template="grand-resort"] .resort-booking-submit-wrap {
  padding: 0;
  background: transparent;
  border: 0 !important;
}

[data-template="grand-resort"] .resort-booking-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: 100%;
  height: 100%;
  min-height: 4rem;
  padding: 1rem 1.5rem;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(255 255 255);
  background: rgb(28 52 39);
  border: 0;
  cursor: pointer;
  transition: background 220ms var(--ease-slow), gap 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-booking-submit:hover {
  background: rgb(21 39 29);
  gap: 0.85rem;
}

[data-template="grand-resort"] .resort-booking-submit:focus-visible {
  outline: 2px solid rgb(78 95 60);
  outline-offset: -3px;
}

@media (max-width: 767px) {
  [data-template="grand-resort"] .resort-booking {
    margin-top: -1.5rem;
  }
  [data-template="grand-resort"] .resort-booking-submit {
    min-height: 3.25rem;
  }
}

/* ============ Z3-01-MEGA SECTION RHYTHM (Regnum-port) ============ */

/* --- Brand Promise band (full-width manifesto) --- */
[data-template="grand-resort"] .resort-promise {
  position: relative;
  padding: clamp(5rem, 4rem + 6vw, 9rem) 0 clamp(4rem, 3rem + 5vw, 7.5rem);
  background: rgb(245 240 228);
  overflow: hidden;
}

[data-template="grand-resort"] .resort-promise::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 1px;
  height: 4rem;
  background: linear-gradient(180deg, rgb(111 78 31 / 0) 0%, rgb(111 78 31 / 0.45) 100%);
}

[data-template="grand-resort"] .resort-promise-inner {
  display: grid;
  gap: 2rem;
  text-align: center;
  max-width: 56rem;
  margin: 0 auto;
}

[data-template="grand-resort"] .resort-promise-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.72);
  margin: 0;
}

[data-template="grand-resort"] .resort-promise-title {
  font-family: var(--font-heading);
  font-size: clamp(2.2rem, 1.6rem + 2.4vw, 3.6rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: rgb(28 24 18);
  margin: 0;
}

[data-template="grand-resort"] .resort-promise-body {
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.95rem + 0.2vw, 1.12rem);
  line-height: 1.78;
  color: rgb(28 24 18 / 0.78);
  max-width: 42rem;
  margin: 0 auto;
}

[data-template="grand-resort"] .resort-promise-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 0.5rem;
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.78);
}

[data-template="grand-resort"] .resort-promise-meta::before,
[data-template="grand-resort"] .resort-promise-meta::after {
  content: "";
  display: block;
  width: 2.5rem;
  height: 1px;
  background: rgb(111 78 31 / 0.45);
}

/* --- Stay showcase (2-col split: image + text) --- */
[data-template="grand-resort"] .resort-showcase {
  position: relative;
  background: rgb(238 231 215);
  padding: clamp(4.5rem, 3.5rem + 5vw, 7.5rem) 0;
}

[data-template="grand-resort"] .resort-showcase-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 960px) {
  [data-template="grand-resort"] .resort-showcase-grid {
    grid-template-columns: 1.1fr 0.9fr;
    gap: 4.5rem;
  }
  [data-template="grand-resort"] .resort-showcase--reverse .resort-showcase-grid {
    grid-template-columns: 0.9fr 1.1fr;
  }
  [data-template="grand-resort"] .resort-showcase--reverse .resort-showcase-media {
    order: 2;
  }
  [data-template="grand-resort"] .resort-showcase--reverse .resort-showcase-copy {
    order: 1;
  }
}

[data-template="grand-resort"] .resort-showcase-media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: rgb(28 24 18 / 0.06);
  box-shadow: var(--tpl-shadow-md);
}

[data-template="grand-resort"] .resort-showcase-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 1200ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-showcase-media:hover img {
  transform: scale(1.04);
}

[data-template="grand-resort"] .resort-showcase-media-frame {
  position: absolute;
  inset: 1.25rem;
  border: 1px solid rgb(255 255 255 / 0.55);
  pointer-events: none;
  z-index: 2;
}

[data-template="grand-resort"] .resort-showcase-copy {
  padding: 0 0.5rem;
}

[data-template="grand-resort"] .resort-showcase-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(111 78 31);
  margin: 0 0 1.1rem;
}

[data-template="grand-resort"] .resort-showcase-title {
  font-family: var(--font-heading);
  font-size: clamp(1.95rem, 1.4rem + 2vw, 3rem);
  font-weight: 400;
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: rgb(28 24 18);
  margin: 0 0 1.4rem;
  max-width: 16ch;
}

[data-template="grand-resort"] .resort-showcase-body {
  font-family: var(--font-body);
  font-size: clamp(0.96rem, 0.92rem + 0.18vw, 1.06rem);
  line-height: 1.78;
  color: rgb(28 24 18 / 0.74);
  margin: 0 0 1.8rem;
  max-width: 32rem;
}

[data-template="grand-resort"] .resort-showcase-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin: 1.5rem 0;
  padding: 1.25rem 0;
  border-top: 1px solid rgb(168 130 74 / 0.24);
  border-bottom: 1px solid rgb(168 130 74 / 0.24);
}

[data-template="grand-resort"] .resort-showcase-meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

[data-template="grand-resort"] .resort-showcase-meta-label {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.78);
}

[data-template="grand-resort"] .resort-showcase-meta-value {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: rgb(28 24 18);
}

[data-template="grand-resort"] .resort-showcase-link {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(111 78 31);
  text-decoration: none;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgb(111 78 31 / 0.42);
  transition: color 220ms var(--ease-slow), border-color 220ms var(--ease-slow), gap 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-showcase-link:hover {
  color: rgb(78 95 60);
  border-color: rgb(78 95 60);
  gap: 0.95rem;
}

[data-template="grand-resort"] .resort-showcase-link svg {
  transition: transform 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-showcase-link:hover svg {
  transform: translateX(3px);
}

/* --- Experiences 3-col grid --- */
[data-template="grand-resort"] .resort-experiences {
  position: relative;
  background: rgb(245 240 228);
  padding: clamp(5rem, 4rem + 5vw, 8rem) 0;
}

[data-template="grand-resort"] .resort-section-head {
  display: grid;
  gap: 1.1rem;
  text-align: center;
  max-width: 46rem;
  margin: 0 auto clamp(2.5rem, 2rem + 2vw, 4rem);
}

[data-template="grand-resort"] .resort-section-head-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.78);
  margin: 0;
}

[data-template="grand-resort"] .resort-section-head-title {
  font-family: var(--font-heading);
  font-size: clamp(1.95rem, 1.4rem + 2vw, 3rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: rgb(28 24 18);
  margin: 0;
}

[data-template="grand-resort"] .resort-section-head-body {
  font-family: var(--font-body);
  font-size: clamp(0.95rem, 0.9rem + 0.18vw, 1.04rem);
  line-height: 1.72;
  color: rgb(28 24 18 / 0.74);
  margin: 0;
}

[data-template="grand-resort"] .resort-experiences-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.75rem;
}

@media (min-width: 768px) {
  [data-template="grand-resort"] .resort-experiences-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}

@media (min-width: 1024px) {
  [data-template="grand-resort"] .resort-experiences-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
  }
}

[data-template="grand-resort"] .resort-exp-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: rgb(255 255 255 / 0.7);
  border: 1px solid rgb(168 130 74 / 0.18);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 480ms var(--ease-slow), box-shadow 480ms var(--ease-slow), border-color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-exp-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--tpl-shadow-md);
  border-color: rgb(168 130 74 / 0.42);
}

[data-template="grand-resort"] .resort-exp-card-media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: rgb(28 24 18 / 0.06);
}

[data-template="grand-resort"] .resort-exp-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 1400ms var(--ease-slow), filter 600ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-exp-card:hover .resort-exp-card-media img {
  transform: scale(1.05);
  filter: brightness(1.04);
}

[data-template="grand-resort"] .resort-exp-card-body {
  padding: 1.4rem 1.5rem 1.6rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

[data-template="grand-resort"] .resort-exp-card-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgb(111 78 31 / 0.72);
  margin: 0;
}

[data-template="grand-resort"] .resort-exp-card-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: rgb(28 24 18);
  margin: 0;
}

[data-template="grand-resort"] .resort-exp-card-body p {
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.62;
  color: rgb(28 24 18 / 0.7);
  margin: 0;
}

[data-template="grand-resort"] .resort-exp-card-cta {
  margin-top: auto;
  padding-top: 0.75rem;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(111 78 31);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

/* --- Location + Final CTA --- */
[data-template="grand-resort"] .resort-locale {
  position: relative;
  padding: clamp(5rem, 4rem + 5vw, 8rem) 0;
  background:
    linear-gradient(180deg, rgb(28 52 39 / 0.85) 0%, rgb(21 39 29 / 0.92) 100%),
    rgb(28 52 39);
  color: rgb(255 255 255);
  overflow: hidden;
}

[data-template="grand-resort"] .resort-locale-grid {
  display: grid;
  gap: 3rem;
  grid-template-columns: 1fr;
  align-items: center;
}

@media (min-width: 960px) {
  [data-template="grand-resort"] .resort-locale-grid {
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
  }
}

[data-template="grand-resort"] .resort-locale-eyebrow {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.6);
  margin: 0 0 1.2rem;
}

[data-template="grand-resort"] .resort-locale-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 1.5rem + 2vw, 3.2rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: rgb(255 255 255 / 0.98);
  margin: 0 0 1.4rem;
  max-width: 14ch;
}

[data-template="grand-resort"] .resort-locale-body {
  font-family: var(--font-body);
  font-size: clamp(0.96rem, 0.92rem + 0.18vw, 1.06rem);
  line-height: 1.78;
  color: rgb(255 255 255 / 0.72);
  margin: 0 0 2rem;
  max-width: 30rem;
}

[data-template="grand-resort"] .resort-locale-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}

[data-template="grand-resort"] .resort-locale-actions .btn-primary {
  background: rgb(255 255 255);
  color: rgb(28 52 39);
  border-color: rgb(255 255 255);
  min-width: 13rem;
  justify-content: center;
}

[data-template="grand-resort"] .resort-locale-actions .btn-primary:hover {
  background: rgb(245 240 228);
  border-color: rgb(245 240 228);
}

[data-template="grand-resort"] .resort-locale-actions .btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 0;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.92);
  text-decoration: none;
  border-bottom: 1px solid rgb(255 255 255 / 0.4);
  transition: gap 220ms var(--ease-slow), border-color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-locale-actions .btn-ghost:hover {
  gap: 0.95rem;
  border-color: rgb(255 255 255);
}

[data-template="grand-resort"] .resort-locale-meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 2.5rem;
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgb(255 255 255 / 0.15);
}

[data-template="grand-resort"] .resort-locale-meta-label {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.58);
  margin: 0 0 0.4rem;
}

[data-template="grand-resort"] .resort-locale-meta-value {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: rgb(255 255 255 / 0.94);
  margin: 0;
  line-height: 1.4;
}

[data-template="grand-resort"] .resort-locale-card {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: rgb(255 255 255 / 0.06);
  border: 1px solid rgb(255 255 255 / 0.1);
}

[data-template="grand-resort"] .resort-locale-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

[data-template="grand-resort"] .resort-locale-card-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgb(28 52 39 / 0) 40%, rgb(21 39 29 / 0.88) 100%);
  display: flex;
  align-items: flex-end;
  padding: 2rem;
}

[data-template="grand-resort"] .resort-locale-card-tag {
  font-family: var(--font-mono, var(--font-body));
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgb(255 255 255 / 0.92);
  margin: 0;
}

@media (max-width: 767px) {
  [data-template="grand-resort"] .resort-locale-meta {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}

/* --- Reveal animation hooks (already wired in _Layout.cshtml IO) --- */
[data-template="grand-resort"] .resort-promise,
[data-template="grand-resort"] .resort-showcase,
[data-template="grand-resort"] .resort-experiences,
[data-template="grand-resort"] .resort-locale {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 800ms var(--ease-slow), transform 900ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-promise.is-visible,
[data-template="grand-resort"] .resort-showcase.is-visible,
[data-template="grand-resort"] .resort-experiences.is-visible,
[data-template="grand-resort"] .resort-locale.is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-template="grand-resort"] .resort-exp-card {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms var(--ease-slow), transform 800ms var(--ease-slow), box-shadow 480ms var(--ease-slow), border-color 220ms var(--ease-slow);
}

[data-template="grand-resort"] .resort-exp-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-template="grand-resort"] .resort-exp-card.is-visible:nth-child(2) { transition-delay: 90ms; }
[data-template="grand-resort"] .resort-exp-card.is-visible:nth-child(3) { transition-delay: 180ms; }
[data-template="grand-resort"] .resort-exp-card.is-visible:nth-child(4) { transition-delay: 270ms; }

@media (prefers-reduced-motion: reduce) {
  [data-template="grand-resort"] .resort-promise,
  [data-template="grand-resort"] .resort-showcase,
  [data-template="grand-resort"] .resort-experiences,
  [data-template="grand-resort"] .resort-locale,
  [data-template="grand-resort"] .resort-exp-card {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* =============================================================================
   RESORT REVAMP 2026-06 — EDITORIAL SERIF HEADING REFINEMENT
   --font-heading artık serif (Lora — NG Hotels referansı; fallback Cormorant).
   Lora yüksek x-height + dolgun gövde: ekran için optimize, küçük boyutta da
   okunaklı. Negatif letter-spacing'i ölçülü tut (harfler dolu → fazla sıkışmasın);
   display weight 500-600 ideal. UI öğeleri (buton/nav/ribbon/label) sans kalır.
   Bu blok mevcut tanımları override eder (cascade: en sonda → kazanır).
   ============================================================================= */

/* ── Display başlıklar: serif, gevşek tracking, nefesli line-height ── */
[data-template="grand-resort"] h1,
[data-template="grand-resort"] .h1 {
  letter-spacing: -0.005em;
  line-height: 1.04;
  font-weight: 500;
  font-variation-settings: normal;  /* Cormorant'ta opsz ekseni yok */
  font-optical-sizing: auto;
}

[data-template="grand-resort"] h2,
[data-template="grand-resort"] .h2 {
  letter-spacing: 0;
  line-height: 1.14;
  font-weight: 500;
  font-variation-settings: normal;
}

[data-template="grand-resort"] h3,
[data-template="grand-resort"] .h3 {
  letter-spacing: 0;
  line-height: 1.3;
  font-weight: 500;  /* Cormorant 400 başlıkta fazla ince */
}

/* ── Hero & sayfa başlıkları — dramatik serif display ── */
[data-template="grand-resort"] .resort-hero-title {
  letter-spacing: -0.015em;
  line-height: 1.0;
  font-weight: 500;
}

[data-template="grand-resort"] .hero-title {
  letter-spacing: -0.01em;
  font-weight: 500;
}

[data-template="grand-resort"] .resort-page-copy .editorial-page-title,
[data-template="grand-resort"] .editorial-page-title {
  letter-spacing: -0.005em;
  line-height: 1.02;
  font-weight: 500;
}

/* ── Kart/listeleme başlıkları — Lora küçükte de okunaklı; weight 600 net ── */
[data-template="grand-resort"] .listing-card-title {
  letter-spacing: 0;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.25;
}

/* ── Stat değerleri: serif ince zarif rakam ── */
[data-template="grand-resort"] .stat-value {
  font-weight: 400;
  letter-spacing: 0;
}

/* ── Testimonial: serif italic kalsın, tracking sıfırla ── */
[data-template="grand-resort"] blockquote {
  letter-spacing: 0;
}

/* ── UI butonları SANS: Cormorant small-caps butonda zayıf; referanslar (NG
   "ARAMA", Regnum Montserrat) sans uppercase kullanır ── */
[data-template="grand-resort"] .btn-primary,
[data-template="grand-resort"] .btn-secondary {
  font-family: var(--font-display-sans);
  font-variant: normal;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
}

/* ── Tertiary serif italic link — Lora italic güzel durur, biraz büyüt ── */
[data-template="grand-resort"] .btn-tertiary,
[data-template="grand-resort"] a.link-reserve {
  font-size: 1.15rem;
}

/* =============================================================================
   LORA KOMPOZİSYON POLİSH — 2026-06 Faz A genişletme
   Serif display'i daha sinematik ölçeğe taşır + section ritmine nefes verir.
   Renk token'a DOKUNMAZ (brand-kit override güvenli): yalnız ölçek/spacing/optik
   ve sabit literal gölge. Pilot (sarman) bu blueprint değişikliğini onaysız
   almaz — demo (cwhotel) üzerinden görsel doğrulama; onay sonrası pilot Güncelle.
   ============================================================================= */

/* Hero: daha cömert serif display + nefesli alt-hizalama */
[data-template="grand-resort"] .resort-hero-title {
  font-size: clamp(3.4rem, 2.1rem + 4.6vw, 6.6rem);
}
[data-template="grand-resort"] .resort-hero-brand {
  letter-spacing: 0.24em;
}
[data-template="grand-resort"] .resort-hero-summary {
  max-width: 38rem;
  line-height: 1.75;
}

/* Section başlıkları: Lora display için biraz daha cömert ölçek (responsive clamp) */
[data-template="grand-resort"] .resort-promise-title {
  font-size: clamp(2.4rem, 1.6rem + 2.8vw, 4rem);
  line-height: 1.06;
}
[data-template="grand-resort"] .resort-showcase-title,
[data-template="grand-resort"] .resort-section-head-title {
  font-size: clamp(2.1rem, 1.4rem + 2.3vw, 3.35rem);
}
[data-template="grand-resort"] .resort-locale-title {
  font-size: clamp(2.2rem, 1.5rem + 2.4vw, 3.5rem);
}

/* Promise band: üst hairline'ı biraz uzat — daha belirgin editorial işaret */
[data-template="grand-resort"] .resort-promise::before {
  height: 5rem;
}

/* Deneyim kartı: hover'da daha belirgin yükseliş + zarif derin gölge */
[data-template="grand-resort"] .resort-exp-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgb(28 24 18 / 0.14);
}

/* Showcase çerçevesi: daha sıkı inset + net beyaz hairline (görsel üstü zarafet) */
[data-template="grand-resort"] .resort-showcase-media-frame {
  inset: 1rem;
  border-color: rgb(255 255 255 / 0.5);
}

/* ============================================================
   FAZ C — RESORT BLOCK COMPONENT KÜTÜPHANESİ (2026-06-02)
   RoomTabBlock · ImageWithContentBlock · ExperienceGridBlock · RoomFeatureBlock
   ============================================================ */

/* ---- RoomTabBlock: sekmeli oda gezgini ---- */
[data-template="grand-resort"] .lp-room-tabs__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 2rem;
  border-bottom: 1px solid rgb(var(--color-border));
  margin-bottom: 2.5rem;
}
[data-template="grand-resort"] .lp-room-tabs__tab {
  appearance: none;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--font-heading);
  font-size: 0.78rem;
  font-variant: small-caps;
  letter-spacing: 0.14em;
  color: rgb(var(--color-text-light));
  padding: 0.9rem 0.25rem;
  margin-bottom: -1px;
  border-bottom: 1px solid transparent;
  transition: color 0.3s ease, border-color 0.3s ease;
}
[data-template="grand-resort"] .lp-room-tabs__tab:hover {
  color: rgb(var(--color-heading));
}
[data-template="grand-resort"] .lp-room-tabs__tab.is-active {
  color: rgb(var(--color-heading));
  border-bottom-color: rgb(var(--color-accent));
}
[data-template="grand-resort"] .lp-room-tabs__panel {
  display: none;
}
[data-template="grand-resort"] .lp-room-tabs__panel.is-active {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 3rem;
  align-items: center;
  animation: lpRoomTabFade 0.5s ease;
}
/* III — Konaklama: desktop'ta görsel sağda, metin solda (2026-06-04 kullanıcı isteği).
   Mobilde (≤860px) DOM sırası korunur: görsel üstte, metin altta. */
@media (min-width: 861px) {
  [data-template="grand-resort"] .lp-room-tabs__panel.is-active {
    grid-template-columns: 1fr 1.15fr;
  }
  [data-template="grand-resort"] .lp-room-tabs__body {
    order: -1;
  }
}
@keyframes lpRoomTabFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
[data-template="grand-resort"] .lp-room-tabs__media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: rgb(var(--color-surface-alt));
}
[data-template="grand-resort"] .lp-room-tabs__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
[data-template="grand-resort"] .lp-room-tabs__panel.is-active:hover .lp-room-tabs__media img {
  transform: scale(1.04);
}
[data-template="grand-resort"] .lp-room-tabs__name {
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  line-height: 1.1;
  color: rgb(var(--color-heading));
  margin-bottom: 1.1rem;
}
[data-template="grand-resort"] .lp-room-tabs__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.25rem;
  list-style: none;
  padding: 0;
  margin: 0 0 1.4rem;
}
[data-template="grand-resort"] .lp-room-tabs__specs li {
  position: relative;
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-variant: small-caps;
  letter-spacing: 0.12em;
  color: rgb(var(--color-accent));
}
[data-template="grand-resort"] .lp-room-tabs__specs li + li::before {
  content: "·";
  position: absolute;
  left: -0.7rem;
  color: rgb(var(--color-border));
}
[data-template="grand-resort"] .lp-room-tabs__desc {
  font-family: var(--font-body);
  color: rgb(var(--color-text-light));
  line-height: 1.75;
  margin-bottom: 1.75rem;
  max-width: 42ch;
}
@media (max-width: 860px) {
  [data-template="grand-resort"] .lp-room-tabs__panel.is-active {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }
  [data-template="grand-resort"] .lp-room-tabs__nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 1.5rem;
  }
  [data-template="grand-resort"] .lp-room-tabs__tab {
    white-space: nowrap;
  }
}

/* ---- ImageWithContentBlock: editoryal görsel + metin split ---- */
[data-template="grand-resort"] .lp-image-content__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
}
[data-template="grand-resort"] .lp-image-content__media {
  position: relative;
  overflow: hidden;
  min-height: 24rem;
}
[data-template="grand-resort"] .lp-image-content__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
[data-template="grand-resort"] .lp-image-content__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 3rem clamp(1.5rem, 5vw, 4.5rem);
}
[data-template="grand-resort"] .lp-image-content--reverse .lp-image-content__media {
  order: 2;
}
[data-template="grand-resort"] .lp-image-content__heading {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 3.2vw, 2.6rem);
  line-height: 1.12;
  color: rgb(var(--color-heading));
  margin: 0.6rem 0 1.25rem;
}
[data-template="grand-resort"] .lp-image-content__text {
  font-family: var(--font-body);
  color: rgb(var(--color-text-light));
  line-height: 1.8;
  max-width: 46ch;
}
[data-template="grand-resort"] .lp-image-content__cta {
  margin-top: 2rem;
  align-self: flex-start;
}
/* Zemin varyantları */
[data-template="grand-resort"] .lp-image-content--bg-light .lp-image-content__body {
  background: rgb(var(--color-surface));
}
[data-template="grand-resort"] .lp-image-content--bg-dark .lp-image-content__body {
  background: rgb(var(--color-heading));
}
[data-template="grand-resort"] .lp-image-content--bg-dark .lp-image-content__heading,
[data-template="grand-resort"] .lp-image-content--bg-dark .lp-image-content__text {
  color: rgb(255 255 255 / 0.92);
}
[data-template="grand-resort"] .lp-image-content--bg-dark .lp-image-content__overline {
  color: rgb(255 255 255 / 0.55);
}
[data-template="grand-resort"] .lp-image-content--bg-accent .lp-image-content__body {
  background: rgb(var(--color-accent) / 0.08);
}
@media (max-width: 860px) {
  [data-template="grand-resort"] .lp-image-content__grid {
    grid-template-columns: 1fr;
  }
  [data-template="grand-resort"] .lp-image-content--reverse .lp-image-content__media {
    order: 0;
  }
  [data-template="grand-resort"] .lp-image-content__media {
    min-height: 16rem;
  }
  [data-template="grand-resort"] .lp-image-content__body {
    padding: 2.5rem 1.5rem;
  }
}

/* ---- ExperienceGridBlock: Lumina görsel-led tile (görsel üstte + içerik altta, gap-px hairline) ---- */
[data-template="grand-resort"] .lp-exp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;                              /* hairline separators */
  background: rgb(var(--color-border));
  margin-top: 3rem;
}
[data-template="grand-resort"] .lp-exp-grid--2 { grid-template-columns: repeat(2, 1fr); }
[data-template="grand-resort"] .lp-exp-grid--3 { grid-template-columns: repeat(3, 1fr); }
[data-template="grand-resort"] .lp-exp-grid--4 { grid-template-columns: repeat(4, 1fr); }
[data-template="grand-resort"] .lp-exp-tile-outer { display: flex; }
[data-template="grand-resort"] .lp-exp-tile {
  display: flex;
  flex-direction: column;
  width: 100%;
  background: rgb(var(--color-bg));
  text-decoration: none;
  color: inherit;
}
[data-template="grand-resort"] .lp-exp-tile__media {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
[data-template="grand-resort"] .lp-exp-tile__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}
[data-template="grand-resort"] .lp-exp-tile.group:hover .lp-exp-tile__img { transform: scale(1.06); }
[data-template="grand-resort"] .lp-exp-tile__body {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  flex: 1;
  padding: 1.6rem;
}
[data-template="grand-resort"] .lp-exp-tile__tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(var(--color-primary));
}
[data-template="grand-resort"] .lp-exp-tile__title {
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: clamp(1.25rem, 1.5vw, 1.55rem);
  line-height: 1.2;
  color: rgb(var(--color-heading));
  margin: 0;
}
[data-template="grand-resort"] .lp-exp-tile__text {
  font-family: var(--font-body);
  font-size: 0.93rem;
  line-height: 1.7;
  color: rgb(var(--color-text-muted));
  margin: 0;
}
[data-template="grand-resort"] .lp-exp-tile__link {
  margin-top: auto;
  padding-top: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(var(--color-primary));
}
[data-template="grand-resort"] .lp-exp-tile__link svg { transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1); }
[data-template="grand-resort"] .lp-exp-tile.group:hover .lp-exp-tile__link svg { transform: translateX(4px); }
@media (max-width: 860px) {
  [data-template="grand-resort"] .lp-exp-grid,
  [data-template="grand-resort"] .lp-exp-grid--2,
  [data-template="grand-resort"] .lp-exp-grid--3,
  [data-template="grand-resort"] .lp-exp-grid--4 {
    grid-template-columns: 1fr;
  }
}

/* ---- ImageWithContentBlock: Lumina dropcap + frame-within-frame (§1.10) ---- */
[data-template="grand-resort"] .lp-image-content__text > p:first-child::first-letter {
  font-family: var(--font-heading);
  font-size: 3.2em;
  float: left;
  line-height: 0.78;
  padding: 0.08em 0.14em 0 0;
  color: rgb(var(--color-primary));
}
[data-template="grand-resort"] .lp-image-content__media { position: relative; }
[data-template="grand-resort"] .lp-image-content__media::after {
  content: "";
  position: absolute;
  inset: 0.85rem;
  border: 1px solid rgb(var(--color-bg) / 0.55);
  pointer-events: none;
  z-index: 1;
}

/* ---- ImageGallery: Lumina mosaic variant (büyük 2×2 + hairline gap + caption) ---- */
[data-template="grand-resort"] .lp-gallery-mosaic {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 215px;
  gap: 1rem;
  grid-auto-flow: dense;
  margin-top: 2.5rem;
}
[data-template="grand-resort"] .lp-gallery-mosaic__item {
  position: relative;
  overflow: hidden;
  margin: 0;
}
[data-template="grand-resort"] .lp-gallery-mosaic__item.is-big {
  grid-column: span 2;
  grid-row: span 2;
}
[data-template="grand-resort"] .lp-gallery-mosaic__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.4s cubic-bezier(0.22, 1, 0.36, 1);
}
[data-template="grand-resort"] .lp-gallery-mosaic__item.group:hover img { transform: scale(1.07); }
[data-template="grand-resort"] .lp-gallery-mosaic__cap {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 0.9rem;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgb(var(--color-bg));
  background: linear-gradient(0deg, rgb(20 18 12 / 0.65), transparent);
}
@media (max-width: 860px) {
  [data-template="grand-resort"] .lp-gallery-mosaic { grid-template-columns: repeat(2, 1fr); }
  [data-template="grand-resort"] .lp-gallery-mosaic__item.is-big { grid-column: span 2; grid-row: span 1; }
}

/* ---- AmenityGrid: Lumina line-icon hairline grid (sol hizalı, gap-px, brass ikon) ---- */
[data-template="grand-resort"] .lp-amenity-grid__grid {
  display: grid;
  grid-template-columns: repeat(var(--lp-amenity-cols, 4), 1fr);
  gap: 1px;
  background: rgb(var(--color-border));
  border: 1px solid rgb(var(--color-border));
  margin-top: 3rem;
}
[data-template="grand-resort"] .lp-amenity-grid__cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 1.85rem 1.6rem;
  background: rgb(var(--color-bg));
  text-align: left;
}
[data-template="grand-resort"] .lp-amenity-grid__icon-wrap {
  display: inline-flex;
  color: rgb(var(--color-primary));
}
[data-template="grand-resort"] .lp-amenity-grid__icon-wrap svg {
  width: 30px;
  height: 30px;
}
[data-template="grand-resort"] .lp-amenity-grid__name {
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 1.02rem;
  line-height: 1.25;
  color: rgb(var(--color-heading));
  margin: 0;
}
[data-template="grand-resort"] .lp-amenity-grid__text {
  font-family: var(--font-body);
  font-size: 0.86rem;
  line-height: 1.6;
  color: rgb(var(--color-text-muted));
  margin: 0;
}
@media (max-width: 860px) {
  [data-template="grand-resort"] .lp-amenity-grid__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  [data-template="grand-resort"] .lp-amenity-grid__grid { grid-template-columns: 1fr; }
}

/* ---- CtaBlock: Lumina dark image band (brass eyebrow + cream metin + light pill) ---- */
[data-template="grand-resort"] .lp-cta-block--banner .overlay {
  background: linear-gradient(180deg, rgb(20 18 12 / 0.40), rgb(20 18 12 / 0.68));
}
[data-template="grand-resort"] .lp-cta-block--banner h2,
[data-template="grand-resort"] .lp-cta-block--banner p {
  color: rgb(var(--color-bg)) !important;
}
[data-template="grand-resort"] .lp-cta-block__eyebrow {
  color: rgb(var(--color-primary)) !important;
  margin-bottom: 1.1rem;
}
[data-template="grand-resort"] .lp-cta-block__pill {
  background: rgb(var(--color-bg));
  color: rgb(var(--color-heading));
  border: 0;
  border-radius: 999px;
  padding: 0.9rem 2.2rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease;
}
[data-template="grand-resort"] .lp-cta-block__pill:hover {
  background: rgb(var(--color-primary));
  color: rgb(var(--color-bg));
  transform: translateY(-2px);
}

/* ---- RoomFeatureBlock: yatay oda spec bar ---- */
[data-template="grand-resort"] .lp-room-features__heading {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  color: rgb(var(--color-heading));
  margin-bottom: 1.5rem;
}
[data-template="grand-resort"] .lp-room-features__bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-block: 1px solid rgb(var(--color-border));
}
[data-template="grand-resort"] .lp-room-features__item {
  flex: 1 1 0;
  min-width: 9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.35rem;
  padding: 1.85rem 1rem;
  border-inline-start: 1px solid rgb(var(--color-border));
}
[data-template="grand-resort"] .lp-room-features__item:first-child {
  border-inline-start: none;
}
[data-template="grand-resort"] .lp-room-features__icon {
  color: rgb(var(--color-accent));
  margin-bottom: 0.25rem;
}
[data-template="grand-resort"] .lp-room-features__icon :is(svg) {
  width: 1.4rem;
  height: 1.4rem;
}
[data-template="grand-resort"] .lp-room-features__value {
  font-family: var(--font-heading);
  font-size: 1.45rem;
  line-height: 1;
  color: rgb(var(--color-heading));
}
[data-template="grand-resort"] .lp-room-features__label {
  font-family: var(--font-heading);
  font-size: 0.68rem;
  font-variant: small-caps;
  letter-spacing: 0.12em;
  color: rgb(var(--color-text-light));
}
@media (max-width: 640px) {
  [data-template="grand-resort"] .lp-room-features__item {
    flex-basis: 50%;
    border-block-start: 1px solid rgb(var(--color-border));
  }
  [data-template="grand-resort"] .lp-room-features__item:nth-child(-n+2) {
    border-block-start: none;
  }
  [data-template="grand-resort"] .lp-room-features__item:nth-child(odd) {
    border-inline-start: none;
  }
}

/* =============================================================================
   LUMINA FLAT PASS — neutralise inline-utility shadows + rounding on content
   cards. Editorial flat aesthetic = radius 0 + hairline borders, depth from
   imagery & dark bands. Scoped to grand-resort; other sectors keep their look.
   (Pills / .rounded-full CTAs intentionally NOT flattened.)
   ============================================================================= */
[data-template="grand-resort"] .lp-stats__cell,
[data-template="grand-resort"] .lp-card-grid .card,
[data-template="grand-resort"] .lp-pricing-tier,
[data-template="grand-resort"] .lp-amenity-grid__cell,
[data-template="grand-resort"] .badge {
  box-shadow: none !important;
  border-radius: 0 !important;
}
[data-template="grand-resort"] .lp-stats__cell:hover,
[data-template="grand-resort"] .lp-card-grid .card:hover,
[data-template="grand-resort"] .lp-pricing-tier:hover {
  box-shadow: none !important;
}
/* Pricing tier layout: BlockGrid 6-kolon hücrede kart `max-w-md mx-auto` ile hücre
   ortasına çekilince iki tier iki uca dağılıp ortada boşluk kalıyordu. max-width:none
   kartın hücreyi doldurmasını sağlar → iki tier yan yana, dengeli. (grand-resort scope) */
[data-template="grand-resort"] .lp-pricing-tier {
  max-width: none;
}
/* Flat cards earn hover affordance from a border-colour shift, not elevation. */
[data-template="grand-resort"] .lp-card-grid .card {
  transition: border-color var(--dur-snap, 180ms) var(--ease, ease);
}
[data-template="grand-resort"] .lp-card-grid .card:hover {
  border-color: rgb(var(--color-border-strong)) !important;
}

/* — STATS → dark editorial band (cells form the band; mono numerals, brass hairline) — */
[data-template="grand-resort"] .lp-stats__cell {
  background: rgb(var(--color-overlay)) !important;
  border: none !important;
  border-right: 1px solid rgb(var(--color-brass) / 0.22) !important;
}
[data-template="grand-resort"] .lp-stats__cell:last-child {
  border-right: none !important;
}
[data-template="grand-resort"] .lp-stats__value {
  font-family: var(--font-mono) !important;   /* mono numerals — Lumina stat signature */
  font-weight: 400 !important;
  color: rgb(var(--color-bg)) !important;
}
[data-template="grand-resort"] .lp-stats__label {
  color: rgb(var(--color-bg) / 0.6) !important;
}
[data-template="grand-resort"] .lp-stats__icon {
  color: rgb(var(--color-brass)) !important;
}

/* — TESTIMONIAL → dark ink band (brass ghost-quote + stars, cream serif quote) — */
[data-template="grand-resort"] .lp-testimonials {
  background: rgb(var(--color-overlay)) !important;
}
[data-template="grand-resort"] .lp-testimonials .block-heading-wrap h2,
[data-template="grand-resort"] .lp-testimonial-highlight p {
  color: rgb(var(--color-bg)) !important;
}
[data-template="grand-resort"] .lp-testimonials .ghost-quote {
  color: rgb(var(--color-brass) / 0.5) !important;
}
[data-template="grand-resort"] .lp-testimonials svg {
  color: rgb(var(--color-brass)) !important;   /* rating stars */
}
[data-template="grand-resort"] .lp-testimonials small {
  color: rgb(var(--color-bg) / 0.5) !important;
}
[data-template="grand-resort"] .lp-testimonial-highlight .block-avatar {
  background: rgb(var(--color-bg) / 0.08) !important;
  border-color: rgb(var(--color-bg) / 0.24) !important;
  color: rgb(var(--color-bg)) !important;
}

/* =============================================================================
   FAZ İ3 — LUMINA INNER-PAGE BLOCK POLISH (grand-resort · additive · scoped)
   block-overline brass eyebrow · resort hero numeral/subtitle · accordion ·
   contact form · lead capture · gallery flat. Other sectors untouched.
   ============================================================================= */

/* Block overline → brass mono eyebrow (chapter-eyebrow language). Cascades to
   Hero/Cta/CardGrid/AmenityGrid/ExperienceGrid/ImageWithContent/RoomTab/Gallery. */
[data-template="grand-resort"] .block-overline {
  font-family:    var(--font-mono);
  letter-spacing: 0.28em;
  color:          rgb(var(--color-primary));
}

/* Resort inner-page hero — chapter numeral + descriptive subtitle
   (emitted by _ResortPageHero.cshtml when provided). */
[data-template="grand-resort"] .resort-page-hero__numeral {
  display:        block;
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.30em;
  text-transform: uppercase;
  color:          rgb(var(--color-brass));
  margin-bottom:  0.85rem;
}
[data-template="grand-resort"] .resort-page-hero__subtitle {
  margin-top:  1.1rem;
  max-width:   40rem;
  font-family: var(--font-body);
  font-size:   1.0625rem;
  line-height: 1.6;
  color:       rgb(255 255 255 / 0.84);
}

/* Accordion (FAQ) → serif question, hairline divider, brass active. */
[data-template="grand-resort"] .lp-accordion summary {
  font-family:    var(--font-heading);
  font-size:      1.3rem;
  font-weight:    500;
  letter-spacing: -0.01em;
  color:          rgb(var(--color-heading));
  padding:        1.4rem 0;
}
[data-template="grand-resort"] .lp-accordion details[open] summary {
  color: rgb(var(--color-primary));
}

/* Contact form → mono uppercase labels, flat brass-focus fields. */
[data-template="grand-resort"] .lp-contact-form .form-label {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-light));
}
[data-template="grand-resort"] .lp-contact-input {
  border-radius: 0 !important;
  border:        1px solid rgb(var(--color-border));
}
[data-template="grand-resort"] .lp-contact-input:focus {
  outline:      none;
  border-color: rgb(var(--color-brass));
  box-shadow:   none;
}

/* Lead capture → flat brass-focus email field. */
[data-template="grand-resort"] .lp-lead-capture input[type="email"] {
  border-radius: 0 !important;
  border:        1px solid rgb(var(--color-border));
}
[data-template="grand-resort"] .lp-lead-capture input[type="email"]:focus {
  border-color: rgb(var(--color-brass));
  box-shadow:   none;
}

/* Gallery grid / slider → flat corners (mosaic already styled above). */
[data-template="grand-resort"] .lp-gallery img {
  border-radius: 0;
}

/* =============================================================================
   FAZ K — KONAKLAMA (Lumina StayPage) · grand-resort · scoped · additive
   In-page hero CTA (glass, mirrors home resort-hero-actions) + room-type card
   grid (tag rozet · meta · fiyat/Detay footer). Felsefe (lp-image-content) +
   Standart (lp-amenity-grid) İ3 stillerini yeniden kullanır. Diğer sektörler etkilenmez.
   ============================================================================= */

/* In-page hero CTA row — glass light button on the dark scrim (= home hero). */
[data-template="grand-resort"] .resort-page-hero__actions {
  margin-top: 2rem;
  display:    flex;
  flex-wrap:  wrap;
  gap:        0.9rem;
}
[data-template="grand-resort"] .resort-page-hero__actions .btn-primary {
  min-width:                13rem;
  justify-content:          center;
  border-color:             rgb(255 255 255 / 0.22);
  background:               rgb(255 255 255 / 0.12);
  color:                    rgb(255 255 255 / 0.98);
  backdrop-filter:          blur(10px);
  -webkit-backdrop-filter:  blur(10px);
}
[data-template="grand-resort"] .resort-page-hero__actions .btn-primary:hover {
  background: rgb(255 255 255 / 0.2);
}

/* Room-type card grid — 1 / 2 / 3 columns. */
[data-template="grand-resort"] .lp-room-grid {
  display:               grid;
  grid-template-columns: 1fr;
  gap:                   2rem;
}
@media (min-width: 768px) {
  [data-template="grand-resort"] .lp-room-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  [data-template="grand-resort"] .lp-room-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Room card — flat editorial: cream surface, hairline border, no radius. */
[data-template="grand-resort"] .lp-room-card {
  display:         flex;
  flex-direction:  column;
  height:          100%;
  background:      rgb(var(--color-surface));
  border:          1px solid rgb(var(--color-border));
  text-decoration: none;
  transition:      border-color var(--dur-snap, 180ms) var(--ease, ease);
}
[data-template="grand-resort"] .lp-room-card:hover {
  border-color: rgb(var(--color-border-strong));
}
[data-template="grand-resort"] .lp-room-card__media {
  position: relative;
  overflow: hidden;
}
[data-template="grand-resort"] .lp-room-card__img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform 1200ms var(--ease-slow, cubic-bezier(0.22, 1, 0.36, 1));
}
[data-template="grand-resort"] .lp-room-card:hover .lp-room-card__img {
  transform: scale(1.05);
}
[data-template="grand-resort"] .lp-room-card__tag {
  position:       absolute;
  top:            1rem;
  left:           1rem;
  padding:        0.4rem 0.8rem;
  font-family:    var(--font-mono);
  font-size:      0.6rem;
  font-weight:    500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
  background:     rgb(var(--color-bg));
}
[data-template="grand-resort"] .lp-room-card__body {
  display:        flex;
  flex:           1;
  flex-direction: column;
  padding:        1.75rem;
}
[data-template="grand-resort"] .lp-room-card__meta {
  font-family:    var(--font-mono);
  font-size:      0.62rem;
  font-weight:    500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
}
[data-template="grand-resort"] .lp-room-card__title {
  margin-top:     0.55rem;
  font-family:    var(--font-heading);
  font-size:      clamp(1.35rem, 1.7vw, 1.7rem);
  font-weight:    500;
  letter-spacing: -0.01em;
  line-height:    1.1;
  color:          rgb(var(--color-heading));
}
[data-template="grand-resort"] .lp-room-card__desc {
  margin-top:  0.85rem;
  flex:        1;
  font-family: var(--font-body);
  font-size:   0.95rem;
  line-height: 1.6;
  color:       rgb(var(--color-text-muted));
}
[data-template="grand-resort"] .lp-room-card__footer {
  margin-top:      1.5rem;
  padding-top:     1.25rem;
  border-top:      1px solid rgb(var(--color-border));
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             1rem;
}
[data-template="grand-resort"] .lp-room-card__price {
  font-family:    var(--font-mono);
  font-size:      0.95rem;
  font-weight:    500;
  letter-spacing: 0.02em;
  color:          rgb(var(--color-heading));
}
[data-template="grand-resort"] .lp-room-card__link {
  font-family:    var(--font-mono);
  font-size:      0.68rem;
  font-weight:    500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
  white-space:    nowrap;
}

/* =============================================================================
   FAZ 0a — BLOCK PARTIAL FIDELITY POLISH (grand-resort · additive · scoped)
   Fills gaps between BlockGrid partial defaults and Lumina demo dark-band styles.
   All rules grand-resort-scoped; other templates/sectors untouched.
   ============================================================================= */

/* — TESTIMONIAL: author name → mono uppercase cream (demo pattern)
     Partial emits <p class="font-medium text-sm tracking-wide"> for author.
     Existing rules cover quote text + heading + stars + avatar but missed this p. — */
[data-template="grand-resort"] .lp-testimonials .lp-testimonial-highlight p.font-medium {
  font-family:    var(--font-mono) !important;
  font-size:      0.68rem !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  font-weight:    500 !important;
  color:          rgb(var(--color-bg) / 0.7) !important;
}

/* — MAP: Lumina editorial sepia tone + cinematic aspect + hairline border.
     Partial emits .lp-map__frame with aspect-video + rounded + border.
     Grand-resort override: flat corners, 21:9 aspect, sepia filter. — */
[data-template="grand-resort"] .lp-map__frame {
  aspect-ratio:  21 / 9 !important;
  border-radius: 0 !important;
  border:        1px solid rgb(var(--color-border-strong)) !important;
  box-shadow:    none !important;
  filter:        sepia(0.32) saturate(0.8) contrast(0.95);
  overflow:      hidden;
}
[data-template="grand-resort"] .lp-map__frame iframe {
  width:  100%;
  height: 100%;
  border: none;
  display: block;
}

/* — PRICING TIER HIGHLIGHT: overlay dark bg + brass border + brass price.
     Partial uses bg-[rgb(var(--color-primary))] + text-white for featured tier.
     Grand-resort override: editorial overlay band + brass accent scheme.
     Note: inline Tailwind utilities on the element are overridden via !important. — */
[data-template="grand-resort"] .lp-pricing-tier--highlight {
  background: rgb(var(--color-overlay)) !important;
  border:     1px solid rgb(var(--color-brass)) !important;
  color:      rgb(var(--color-bg)) !important;
}
/* Badge inside highlight tier → brass bg (Lumina badge "En Çok Tercih Edilen") */
[data-template="grand-resort"] .lp-pricing-tier--highlight > span:first-child {
  background: rgb(var(--color-brass)) !important;
  color:      rgb(var(--color-overlay)) !important;
  border-radius: 0 !important;
}
/* Tier name inside highlight → cream/70 */
[data-template="grand-resort"] .lp-pricing-tier--highlight h3 {
  color: rgb(var(--color-bg) / 0.75) !important;
}
/* Price inside highlight → brass mono */
[data-template="grand-resort"] .lp-pricing-tier--highlight .text-4xl,
[data-template="grand-resort"] .lp-pricing-tier--highlight .text-5xl {
  color: rgb(var(--color-brass)) !important;
}
/* Feature list text inside highlight → cream/85 */
[data-template="grand-resort"] .lp-pricing-tier--highlight li {
  color: rgb(var(--color-bg) / 0.85) !important;
}
/* Feature check icon inside highlight → brass */
[data-template="grand-resort"] .lp-pricing-tier--highlight li svg {
  color: rgb(var(--color-brass)) !important;
}
/* CTA button inside highlight → light bg (cream on overlay, inverted) */
[data-template="grand-resort"] .lp-pricing-tier--highlight .btn:not(.btn-primary) {
  background: rgb(var(--color-bg)) !important;
  color:      rgb(var(--color-overlay)) !important;
  border-color: transparent !important;
}
/* Price divider inside highlight → brass/40 */
[data-template="grand-resort"] .lp-pricing-tier--highlight .border-b {
  border-color: rgb(var(--color-brass) / 0.4) !important;
}

/* — ACCORDION ADJACENT: collapse top-padding between consecutive accordion blocks.
     Each AccordionBlock.cshtml wraps in <section class="section lp-accordion">.
     When multiple blocks are placed back-to-back the 9rem section padding doubles.
     Solution: zero top padding on consecutive siblings, maintaining single rhythm. — */
[data-template="grand-resort"] section.lp-accordion + section.lp-accordion {
  padding-top: 0 !important;
}
