/* 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:
   - Regnum benchmark uses a disciplined sans-heavy luxury resort language.
   - We therefore use Montserrat for both display and UI copy to keep headlines,
     navigation, and body text in the same refined family.
   - Spec §1.3 calls Geist Mono → IBM Plex Mono (Google Fonts variable, Turkish-safe)
   Swap heading/body stack only if a future licensed hospitality family is preferred.
   ═══════════════════════════════════════════════════════════════════ */

/* Font loading: handled via _Layout.cshtml Google Fonts link tag (DM Serif Display, Inter, 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 (with free alternatives) ── */
  --font-heading: 'Montserrat', 'Inter', -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', sans-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);

  /* ── 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/corporate/holding.css --- */
/* ═══════════════════════════════════════════════════════════════════
   HOLDING — Corporate Editorial Authority
   Reference: Bloomberg Businessweek + Apollo Global + Linear + Stripe Press
   Spec: /design-spec-v2.md §2.3–2.5
   Fonts: DM Serif Display (Google Fonts) + Inter variable + JetBrains Mono variable
   All font tokens: Google Fonts compatible, Turkish character verified.
   ═══════════════════════════════════════════════════════════════════ */

/* Font loading: handled via _Layout.cshtml Google Fonts link tag (DM Serif Display, Inter, JetBrains Mono) */

[data-sector="corporate"] {
  /* ── Color tokens — §2.5 ── */
  --color-bg:            18 22 30;      /* #12161e deep midnight ink */
  --color-surface:       24 29 40;      /* #181d28 card, elevated panel */
  --color-surface-alt:   30 36 50;      /* #1e2432 section contrast */
  --color-text:         238 234 220;    /* #eeeadc warm ivory body */
  --color-text-muted:   155 148 130;    /* #9b9482 secondary, aged paper */
  --color-heading:      248 244 232;    /* #f8f4e8 heading brighter ivory */
  --color-primary:      178 130 58;     /* #b2823a copper bronze (client-overridable) */
  --color-primary-fg:    18 22 30;      /* #12161e dark text on copper */
  --color-accent:        82 105 148;    /* #526994 institutional blue */
  --color-border:        38 44 58;      /* #262c3a subtle divider */
  --color-border-strong: 60 68 88;      /* #3c4458 visible border */
  --color-overlay:       12 15 22;      /* scrim base — use /0.55 in usage */

  /* ── Semantic state tokens ── */
  --color-success:  88 162 100;         /* #58a264 */
  --color-warning: 210 158 48;          /* #d29e30 */
  --color-error:   210 78 62;           /* #d24e3e */
  --color-info:    100 148 208;         /* #6494d0 */

  /* ── Font stacks — §2.3 ── */
  --font-heading: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', 'SF Mono', 'Fira Code', Menlo, Consolas, monospace;
  --font-accent:  var(--font-mono);

  /* ── Motion tokens — §2.8 ── */
  --ease-precise:   cubic-bezier(0.4, 0, 0.2, 1);
  --ease-editorial: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --dur-glacier:    1400ms;
  --dur-smooth:     500ms;
  --dur-snap:       150ms;

  /* ── V1-compat aliases (used by _base-components.css) ── */
  --color-primary-light:  198 158 88;
  --color-primary-dark:   138 100 44;
  --color-secondary:      82 105 148;
  --color-secondary-light:110 135 178;
  --color-secondary-dark:  58  78 112;
  --color-accent-light:   110 135 178;
  --color-accent-dark:     58  78 112;
  --color-surface-dark:     8  10  16;
  --color-text-light:     155 148 130;
  --color-text-inverse:    18  22  30;

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

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

  --shadow-sm: 0 1px 4px rgb(0 0 0 / 0.20);
  --shadow-md: 0 2px 24px rgb(0 0 0 / 0.18);
  --shadow-lg: 0 8px 40px rgb(0 0 0 / 0.22);
  --shadow-xl: 0 16px 56px rgb(0 0 0 / 0.28);

  --space-section: 7rem;
  --space-block:   3rem;
  --space-element: 1rem;
}


/* --- tailwind/themes/landing/signature-story.css --- */
/* ═══════════════════════════════════════════════════════════════════
   SIGNATURE STORY — Cinematic Landing
   Reference: Dior Sauvage campaign site + Aesop + Studio Bruch
   Spec: /design-spec-v2.md §3.3–3.5

   NOTE: PP Neue Machina (Pangram Pangram) is a paid typeface.
   Space Grotesk (Google Fonts variable) used as free alternative.
   Swap --font-heading stack if PP Neue Machina license is acquired.

   NOTE: Geist Mono has no Google Fonts mirror.
   IBM Plex Mono (Google Fonts variable) used as free alternative.
   Both support Turkish characters (İ Ğ Ş Ç Ö Ü).
   ═══════════════════════════════════════════════════════════════════ */

/* Font loading: handled via _Layout.cshtml Google Fonts link tag (Archivo, Inter, IBM Plex Mono) */
/* Archivo variable (wght 100-900) replaces PP Neue Machina. Extreme weight contrast (H1=800, H3=200) now renders correctly. Turkish-safe. */

[data-sector="landing"] {
  /* ── Color tokens — §3.5 ── */
  --color-bg:             10  11  12;   /* #0a0b0c graphite cinema black */
  --color-surface:        16  18  20;   /* #101214 dark card */
  --color-surface-alt:    22  25  28;   /* #16191c deep shadow contrast */
  --color-text:          228 230 228;   /* #e4e6e4 cold off-white body */
  --color-text-muted:    122 126 124;   /* #7a7e7c zinc secondary */
  --color-heading:       245 246 244;   /* #f5f6f4 cold near-pure white */
  --color-primary:        32 198 188;   /* #20c6bc bioluminescence teal (client-overridable) */
  --color-primary-fg:     10  11  12;   /* #0a0b0c dark text on teal */
  --color-accent:        200 162  88;   /* #c8a258 ember gold ornament */
  --color-border:         28  30  32;   /* #1c1e20 barely visible hairline */
  --color-border-strong:  48  52  56;   /* #303438 visible edge */
  --color-overlay:        10  11  12;   /* scrim base — use /0.65 in usage */

  /* ── Semantic state tokens ── */
  --color-success:  56 186 132;         /* #38ba84 */
  --color-warning: 220 170  50;         /* #dcaa32 */
  --color-error:   230  60  68;         /* #e63c44 */
  --color-info:     80 160 220;         /* #50a0dc */

  /* ── Font stacks — §3.3 (with free alternatives noted) ── */
  /* NOTE: PP Neue Machina alternative — Archivo variable used (wght 100-900, width axis). Swap if license acquired. */
  --font-heading: 'Archivo', 'Space Grotesk', -apple-system, sans-serif;
  --font-body:    'Inter', -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  /* NOTE: Geist Mono alternative — IBM Plex Mono used for Google Fonts compatibility. */
  --font-mono:    'IBM Plex Mono', 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --font-accent:  var(--font-mono);

  /* ── Motion tokens — §3.8 ── */
  --ease-film:     cubic-bezier(0.16, 1, 0.3, 1);
  --ease-cut:      cubic-bezier(0.4, 0, 1, 1);
  --dur-glacier:   2200ms;
  --dur-smooth:    700ms;
  --dur-snap:      200ms;

  /* ── V1-compat aliases ── */
  --color-primary-light:   60 220 210;
  --color-primary-dark:    18 158 150;
  --color-secondary:      200 162  88;
  --color-secondary-light:220 185 120;
  --color-secondary-dark:  158 125  60;
  --color-accent-light:   220 185 120;
  --color-accent-dark:    158 125  60;
  --color-surface-dark:     6   7   8;
  --color-text-light:     122 126 124;
  --color-text-inverse:    10  11  12;

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

  --radius-sm:   0;
  --radius-md:   2px;
  --radius-lg:   2px;
  --radius-xl:   4px;
  --radius-full: 9999px;  /* pill for CTAs */

  --shadow-sm: 0 1px 6px rgb(0 0 0 / 0.4);
  --shadow-md: 0 4px 24px rgb(0 0 0 / 0.5);
  --shadow-lg: 0 12px 48px rgb(0 0 0 / 0.6);
  --shadow-xl: 0 24px 72px rgb(0 0 0 / 0.7);

  --space-section: 0;        /* scenes: full-bleed. text sections: 6rem applied in template */
  --space-block:   2.5rem;
  --space-element: 1rem;
}


/* --- 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 {
  background-color: rgb(var(--color-surface-dark) / 0.93) !important;
  box-shadow: 0 20px 48px rgb(var(--color-primary-dark) / 0.28);
}

[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: 999px;
    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 */

  --tpl-shadow-sm: 0 1px 4px  rgb(var(--color-primary) / 0.04);
  --tpl-shadow-md: 0 8px 30px rgb(var(--color-primary) / 0.07);
  --tpl-shadow-lg: 0 16px 48px rgb(var(--color-primary) / 0.09);
}

/* ============ 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:       12px;
  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:        none;
  border-radius: 0;
  box-shadow:    var(--tpl-shadow-md);
  overflow:      hidden;
  background:    rgb(var(--color-surface));
  transition:    box-shadow var(--dur-smooth) var(--ease-slow),
                 transform  var(--dur-smooth) var(--ease-slow);
}

[data-template="grand-resort"] .card:hover {
  transform:  translateY(-3px);
  box-shadow: var(--tpl-shadow-lg);
}

[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"] {
  --tpl-shadow-sm: 0 16px 32px rgb(18 28 20 / 0.08);
  --tpl-shadow-md: 0 28px 60px rgb(18 28 20 / 0.11);
  --tpl-shadow-lg: 0 40px 90px rgb(18 28 20 / 0.14);
}

[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(18 38 27) !important;
}

[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);
}

[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);
}

[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;
  background:
    linear-gradient(180deg, rgb(9 19 13 / 0.16) 0%, rgb(9 19 13 / 0.02) 22%, rgb(9 19 13 / 0.18) 52%, rgb(9 19 13 / 0.62) 100%),
    linear-gradient(90deg, rgb(9 19 13 / 0.44) 0%, rgb(9 19 13 / 0.18) 28%, rgb(9 19 13 / 0.02) 58%, rgb(9 19 13 / 0.12) 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,
[data-template="grand-resort"] .resort-hero-kicker {
  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);
}

[data-template="grand-resort"] .resort-hero-kicker {
  margin-top: 1rem;
  margin-bottom: 1.15rem;
}

[data-template="grand-resort"] .resort-hero-title {
  max-width: 10ch;
  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;
}

[data-template="grand-resort"] .resort-hero-actions .btn-primary {
  min-width: 14rem;
  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);
}

[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: 10ch;
  }
}

@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: 10ch;
    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 {
  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;
}

[data-template="grand-resort"] .hero-slideshow-controls {
  position: absolute;
  left: 0;
  right: 0;
  /* Booking widget overlaps hero bottom by 3.75rem (margin-top: -3.75rem).
     Place controls above that overlap so they don't sit on top of inputs. */
  bottom: 5.25rem;
  z-index: 5; /* Above .resort-hero-inner (z:2) — JS appends to .resort-hero, escape stacking */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  padding: 0 1.5rem;
  pointer-events: none;
}

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

[data-template="grand-resort"] .hero-slideshow-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgb(255 255 255 / 0.32);
  border-radius: 999px;
  background: rgb(255 255 255 / 0.08);
  color: rgb(255 255 255 / 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  transition: background 220ms var(--ease-slow), border-color 220ms var(--ease-slow), transform 220ms var(--ease-slow);
}

[data-template="grand-resort"] .hero-slideshow-arrow:hover {
  background: rgb(255 255 255 / 0.18);
  border-color: rgb(255 255 255 / 0.5);
  transform: scale(1.05);
}

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

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

[data-template="grand-resort"] .hero-slideshow-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgb(255 255 255 / 0.42);
  background: transparent;
  padding: 0;
  cursor: pointer;
  transition: background 220ms var(--ease-slow), border-color 220ms var(--ease-slow), width 320ms var(--ease-slow), opacity 220ms var(--ease-slow);
  opacity: 0.72;
}

[data-template="grand-resort"] .hero-slideshow-dot:hover {
  background: rgb(255 255 255 / 0.4);
  opacity: 1;
}

[data-template="grand-resort"] .hero-slideshow-dot.is-active {
  background: rgb(255 255 255 / 0.92);
  border-color: rgb(255 255 255 / 0.92);
  width: 22px;
  opacity: 1;
}

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

@media (max-width: 767px) {
  [data-template="grand-resort"] .hero-slideshow-controls {
    /* Mobilde booking widget margin-top -1.5rem ile daha az binişir */
    bottom: 3rem;
    gap: 0.85rem;
  }
  [data-template="grand-resort"] .hero-slideshow-arrow {
    width: 34px;
    height: 34px;
  }
}

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

/* Footer shell — sade derin orman tonu (gradient yok, sade tek ton) */
[data-template="grand-resort"] .resort-footer-shell {
  background: rgb(20 32 24) !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(26 40 30);
  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ı — derin tonun aynısı, sadece sol border ile ayrılır */
[data-template="grand-resort"] .resort-footer-band-concierge {
  display: flex;
  align-items: center;
  background: rgb(20 32 24);
  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 — heading font, refined size, cream tone */
[data-template="grand-resort"] .resort-footer-shell .cw-footer-nav-link {
  font-family: var(--font-heading) !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;
}

/* 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: 1.25rem 0;
}

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

[data-template="grand-resort"] .resort-footer-shell .cw-footer-legal-link {
  font-family: var(--font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 500;
  letter-spacing: 0.16em;
  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 — biraz daha rahat */
[data-template="grand-resort"] .resort-footer-shell > div:nth-child(2) {
  padding-top: clamp(3.5rem, 2.5rem + 3vw, 5.5rem);
  padding-bottom: clamp(3rem, 2.25rem + 2vw, 4.5rem);
}

/* ============ 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;
}

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

[data-template="grand-resort"] .resort-booking {
  position: relative;
  background: rgb(245 240 228);
  padding: 0;
  margin-top: -3.75rem;
  z-index: 4;
}

[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 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: 999px;
  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;
}

[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;
  }
}


/* --- tailwind/templates/corporate/holding.css --- */
/* =============================================================================
   HOLDING TEMPLATE — Corporate editorial authority
   Reference: Bloomberg Businessweek + Apollo Global + Linear + Stripe Press
   Spec: /design-spec-v2.md §2.6–2.13
   All colors via rgb(var(--token)) — theme override compatible.
   ============================================================================= */

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

/* Parent context for absolute-positioned children (cover number, folio page, scene-pin) */
[data-template="holding"] section {
  position: relative;
}

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

[data-template="holding"] body {
  color: rgb(var(--color-text));
  background:
    radial-gradient(1200px 520px at 0% 0%, rgb(var(--color-primary) / 0.04), transparent 58%),
    radial-gradient(900px 420px at 100% 0%, rgb(var(--color-accent) / 0.06), transparent 54%),
    linear-gradient(180deg, rgb(14 18 26), rgb(18 22 30) 18%, rgb(20 24 33) 100%);
}

/* Container: 88rem max, desktop 4rem margin */
[data-template="holding"] .container-page {
  max-width:      88rem;
  margin-inline:  auto;
  padding-inline: 3rem;
}

/* Section rhythm — §2.7 */
[data-template="holding"] .section {
  padding-top:    6.5rem;
  padding-bottom: 6.5rem;
}

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

/* Full-bleed utility (only logoBar and stats band) */
[data-template="holding"] .full-bleed {
  margin-inline: calc(50% - 50vw);
}

/* Block gap */
[data-template="holding"] .block-gap > * + * {
  margin-top: 3rem;
}

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

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

/* ============ TYPOGRAPHY ============ */

[data-template="holding"] h1,
[data-template="holding"] .h1 {
  font-family:    var(--font-heading);
  font-size:      clamp(2.35rem, 1.65rem + 2.55vw, 4rem);
  line-height:    1;
  letter-spacing: -0.028em;
  font-weight:    400;
  color:          rgb(var(--color-heading));
}

[data-template="holding"] h2,
[data-template="holding"] .h2 {
  font-family:    var(--font-heading);
  font-size:      clamp(1.95rem, 1.35rem + 2vw, 3.1rem);
  line-height:    1.08;
  letter-spacing: -0.02em;
  font-weight:    400;
  color:          rgb(var(--color-heading));
}

[data-template="holding"] h3,
[data-template="holding"] .h3 {
  font-family:    var(--font-heading);
  font-size:      clamp(1.35rem, 1rem + 1vw, 1.85rem);
  line-height:    1.24;
  letter-spacing: -0.015em;
  font-weight:    400;
  color:          rgb(var(--color-heading));
}

[data-template="holding"] h4,
[data-template="holding"] .h4 {
  font-family:    var(--font-body);
  font-size:      clamp(1rem, 0.92rem + 0.45vw, 1.2rem);
  line-height:    1.42;
  letter-spacing: -0.005em;
  font-weight:    600;
  color:          rgb(var(--color-heading));
}

[data-template="holding"] p,
[data-template="holding"] .body-text {
  font-family:    var(--font-body);
  font-size:      clamp(0.96rem, 0.92rem + 0.14vw, 1rem);
  line-height:    1.82;
  letter-spacing: 0.004em;
  font-weight:    400;
  color:          rgb(var(--color-text));
}

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

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

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

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

[data-template="holding"] #site-navbar {
  height:           76px;
  background:
    linear-gradient(180deg, rgb(18 22 30 / 0.94), rgb(18 22 30 / 0.82));
  border-bottom:    1px solid rgb(var(--color-border-strong) / 0.72);
  box-shadow:       0 14px 34px rgb(0 0 0 / 0.18);
  position:         sticky;
  top:              0;
  z-index:          100;
  backdrop-filter:  blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

[data-template="holding"] #site-navbar .nav-inner {
  height:         76px;
  max-width:      88rem;
  margin-inline:  auto;
  padding-inline: 3rem;
  display:        flex;
  align-items:    center;
  justify-content: space-between;
  gap:            2rem;
}

[data-template="holding"] .nav-link {
  font-family:    var(--font-body);
  font-size:      0.8125rem;
  font-weight:    500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
  transition:     color var(--dur-snap) var(--ease-precise),
                  opacity var(--dur-snap) var(--ease-precise);
  text-decoration: none;
  padding-block:   0.75rem;  /* ~44px vertical hit area — a11y §2.4.5 */
}

[data-template="holding"] .nav-link:hover,
[data-template="holding"] .nav-link.active {
  color:   rgb(var(--color-text));
  opacity: 1;
}

[data-template="holding"] .nav-brand-text {
  font-family:    var(--font-heading);
  font-size:      clamp(1.5rem, 1.15rem + 0.6vw, 1.95rem);
  line-height:    1;
  color:          rgb(var(--color-heading));
}

[data-template="holding"] .nav-cta {
  white-space: nowrap;
}

[data-template="holding"] .nav-menu-toggle {
  color: rgb(var(--color-text));
}

[data-template="holding"] .nav-link:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
  border-radius:  1px;
}

/* ============ HERO COMPOSITION — §2.6 ============ */

/* 12-col grid: text 7 cols left, image 5 cols right */
[data-template="holding"] .hero-holding {
  min-height:      min(76vh, 720px);
  display:         block;
  padding-top:     2.75rem;
  padding-bottom:  3.25rem;
  max-width:       72rem;
  margin-inline:   auto;
  padding-inline:  3rem;
}

[data-template="holding"] .hero-holding .hero-text {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
  max-width:      42rem;
}

[data-template="holding"] .holding-hero-shell {
  position: relative;
  isolation: isolate;
  padding-top: 0;
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0.04), transparent 20%),
    linear-gradient(135deg, rgb(var(--color-surface)) 0%, rgb(var(--color-surface-alt)) 100%);
}

[data-template="holding"] .holding-hero-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(720px 360px at 84% 18%, rgb(var(--color-primary) / 0.08), transparent 62%);
}

/* ============ SIGNATURE ELEMENTS — §2.10 ============ */

/* 1. Masthead Dateline Bar */
[data-template="holding"] .masthead-dateline {
  display: none;
}

/* 2. Cover Number Headline Prefix — aria-hidden ghost numeral */
[data-template="holding"] .cover-number {
  position:     absolute;
  font-family:  var(--font-heading);
  font-size:    clamp(4rem, 4vw, 5.5rem);
  font-weight:  400;
  line-height:  1;
  color:        rgb(var(--color-heading));
  opacity:      0.04;
  z-index:      -1;
  pointer-events: none;
  user-select:  none;
  left:         -1rem;
  top:          -1rem;
}

/* 3. Column Rule — broadsheet multi-column text */
[data-template="holding"] .column-rule-text {
  column-count:  2;
  column-gap:    3rem;
  column-rule:   1px solid rgb(var(--color-border));
}

/* 4. Monospace Data Callout */
[data-template="holding"] .stat-callout,
[data-template="holding"] .data-number {
  font-family:         var(--font-mono);
  font-size:           inherit;
  font-variant-numeric: tabular-nums;
  border-bottom:       2px solid rgb(var(--color-primary));
  padding-bottom:      1px;
  color:               rgb(var(--color-heading));
}

/* 5. Dropped Folio Page Number */
[data-template="holding"] .folio-number {
  position:    absolute;
  bottom:      2rem;
  right:       2rem;
  font-family: var(--font-mono);
  font-size:   0.6875rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  color:       rgb(var(--color-text));
  opacity:     0.4;
  pointer-events: none;
  user-select: none;
}

/* ============ CHAPTER MARKERS — §2.10 ============ */

/* Chapter eyebrow + rule: left offset on desktop */
[data-template="holding"] .chapter-marker {
  position:      relative;
  margin-bottom: 1rem;
}

[data-template="holding"] .chapter-number {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
  display:        inline-block;
  margin-bottom:  0.5rem;
}

[data-template="holding"] .chapter-rule {
  display:    block;
  width:      40px;
  height:     2px;
  background: rgb(var(--color-primary));
  transform-origin: left center;
  /* scaleX 0→1 animation via .is-visible */
  transform:  scaleX(0);
  transition: transform var(--dur-smooth) var(--ease-editorial);
}

[data-template="holding"] .chapter-marker.is-visible .chapter-rule {
  transform: scaleX(1);
}

/* Chapter number fades in on entry */
[data-template="holding"] .chapter-number {
  opacity:    0;
  transform:  translateY(0.5rem);
  transition: opacity var(--dur-smooth) var(--ease-editorial),
              transform var(--dur-smooth) var(--ease-editorial);
}

[data-template="holding"] .chapter-marker.is-visible .chapter-number {
  opacity:   1;
  transform: translateY(0);
}

/* ============ STATS BAND (full-bleed) ============ */

[data-template="holding"] .stats-band {
  padding-top:    5rem;
  padding-bottom: 5rem;
  background:     rgb(var(--color-surface-alt));
  border-top:     1px solid rgb(var(--color-border));
  border-bottom:  1px solid rgb(var(--color-border));
}

[data-template="holding"] .stats-band-inner {
  max-width:      88rem;
  margin-inline:  auto;
  padding-inline: 4rem;
  display:        flex;
  gap:            0;
  border-left:    1px solid rgb(var(--color-border));
}

[data-template="holding"] .stats-band-item {
  flex:           1;
  padding:        1.5rem 2.5rem;
  border-right:   1px solid rgb(var(--color-border));
}

/* ============ CTA PATTERNS — §2.11 ============ */

/* Primary: solid ink-black, zero radius, mono uppercase ASCII arrow */
[data-template="holding"] .btn-primary {
  display:         inline-flex;
  align-items:     center;
  gap:             0.625rem;
  background:      rgb(var(--color-text));
  color:           rgb(var(--color-bg));
  font-family:     var(--font-mono);
  font-size:       0.75rem;
  font-weight:     500;
  letter-spacing:  0.12em;
  text-transform:  uppercase;
  padding:         0.875rem 1.5rem;
  border-radius:   0;
  border:          none;
  text-decoration: none;
  cursor:          pointer;
  transition:      background var(--dur-snap) var(--ease-precise),
                   box-shadow  var(--dur-snap) var(--ease-precise);
  position:        relative;
  overflow:        hidden;
}

[data-template="holding"] .btn-primary .btn-arrow {
  transition: transform var(--dur-snap) var(--ease-precise);
  display:    inline-block;
}

/* §2.11: CSS-guaranteed ASCII arrow — no markup dependency */
[data-template="holding"] .btn-primary .btn-arrow::after,
[data-template="holding"] a.btn-primary::after {
  content:    " ->";
  display:    inline-block;
  transition: transform var(--dur-snap) var(--ease-precise);
}

[data-template="holding"] .btn-primary:hover {
  background: rgb(var(--color-primary));
  box-shadow: 0 2px 12px rgb(var(--color-primary) / 0.35);
}

[data-template="holding"] .btn-primary:hover .btn-arrow {
  transform: translateX(4px);
}

[data-template="holding"] .btn-primary:hover .btn-arrow::after,
[data-template="holding"] a.btn-primary:hover::after {
  transform: translateX(4px);
}

[data-template="holding"] .btn-primary:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
}

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

/* Secondary: outline only, inverts on hover */
[data-template="holding"] .btn-secondary {
  display:         inline-flex;
  align-items:     center;
  gap:             0.625rem;
  background:      transparent;
  color:           rgb(var(--color-text));
  font-family:     var(--font-mono);
  font-size:       0.75rem;
  font-weight:     500;
  letter-spacing:  0.12em;
  text-transform:  uppercase;
  padding:         0.82rem 1.35rem;
  border-radius:   0;
  border:          1px solid rgb(var(--color-text));
  text-decoration: none;
  cursor:          pointer;
  transition:      background var(--dur-snap) var(--ease-precise),
                   color      var(--dur-snap) var(--ease-precise),
                   border-color var(--dur-snap) var(--ease-precise);
}

[data-template="holding"] .btn-secondary:hover {
  background: rgb(var(--color-text));
  color:      rgb(var(--color-bg));
}

[data-template="holding"] .btn-secondary:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
}

/* Tertiary: inline mono text link, arrow advances */
[data-template="holding"] .btn-tertiary,
[data-template="holding"] a.link-inline {
  display:         inline-flex;
  align-items:     center;
  gap:             0.4rem;
  font-family:     var(--font-mono);
  font-size:       0.8125rem;
  font-weight:     400;
  letter-spacing:  0.04em;
  color:           rgb(var(--color-text));
  text-decoration: none;
  border-bottom:   1px solid rgb(var(--color-text));
  padding-bottom:  1px;
  transition:      color          var(--dur-snap) var(--ease-precise),
                   border-color   var(--dur-snap) var(--ease-precise),
                   opacity        var(--dur-snap) var(--ease-precise);
}

[data-template="holding"] .btn-tertiary:hover,
[data-template="holding"] a.link-inline:hover {
  border-color: transparent;
}

[data-template="holding"] .btn-tertiary .btn-arrow,
[data-template="holding"] a.link-inline .btn-arrow {
  transition: transform var(--dur-snap) var(--ease-precise);
  display:    inline-block;
}

[data-template="holding"] .btn-tertiary:hover .btn-arrow,
[data-template="holding"] a.link-inline:hover .btn-arrow {
  transform: translateX(3px);
}

[data-template="holding"] .btn-tertiary:focus-visible,
[data-template="holding"] a.link-inline:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
}

/* ============ LINKS ============ */

[data-template="holding"] a {
  color:          inherit;
  text-decoration: none;
  transition:     color   var(--dur-snap) var(--ease-precise),
                  opacity var(--dur-snap) var(--ease-precise);
}

[data-template="holding"] .prose a {
  color:           rgb(var(--color-primary));
  text-decoration: none;
  border-bottom:   1px solid rgb(var(--color-primary) / 0.4);
}

[data-template="holding"] .prose a:hover {
  opacity:      0.75;
  border-color: rgb(var(--color-primary));
}

[data-template="holding"] a:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
  border-radius:  1px;
}

/* ============ IMAGE TREATMENT — §2.12 ============ */

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

[data-template="holding"] .image-wrap img {
  display:      block;
  width:        100%;
  height:       100%;
  object-fit:   cover;
  border-radius: 0;
}

/* Aspect ratios — §2.12: 3:2 dominant, 1:1 portraits, 5:4 full-page */
[data-template="holding"] .aspect-editorial    { aspect-ratio: 3/2; }
[data-template="holding"] .aspect-portrait      { aspect-ratio: 1/1; }
[data-template="holding"] .aspect-feature       { aspect-ratio: 5/4; }

/* Image caption — mono flush-left, figure number prefix */
[data-template="holding"] .image-caption {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    400;
  letter-spacing: 0.04em;
  color:          rgb(var(--color-text-muted));
  margin-top:     0.5rem;
  text-transform: uppercase;
}

/* Embossed logo marks — §2.10 context */
[data-template="holding"] .logo-mark img,
[data-template="holding"] .partner-logo img {
  filter:    grayscale(1) brightness(0.75);
  opacity:   0.7;
  transition: opacity var(--dur-snap) var(--ease-precise),
              filter  var(--dur-snap) var(--ease-precise);
}

[data-template="holding"] .logo-mark:hover img,
[data-template="holding"] .partner-logo:hover img {
  opacity: 1;
  filter:  grayscale(0.4) brightness(0.9);
}

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

[data-template="holding"] .card {
  background:    rgb(var(--color-surface));
  border:        1px solid rgb(var(--color-border));
  border-radius: 0;
  overflow:      hidden;
}

[data-template="holding"] .card:hover {
  border-color: rgb(var(--color-border-strong));
}

/* ============ SECTION DIVIDER ============ */

/* Brass-ish horizontal rule */
[data-template="holding"] hr,
[data-template="holding"] .divider {
  border:           none;
  border-top:       1px solid rgb(var(--color-border));
  margin-block:     3rem;
}

/* Indented short divider */
[data-template="holding"] .divider-short {
  border:      none;
  border-top:  1px solid rgb(var(--color-primary) / 0.5);
  width:       40px;
  margin-top:  2rem;
  margin-bottom: 2rem;
}

/* ============ FOOTER — magazine layout ============ */

[data-template="holding"] footer {
  background:
    linear-gradient(180deg, rgb(var(--color-surface)) 0%, rgb(var(--color-bg)) 100%);
  border-top:  1px solid rgb(var(--color-border));
  padding-top: 5rem;
}

[data-template="holding"] footer .footer-grid {
  max-width:      88rem;
  margin-inline:  auto;
  padding-inline: 3rem;
  display:        grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.2fr);
  gap:            3rem;
}

[data-template="holding"] footer h3,
[data-template="holding"] footer h4 {
  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:  1.25rem;
}

[data-template="holding"] footer a {
  font-family:    var(--font-body);
  font-size:      0.875rem;
  font-weight:    400;
  color:          rgb(var(--color-text-muted));
  transition:     color var(--dur-snap) var(--ease-precise);
  text-decoration: none;
}

[data-template="holding"] footer a:hover {
  color: rgb(var(--color-text));
}

[data-template="holding"] footer a:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
}

[data-template="holding"] footer .footer-bottom {
  max-width:        88rem;
  margin-inline:    auto;
  padding-inline:   3rem;
  padding-block:    1.5rem;
  border-top:       1px solid rgb(var(--color-border));
  margin-top:       4rem;
  display:          flex;
  justify-content:  space-between;
  align-items:      center;
  font-family:      var(--font-mono);
  font-size:        0.6875rem;
  font-weight:      400;
  letter-spacing:   0.06em;
  color:            rgb(var(--color-text-muted));
}

[data-template="holding"] .holding-menu-overlay {
  background:
    linear-gradient(180deg, rgb(10 12 18 / 0.96), rgb(16 20 28 / 0.98)),
    radial-gradient(720px 300px at 84% 12%, rgb(var(--color-primary) / 0.14), transparent 62%);
}

[data-template="holding"] .holding-menu-grid {
  align-items: end;
}

[data-template="holding"] .hero-holding .prose {
  max-width: 32rem;
}

[data-template="holding"] .hero-holding .eyebrow {
  margin-top: 0.15rem;
}

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

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

[data-template="holding"] .editorial-page-copy {
  max-width: 52rem;
}

[data-template="holding"] .editorial-page-copy .eyebrow {
  color: rgb(255 255 255 / 0.64);
  margin-bottom: 0.9rem;
}

[data-template="holding"] .editorial-page-title {
  color: rgb(255 255 255 / 0.96);
  text-shadow: 0 3px 32px rgb(0 0 0 / 0.24);
}

[data-template="holding"] .editorial-intro {
  max-width: 40rem;
}

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

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

[data-template="holding"] .listing-card-body,
[data-template="holding"] .team-card-body {
  padding: 1.15rem 0 1.4rem;
  border-bottom: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .listing-card-title,
[data-template="holding"] .team-card-title {
  margin-bottom: 0.45rem;
}

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

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

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

[data-template="holding"] .listing-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.55rem;
  border: 1px solid rgb(var(--color-border));
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(var(--color-text-muted));
}

[data-template="holding"] .team-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 2rem;
}

[data-template="holding"] .team-card-media {
  border: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .holding-menu-overlay .menu-close-btn {
  color: rgb(var(--color-text));
  border-color: rgb(var(--color-border));
  background: rgb(255 255 255 / 0.02);
}

[data-template="holding"] .holding-menu-overlay .menu-nav-link {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 2.6vw, 3.4rem);
  line-height: 0.98;
  letter-spacing: -0.02em;
  color: rgb(var(--color-heading));
}

[data-template="holding"] .holding-menu-overlay .menu-secondary {
  border-left: 1px solid rgb(var(--color-border));
  padding-left: 2rem;
}

[data-template="holding"] .holding-footer-shell .footer-socials a {
  border-color: rgb(var(--color-border));
  color: rgb(var(--color-text-muted));
  background: rgb(255 255 255 / 0.02);
}

[data-template="holding"] .holding-footer-shell .footer-socials a:hover {
  color: rgb(var(--color-heading));
  border-color: rgb(var(--color-border-strong));
  background: rgb(255 255 255 / 0.06);
}

[data-template="holding"] .holding-flow {
  position: relative;
  padding-bottom: 5rem;
}

[data-template="holding"] .holding-flow .umb-block-grid__layout-item[data-content-element-type-alias="textBlock"]:nth-child(-n+3) {
  display: none;
}

[data-template="holding"] .holding-signature-band {
  max-width: 88rem;
  margin: 0 auto;
  padding: 1.25rem 3rem 4.25rem;
}

[data-template="holding"] .holding-signature-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: end;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .holding-signature-kicker {
  display: inline-block;
  margin-bottom: 1rem;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgb(var(--color-primary));
}

[data-template="holding"] .holding-signature-intro .h2 {
  max-width: 24rem;
}

[data-template="holding"] .holding-signature-copy .body-text {
  max-width: 34rem;
  color: rgb(var(--color-text) / 0.9);
}

[data-template="holding"] .holding-signature-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  padding-top: 1.75rem;
}

[data-template="holding"] .holding-signature-card {
  padding-top: 1rem;
  border-top: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .holding-signature-index {
  display: inline-block;
  margin-bottom: 0.85rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  color: rgb(var(--color-heading));
}

[data-template="holding"] .holding-signature-card h3 {
  margin-bottom: 0.7rem;
}

[data-template="holding"] .holding-flow .umb-block-grid__layout-item[data-content-element-type-alias="textBlock"]:nth-child(-n+3) {
  display: none;
}

[data-template="holding"] .holding-signature-band {
  max-width: 88rem;
  margin: 0 auto;
  padding: 1.25rem 3rem 4.25rem;
}

[data-template="holding"] .holding-signature-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: end;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .holding-signature-kicker {
  display: inline-block;
  margin-bottom: 1rem;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgb(var(--color-primary));
}

[data-template="holding"] .holding-signature-intro .h2 {
  max-width: 24rem;
}

[data-template="holding"] .holding-signature-copy .body-text {
  max-width: 34rem;
  color: rgb(var(--color-text) / 0.9);
}

[data-template="holding"] .holding-signature-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  padding-top: 1.75rem;
}

[data-template="holding"] .holding-signature-card {
  padding-top: 1rem;
  border-top: 1px solid rgb(var(--color-border));
}

[data-template="holding"] .holding-signature-index {
  display: inline-block;
  margin-bottom: 0.85rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  color: rgb(var(--color-heading));
}

[data-template="holding"] .holding-signature-card h3 {
  margin-bottom: 0.7rem;
}

[data-template="holding"] .section::before,
[data-template="holding"] .section-lg::before,
[data-template="holding"] .holding-flow::before {
  display: none;
}

[data-template="holding"] #site-navbar {
  background: rgb(var(--color-surface-dark) / 0.92);
  box-shadow: none;
}

[data-template="holding"] #site-navbar.navbar-scrolled {
  background: rgb(var(--color-surface-dark) / 0.96) !important;
  box-shadow: 0 14px 36px rgb(0 0 0 / 0.18);
}

[data-template="holding"] .holding-flow .umb-block-grid__layout-container {
  gap: 2rem;
}

[data-template="holding"] .holding-flow .umb-block-grid__layout-item > * {
  height: 100%;
}

[data-template="holding"] .holding-flow-empty .container-narrow {
  max-width: 44rem;
}

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

[data-template="holding"] .form-input {
  background:   rgb(var(--color-surface));
  border:       1px solid rgb(var(--color-border));
  border-radius: 0;
  color:        rgb(var(--color-text));
  font-family:  var(--font-body);
  padding:      0.75rem 1rem;
  transition:   border-color var(--dur-snap) var(--ease-precise);
  width:        100%;
}

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

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

/* ============ MOTION — §2.8 ============ */

/* Hero text: whole-block fade + translateY */
[data-template="holding"] .reveal-text {
  opacity:    0;
  transform:  translateY(1rem);
  transition: opacity   var(--dur-smooth) var(--ease-editorial),
              transform var(--dur-smooth) var(--ease-editorial);
}

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

/* Image reveal: opacity + translateY */
[data-template="holding"] .reveal-image {
  opacity:    0;
  transform:  translateY(1rem);
  transition: opacity   var(--dur-smooth) var(--ease-editorial),
              transform var(--dur-smooth) var(--ease-editorial);
}

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

/* General reveal (stagger via --delay CSS var) */
[data-template="holding"] .reveal-on-scroll {
  opacity:    0;
  transform:  translateY(0.75rem);
  transition: opacity   var(--dur-smooth) var(--ease-editorial),
              transform var(--dur-smooth) var(--ease-editorial);
  transition-delay: var(--delay, 0ms);
}

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

/* Minimal parallax — hero image translateY on scroll via JS custom prop */
[data-template="holding"] .hero-parallax {
  will-change: transform;
  transform:   translateY(var(--scroll-parallax, 0));
  transition:  transform 0ms linear;
}

/* ============ INTERACTIONS — §2.9 ============ */

/* Link hover: color shift + opacity drop */
[data-template="holding"] .nav-link:hover {
  opacity: 0.75;
}

/* Image hover — barely perceptible scale */
[data-template="holding"] .image-hover-scale img {
  transition: transform var(--dur-smooth) var(--ease-editorial);
}

[data-template="holding"] .image-hover-scale:hover img {
  transform: scale(1.015);
}

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

[data-template="holding"] *:focus-visible {
  outline:        2px solid rgb(var(--color-accent));
  outline-offset: 3px;
}

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

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

  [data-template="holding"] .chapter-number {
    opacity:   1;
    transform: none;
    transition: none;
  }

  [data-template="holding"] .chapter-rule {
    transform: scaleX(1);
    transition: none;
  }

  [data-template="holding"] .hero-parallax {
    transform: none !important;
    transition: none;
  }

  [data-template="holding"] .hero-holding .hero-image-wrap img:hover {
    transform: none;
  }

  [data-template="holding"] .image-hover-scale:hover img {
    transform: none;
  }

  [data-template="holding"] .btn-primary:hover .btn-arrow,
  [data-template="holding"] .btn-tertiary:hover .btn-arrow,
  [data-template="holding"] a.link-inline:hover .btn-arrow {
    transform: none;
  }

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

/* ============ RESPONSIVE — §2.13 ============ */

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

  [data-template="holding"] .hero-holding {
    padding-inline:        2rem;
    min-height:            auto;
  }

  [data-template="holding"] .holding-signature-band {
    padding-inline: 2rem;
  }

  [data-template="holding"] .holding-signature-grid,
  [data-template="holding"] .holding-signature-points {
    grid-template-columns: 1fr;
  }

  [data-template="holding"] .section {
    padding-top:    5rem;
    padding-bottom: 5rem;
  }

  [data-template="holding"] .stats-band-inner {
    flex-wrap: wrap;
  }

  [data-template="holding"] .stats-band-item {
    flex:       0 0 50%;
    max-width:  50%;
  }

  [data-template="holding"] .column-rule-text {
    column-count: 1;
  }

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

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

  [data-template="holding"] .team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

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

  [data-template="holding"] .hero-holding {
    padding-inline: 1rem;
  }

  [data-template="holding"] .holding-signature-band {
    padding: 0.5rem 1rem 3rem;
  }

  [data-template="holding"] .section {
    padding-top:    3.5rem;
    padding-bottom: 3.5rem;
  }

  [data-template="holding"] .stats-band-item {
    flex:      0 0 50%;
    max-width: 50%;
  }

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

  [data-template="holding"] .chapter-marker {
    left: 0;
  }

  [data-template="holding"] .cover-number {
    font-size: 4rem;
    opacity:   0.1;
  }

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

  [data-template="holding"] .editorial-page-hero__content {
    padding: 7.5rem 0 3rem;
  }

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

}

/* ≥1280px: chapter markers absolute left offset */
@media (min-width: 1280px) {
  [data-template="holding"] .chapter-marker {
    position: relative;
  }

  [data-template="holding"] .chapter-number-offset {
    position: absolute;
    left:     -3rem;
  }
}


/* --- tailwind/templates/landing/signature-story.css --- */
/* =============================================================================
   SIGNATURE STORY TEMPLATE — Cinematic single-scroll landing
   Reference: Dior Sauvage campaign + Aesop + Studio Bruch
   Spec: /design-spec-v2.md §3.6–3.13

   SCROLL ANIMATION APPROACH:
   - CSS animation-timeline: scroll() / view() used where supported
   - Fallback: JS IntersectionObserver toggles .is-visible / .in-view classes
   - All animations have @media (prefers-reduced-motion: reduce) overrides

   JS HOOKS (signature-story-scroll.js — future):
   - .scene-section: IntersectionObserver → toggles .in-view
   - .scene-pin: sticky scroll pin per scene
   - .word-reveal [data-word-index]: per-word stagger
   - .scene-counter [data-scene]: updates aria-current + active state
   - Custom property --scroll-parallax on elements with data-parallax
   ============================================================================= */

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

/* Parent context for absolute-positioned children (folio page number, scene-pin) */
[data-template="signature-story"] section {
  position: relative;
}

[data-template="signature-story"] {
  background-color: rgb(var(--color-bg));
  color:            rgb(var(--color-text));
  font-family:      var(--font-body);
  overflow-x:       hidden;
}

/* No navbar for signature-story — §3.6 */
[data-template="signature-story"] #site-navbar {
  display: none;
}

/* Scene sections — full-bleed by default */
[data-template="signature-story"] .scene-section {
  position: relative;
  width:    100%;
  overflow: hidden;
}

/* Text essay sections — contained, max 52rem */
[data-template="signature-story"] .text-essay {
  max-width:      52rem;
  margin-inline:  auto;
  padding-inline: 6rem;
  padding-block:  6rem;
}

/* Pull quote */
[data-template="signature-story"] .pull-quote {
  max-width:     36rem;
  margin:        4rem auto;
  padding-left:  2rem;
  border-left:   0 solid rgb(var(--color-primary));
  transition:    border-left-width var(--dur-smooth) var(--ease-film),
                 border-color      var(--dur-smooth) var(--ease-film);
}

[data-template="signature-story"] .pull-quote:hover {
  border-left-width: 3px;
}

[data-template="signature-story"] .pull-quote:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 5px;
}

/* Inter-scene spacer */
[data-template="signature-story"] .scene-gap {
  height: clamp(0rem, 2vw, 2rem);
}

/* ============ TYPOGRAPHY — §3.4 ============ */

[data-template="signature-story"] h1,
[data-template="signature-story"] .h1 {
  font-family:    var(--font-heading);
  font-size:      clamp(3.2rem, 1.9rem + 5.8vw, 6.75rem);
  line-height:    0.94;
  letter-spacing: -0.04em;
  font-weight:    800;
  color:          rgb(var(--color-heading));
  text-transform: none;
}

[data-template="signature-story"] h2,
[data-template="signature-story"] .h2 {
  font-family:    var(--font-heading);
  font-size:      clamp(2.35rem, 1.35rem + 3.8vw, 4.5rem);
  line-height:    0.98;
  letter-spacing: -0.03em;
  font-weight:    700;
  color:          rgb(var(--color-heading));
}

[data-template="signature-story"] h3,
[data-template="signature-story"] .h3 {
  font-family:    var(--font-heading);
  font-size:      clamp(1.5rem, 1rem + 2.5vw, 3rem);
  line-height:    1.1;
  letter-spacing: -0.01em;
  font-weight:    200;      /* extreme weight contrast — §3.3 */
  color:          rgb(var(--color-heading));
}

[data-template="signature-story"] h4,
[data-template="signature-story"] .h4 {
  font-family:    var(--font-body);
  font-size:      clamp(1rem, 0.9rem + 0.8vw, 1.375rem);
  line-height:    1.3;
  letter-spacing: 0.02em;
  font-weight:    500;
  color:          rgb(var(--color-heading));
}

[data-template="signature-story"] p,
[data-template="signature-story"] .body-text {
  font-family:    var(--font-body);
  font-size:      clamp(0.95rem, 0.89rem + 0.24vw, 1rem);
  line-height:    1.72;
  letter-spacing: 0.01em;
  font-weight:    350;
  color:          rgb(var(--color-text));
}

[data-template="signature-story"] .text-small {
  font-family:    var(--font-body);
  font-size:      clamp(0.8125rem, 0.78rem + 0.25vw, 0.9375rem);
  line-height:    1.7;
  letter-spacing: 0.015em;
  font-weight:    300;
  color:          rgb(var(--color-text-muted));
}

/* Eyebrow — ALL CAPS, extreme tracking, §3.3 */
[data-template="signature-story"] .eyebrow,
[data-template="signature-story"] .overline {
  font-family:    var(--font-mono);
  font-size:      clamp(0.625rem, 0.6rem + 0.15vw, 0.6875rem);
  line-height:    1.3;
  letter-spacing: 0.30em;
  font-weight:    500;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
}

/* Caption — timecode burn-in feel */
[data-template="signature-story"] .caption,
[data-template="signature-story"] .timecode {
  font-family:    var(--font-mono);
  font-size:      clamp(0.6875rem, 0.65rem + 0.2vw, 0.75rem);
  line-height:    1.5;
  letter-spacing: 0.08em;
  font-weight:    400;
  color:          rgb(var(--color-primary));
  text-transform: uppercase;
}

/* ============ HERO — §3.6 ============ */

/* Full 100vh sticky hero — scroll-locked */
[data-template="signature-story"] .hero-signature {
  position:    sticky;
  top:         0;
  width:       100%;
  height:      100vh;
  min-height:  100svh;
  overflow:    hidden;
  z-index:     1;
}

/* Full-viewport image */
[data-template="signature-story"] .hero-signature .hero-image {
  position:    absolute;
  inset:       0;
  width:       100%;
  height:      100%;
  object-fit:  cover;
  object-position: center;
  /* Color grade — §3.6 */
  filter:      saturate(0.9) contrast(1.05);
  /* Scroll-linked scale via CSS custom property or animation-timeline */
  transform:   scale(var(--hero-scale, 1.0));
  transition:  transform 0ms linear;
  /* animation-timeline: scroll() where supported */
  animation:   hero-scale-in var(--dur-glacier) var(--ease-film) forwards paused;
  animation-timeline: scroll(root);
  animation-range: 0vh 100vh;
}

@keyframes hero-scale-in {
  from { transform: scale(1.0); filter: saturate(0.9) contrast(1.05); }
  to   { transform: scale(1.06); filter: saturate(0.7) contrast(1.1); }
}

/* Bottom gradient overlay — §3.6 */
[data-template="signature-story"] .hero-signature::after {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(
    180deg,
    transparent 0%,
    transparent 40%,
    rgb(0 0 0 / 0.55) 100%
  );
  pointer-events: none;
  z-index:    2;
}

/* Duotone overlay — §3.10 #4 */
[data-template="signature-story"] .hero-signature .hero-duotone {
  position:        absolute;
  inset:           0;
  background:      rgb(var(--color-accent) / 0.07);
  mix-blend-mode:  multiply;
  pointer-events:  none;
  z-index:         2;
}

/* Headline — centered, pinned bottom */
[data-template="signature-story"] .hero-headline-wrap {
  position: absolute;
  bottom:   11vh;
  left:     0;
  right:    0;
  z-index:  3;
  text-align: center;
  padding-inline: 2rem;
  max-width: 52rem;
  margin-inline: auto;
}

[data-template="signature-story"] .hero-headline-wrap h1 {
  color:     rgb(var(--color-heading));
  text-shadow: 0 4px 48px rgb(0 0 0 / 0.5);
}

[data-template="signature-story"] .hero-brandline {
  margin-bottom: 1rem;
  font-family:   var(--font-heading);
  font-size:     clamp(1rem, 0.85rem + 0.6vw, 1.35rem);
  font-weight:   700;
  letter-spacing: -0.02em;
  color:         rgb(var(--color-heading) / 0.92);
}

[data-template="signature-story"] .hero-kicker {
  margin-bottom: 1.25rem;
}

[data-template="signature-story"] .hero-summary {
  max-width:   38rem;
  margin:      1.25rem auto 0;
  color:       rgb(var(--color-text) / 0.88);
}

[data-template="signature-story"] .hero-actions {
  display:         flex;
  justify-content: center;
  margin-top:      2rem;
}

[data-template="signature-story"] .hero-proof-strip {
  display:        flex;
  justify-content:center;
  flex-wrap:      wrap;
  gap:            0.85rem 1.25rem;
  margin-top:     1.25rem;
  font-family:    var(--font-mono);
  font-size:      0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted) / 0.76);
}

[data-template="signature-story"] .hero-proof-strip span {
  padding-top:    0.85rem;
  border-top:     1px solid rgb(var(--color-border-strong) / 0.85);
  min-width:      8.5rem;
}

/* Scroll indicator — fade-pulse */
[data-template="signature-story"] .scroll-prompt {
  position:    absolute;
  bottom:      4vh;
  left:        50%;
  transform:   translateX(-50%);
  z-index:     3;
  font-family: var(--font-mono);
  font-size:   0.6875rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color:       rgb(var(--color-text) / 0.7);
  animation:   scroll-pulse 3s ease-in-out infinite;
}

@keyframes scroll-pulse {
  0%, 100% { opacity: 0.4; }
  50%       { opacity: 1; }
}

/* Micro logo — bottom-right optional, §3.6 */
[data-template="signature-story"] .hero-micro-logo {
  position:    absolute;
  bottom:      2rem;
  right:       2rem;
  z-index:     3;
  width:       32px;
  height:      32px;
  opacity:     0.6;
}

/* ============ SIGNATURE ELEMENTS — §3.10 ============ */

/* 1. Scene Counter — fixed left vertical film leader */
[data-template="signature-story"] .scene-counter {
  position:    fixed;
  left:        2rem;
  top:         50%;
  transform:   translateY(-50%);
  z-index:     200;
  display:     flex;
  flex-direction: column;
  align-items: center;
  gap:         0.75rem;
  pointer-events: none;
}

[data-template="signature-story"] .scene-counter::before {
  content:    '';
  display:    block;
  width:      1px;
  height:     3rem;
  background: rgb(var(--color-primary) / 0.3);
  margin-bottom: 0.25rem;
}

[data-template="signature-story"] .scene-counter::after {
  content:    '';
  display:    block;
  width:      1px;
  height:     3rem;
  background: rgb(var(--color-primary) / 0.3);
  margin-top:  0.25rem;
}

[data-template="signature-story"] .scene-counter-label {
  font-family:  var(--font-mono);
  font-size:    0.625rem;
  font-weight:  400;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color:        rgb(var(--color-text-muted));
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transition:   color var(--dur-snap) var(--ease-film);
}

[data-template="signature-story"] .scene-counter-label[aria-current="true"] {
  color: rgb(var(--color-primary));
}

/* 2. Title-Card Reveal Heading — mono scene code + headline */
[data-template="signature-story"] .title-card {
  position: relative;
}

[data-template="signature-story"] .story-manifesto {
  display:        grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(15rem, 0.9fr);
  gap:            2rem;
  align-items:    end;
}

[data-template="signature-story"] .story-aside {
  padding-bottom: 0.5rem;
}

[data-template="signature-story"] .story-aside-label {
  display:        inline-block;
  margin-bottom:  0.9rem;
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color:          rgb(var(--color-primary));
}

[data-template="signature-story"] .story-body {
  margin-top: 2.5rem;
  max-width:  42rem;
}

[data-template="signature-story"] .story-proof-grid {
  display:        grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:            1.25rem;
  margin-top:     2.25rem;
}

[data-template="signature-story"] .story-proof-item {
  border-top:     1px solid rgb(var(--color-border-strong));
  padding-top:    1rem;
}

[data-template="signature-story"] .story-proof-item h3 {
  margin-top:     0.85rem;
  margin-bottom:  0.75rem;
  font-size:      clamp(1rem, 0.92rem + 0.4vw, 1.35rem);
  font-weight:    500;
  letter-spacing: -0.02em;
}

[data-template="signature-story"] .title-card .scene-code {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    400;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color:          rgb(var(--color-text-muted));
  opacity:        0;
  transform:      translateY(4px);
  transition:     opacity   var(--dur-smooth) var(--ease-film),
                  transform var(--dur-smooth) var(--ease-film);
  margin-bottom:  1rem;
}

[data-template="signature-story"] .title-card.in-view .scene-code {
  opacity:   1;
  transform: translateY(0);
}

[data-template="signature-story"] .title-card h2 {
  opacity:    0;
  transform:  translateY(6px);
  transition: opacity   var(--dur-smooth) var(--ease-film),
              transform var(--dur-smooth) var(--ease-film);
  transition-delay: 200ms;
}

[data-template="signature-story"] .title-card.in-view h2 {
  opacity:   1;
  transform: translateY(0);
}

/* 3. Grain Overlay — cinematic emulsion, §3.10 */
[data-template="signature-story"] .grain-overlay {
  position:       fixed;
  inset:          0;
  z-index:        9999;
  pointer-events: none;
  opacity:        0.06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='grain'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' seed='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23grain)'/%3E%3C/svg%3E");
  background-size: 256px 256px;
  animation:      grain-shift 0.08s steps(3) infinite;
}

@keyframes grain-shift {
  0%   { background-position:   0px   0px; }
  33%  { background-position: -64px  32px; }
  66%  { background-position:  32px -48px; }
  100% { background-position: -32px  64px; }
}

/* 4. Duotone hero — already applied via .hero-duotone above */

/* 5. Letterbox Bars — §3.10 */
[data-template="signature-story"] .letterbox {
  aspect-ratio:  21/9;
  position:      relative;
  overflow:      hidden;
  border-top:    64px solid rgb(var(--color-bg));
  border-bottom: 64px solid rgb(var(--color-bg));
  transition:    border-top-width    var(--dur-smooth) var(--ease-film),
                 border-bottom-width var(--dur-smooth) var(--ease-film);
}

[data-template="signature-story"] .letterbox.in-view {
  border-top-width:    48px;
  border-bottom-width: 48px;
}

[data-template="signature-story"] .letterbox img {
  width:  100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ============ SCENE — IMAGE PIN (sticky scroll) ============ */

[data-template="signature-story"] .scene-pin-wrap {
  position: relative;
}

[data-template="signature-story"] .scene-pin {
  position: sticky;
  top:      0;
  height:   100vh;
  overflow: hidden;
}

[data-template="signature-story"] .scene-pin img {
  width:       100%;
  height:      100%;
  object-fit:  cover;
  /* Scroll-linked scale via view() timeline */
  animation:   scene-image-scale 1s var(--ease-film) forwards paused;
  animation-timeline: view();
  animation-range:    entry 0% cover 100%;
}

@keyframes scene-image-scale {
  from { transform: scale(1.0); }
  to   { transform: scale(1.08); }
}

/* Scene entry — clip-path wipe up */
[data-template="signature-story"] .scene-enter {
  clip-path:  inset(100% 0 0 0);
  transition: clip-path var(--dur-glacier) var(--ease-film);
}

[data-template="signature-story"] .scene-enter.in-view {
  clip-path: inset(0% 0 0 0);
}

/* ============ WORD-BY-WORD REVEAL — §3.8 ============ */

/* Container: each word wrapped in span[data-word] by JS */
[data-template="signature-story"] .word-reveal {
  overflow: hidden;
}

[data-template="signature-story"] .word-reveal [data-word] {
  display:    inline-block;
  opacity:    0;
  transform:  translateY(0.5rem);
  transition: opacity   600ms var(--ease-film),
              transform 600ms var(--ease-film);
  transition-delay: calc(var(--word-index, 0) * 60ms);
}

[data-template="signature-story"] .word-reveal.in-view [data-word] {
  opacity:   1;
  transform: translateY(0);
}

/* Fallback: block fade if JS word-wrap not applied */
[data-template="signature-story"] .reveal-block {
  opacity:    0;
  transform:  translateY(0.5rem);
  transition: opacity   var(--dur-smooth) var(--ease-film),
              transform var(--dur-smooth) var(--ease-film);
  transition-delay: var(--delay, 0ms);
}

[data-template="signature-story"] .reveal-block.in-view {
  opacity:   1;
  transform: translateY(0);
}

/* ============ CTA PATTERNS — §3.11 ============ */

/* Primary: pill, electric teal fill */
[data-template="signature-story"] .btn-primary {
  display:         inline-flex;
  align-items:     center;
  gap:             0.5rem;
  background:      rgb(var(--color-primary));
  color:           rgb(var(--color-primary-fg));
  font-family:     var(--font-body);
  font-size:       0.75rem;
  font-weight:     500;
  letter-spacing:  0.14em;
  text-transform:  uppercase;
  padding:         0.95rem 1.8rem;
  border-radius:   9999px;
  border:          none;
  text-decoration: none;
  cursor:          pointer;
  transition:      filter     var(--dur-snap) var(--ease-film),
                   box-shadow var(--dur-snap) var(--ease-film);
  position:        relative;
  overflow:        hidden;
}

[data-template="signature-story"] .btn-primary:hover {
  filter:     brightness(1.08);
  box-shadow: inset 0 0 24px rgb(var(--color-accent) / 0.4),
              0 4px 24px rgb(var(--color-primary) / 0.4);
}

[data-template="signature-story"] .btn-primary:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 5px;
}

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

/* Secondary: outline pill, center-out fill on hover */
[data-template="signature-story"] .btn-secondary {
  display:         inline-flex;
  align-items:     center;
  gap:             0.5rem;
  background:      transparent;
  color:           rgb(var(--color-primary));
  font-family:     var(--font-body);
  font-size:       0.75rem;
  font-weight:     500;
  letter-spacing:  0.14em;
  text-transform:  uppercase;
  padding:         0.95rem 1.8rem;
  border-radius:   9999px;
  border:          1px solid rgb(var(--color-primary));
  text-decoration: none;
  cursor:          pointer;
  position:        relative;
  overflow:        hidden;
  /* clip-path center-out fill */
  isolation:       isolate;
  transition:      color var(--dur-smooth) var(--ease-film);
}

[data-template="signature-story"] .btn-secondary::before {
  content:       '';
  position:      absolute;
  inset:         0;
  background:    rgb(var(--color-primary));
  border-radius: 9999px;
  clip-path:     circle(0% at 50% 50%);
  transition:    clip-path 350ms var(--ease-film);
  z-index:       -1;
}

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

[data-template="signature-story"] .btn-secondary:hover::before {
  clip-path: circle(100% at 50% 50%);
}

[data-template="signature-story"] .btn-secondary:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 5px;
}

/* ============ IMAGE TREATMENT — §3.12 ============ */

[data-template="signature-story"] .image-scene {
  display:   block;
  width:     100%;
  position:  relative;
  overflow:  hidden;
}

/* Inline images: 2px radius for film-still softening */
[data-template="signature-story"] .image-inline {
  border-radius: 2px;
  overflow:      hidden;
}

/* Cinematic 21:9 */
[data-template="signature-story"] .aspect-cinema  { aspect-ratio: 21/9; }
/* Climax 2.39:1 */
[data-template="signature-story"] .aspect-scope    { aspect-ratio: 239/100; }

/* Scene gallery hover */
[data-template="signature-story"] .image-gallery-item {
  overflow: hidden;
  position: relative;
  cursor:   zoom-in;
}

[data-template="signature-story"] .image-gallery-item img {
  transition: transform var(--dur-smooth) var(--ease-film);
  display:    block;
  width:      100%;
}

[data-template="signature-story"] .image-gallery-item:hover img {
  transform: scale(1.02);
}

[data-template="signature-story"] .image-gallery-item:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 3px;
}

/* Image caption — overlay bottom-left, timecode */
[data-template="signature-story"] .image-caption-overlay {
  position:    absolute;
  bottom:      1rem;
  left:        1.25rem;
  font-family: var(--font-mono);
  font-size:   0.6875rem;
  font-weight: 400;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color:       rgb(var(--color-primary));
}

/* Parallax depth layers: fg/mid/bg — JS sets --parallax-offset */
[data-template="signature-story"] [data-parallax="fg"] {
  transform:  translateY(calc(var(--parallax-offset, 0px) * 0.10));
  will-change: transform;
}

[data-template="signature-story"] [data-parallax="mid"] {
  transform:  translateY(calc(var(--parallax-offset, 0px) * 0.05));
  will-change: transform;
}

[data-template="signature-story"] [data-parallax="bg"] {
  transform:  translateY(calc(var(--parallax-offset, 0px) * 0.02));
  will-change: transform;
}

/* ============ CHAPTER ENTRY — letter-spacing expand ============ */

[data-template="signature-story"] .chapter-title {
  display:        inline-block;
  letter-spacing: 0.4em;
  opacity:        0;
  transition:     letter-spacing 800ms var(--ease-film),
                  opacity        800ms var(--ease-film);
}

[data-template="signature-story"] .chapter-title.in-view {
  letter-spacing: 0.05em;
  opacity:        1;
}

/* ============ FOOTER — minimal bar ============ */

[data-template="signature-story"] footer {
  background:     rgb(var(--color-surface));
  border-top:     1px solid rgb(var(--color-border));
  padding-block:  2rem;
  padding-inline: 2rem;
  display:        flex;
  justify-content: space-between;
  align-items:    center;
}

[data-template="signature-story"] footer .footer-legal {
  font-family:    var(--font-mono);
  font-size:      0.6875rem;
  font-weight:    400;
  letter-spacing: 0.08em;
  color:          rgb(var(--color-text-muted));
}

[data-template="signature-story"] footer a {
  color:           rgb(var(--color-text-muted));
  text-decoration: none;
  transition:      color var(--dur-snap) var(--ease-film);
}

[data-template="signature-story"] footer a:hover {
  color: rgb(var(--color-text));
}

[data-template="signature-story"] footer a:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 3px;
}

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

[data-template="signature-story"] *:focus-visible {
  outline:        2px solid rgb(var(--color-heading));
  outline-offset: 5px;
}

[data-template="signature-story"] *:focus-visible:not(button):not(a) {
  outline-color: rgb(var(--color-primary));
}

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

[data-template="signature-story"] .landing-page-hero {
  position:     relative;
  min-height:   min(82svh, 52rem);
  overflow:     hidden;
}

[data-template="signature-story"] .landing-page-hero__fallback {
  background:
    radial-gradient(circle at top left, rgb(var(--color-primary) / 0.18), transparent 38%),
    linear-gradient(145deg, rgb(var(--color-surface-alt)), rgb(var(--color-bg)) 72%);
}

[data-template="signature-story"] .landing-page-hero__content {
  position:     relative;
  z-index:      1;
  min-height:   min(82svh, 52rem);
  display:      flex;
  align-items:  flex-end;
  padding:      clamp(5rem, 10vw, 8rem) 1.5rem 3.5rem;
}

[data-template="signature-story"] .landing-page-hero__grid {
  width:                 min(100%, 74rem);
  margin-inline:         auto;
  display:               grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(14rem, 0.7fr);
  gap:                   2rem;
  align-items:           end;
}

[data-template="signature-story"] .landing-page-copy {
  max-width: 42rem;
}

[data-template="signature-story"] .landing-page-title {
  margin-top: 0.75rem;
}

[data-template="signature-story"] .landing-page-summary {
  max-width:   34rem;
  margin-top:  1rem;
  color:       rgb(var(--color-text) / 0.86);
}

[data-template="signature-story"] .landing-page-meta {
  border-top:     1px solid rgb(var(--color-border-strong));
  padding-top:    1rem;
}

@media (prefers-reduced-motion: reduce) {
  /* Freeze grain */
  [data-template="signature-story"] .grain-overlay {
    animation: none;
    background-position: 0 0;
  }

  /* Hero scroll-lock released — static */
  [data-template="signature-story"] .hero-signature {
    position: relative;
  }

  [data-template="signature-story"] .hero-signature .hero-image {
    animation:  none;
    transform:  scale(1) !important;
    filter:     saturate(0.9) contrast(1.05);
    transition: none;
  }

  /* Scene clip wipes → opacity fade */
  [data-template="signature-story"] .scene-enter {
    clip-path:  none;
    opacity:    0;
    transition: opacity 300ms ease;
  }

  [data-template="signature-story"] .scene-enter.in-view {
    clip-path: none;
    opacity:   1;
  }

  /* Parallax disabled */
  [data-template="signature-story"] [data-parallax] {
    transform:   none !important;
    will-change: auto;
  }

  /* Word stagger → block fade */
  [data-template="signature-story"] .word-reveal [data-word] {
    opacity:          0;
    transform:        none;
    transition:       opacity 300ms ease;
    transition-delay: 0ms;
  }

  [data-template="signature-story"] .word-reveal.in-view [data-word] {
    opacity: 1;
  }

  /* Block reveals — no translate */
  [data-template="signature-story"] .reveal-block,
  [data-template="signature-story"] .title-card .scene-code,
  [data-template="signature-story"] .title-card h2 {
    transform:  none;
    transition: opacity 300ms ease;
  }

  /* Chapter title spacing reset */
  [data-template="signature-story"] .chapter-title {
    letter-spacing: 0.05em;
    opacity:        0;
    transition:     opacity 300ms ease;
  }

  [data-template="signature-story"] .chapter-title.in-view {
    letter-spacing: 0.05em;
    opacity:        1;
  }

  /* Sticky pins → normal block */
  [data-template="signature-story"] .scene-pin {
    position: relative;
    height:   70vh;
  }

  [data-template="signature-story"] .scene-pin img {
    animation: none;
    transform: none;
  }

  /* Letterbox static */
  [data-template="signature-story"] .letterbox {
    transition:          none;
    border-top-width:    48px;
    border-bottom-width: 48px;
  }

  /* Btn clip animation off */
  [data-template="signature-story"] .btn-secondary::before {
    transition: none;
  }

  /* Scroll pulse off */
  [data-template="signature-story"] .scroll-prompt {
    animation: none;
    opacity:   0.7;
  }

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

  /* Global override */
  [data-template="signature-story"] * {
    animation-duration:       0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration:       300ms !important;
  }
}

/* ============ RESPONSIVE — §3.13 ============ */

/* ≥1280px: full experience */
@media (min-width: 1280px) {
  [data-template="signature-story"] .scene-counter {
    display: flex;
  }
}

/* 768–1279px: preserved scroll-lock, parallax reduced */
@media (max-width: 1279px) {
  [data-template="signature-story"] .scene-counter {
    display: none;
  }

  [data-template="signature-story"] .text-essay {
    padding-inline: 3rem;
    padding-block:  4rem;
  }

  [data-template="signature-story"] .story-manifesto,
  [data-template="signature-story"] .landing-page-hero__grid {
    grid-template-columns: 1fr;
  }

  [data-template="signature-story"] .story-proof-grid {
    grid-template-columns: 1fr;
  }

  [data-template="signature-story"] [data-parallax="fg"] {
    transform: translateY(calc(var(--parallax-offset, 0px) * 0.06));
  }

  [data-template="signature-story"] [data-parallax="mid"],
  [data-template="signature-story"] [data-parallax="bg"] {
    transform: none;
  }
}

/* <768px: scroll-lock disabled, static 100vh */
@media (max-width: 767px) {
  [data-template="signature-story"] .scene-counter {
    display: none;
  }

  /* Scroll-lock released on mobile */
  [data-template="signature-story"] .hero-signature {
    position:   relative;
    height:     100vh;
  }

  [data-template="signature-story"] .hero-signature .hero-image {
    animation:  none;
    transform:  scale(1) !important;
  }

  /* Scene pins → block flow */
  [data-template="signature-story"] .scene-pin {
    position: relative;
    height:   70vh;
  }

  [data-template="signature-story"] .scene-pin img {
    animation: none;
    height:    100%;
  }

  /* Parallax all off */
  [data-template="signature-story"] [data-parallax] {
    transform: none !important;
  }

  /* Text essay: tighter mobile */
  [data-template="signature-story"] .text-essay {
    padding-inline: 1.25rem;
    padding-block:  3rem;
  }

  [data-template="signature-story"] .hero-headline-wrap {
    padding-inline: 1.25rem;
    bottom:         8vh;
  }

  [data-template="signature-story"] .hero-summary {
    max-width: 30rem;
  }

  [data-template="signature-story"] .hero-proof-strip {
    gap: 0.75rem;
  }

  [data-template="signature-story"] .hero-proof-strip span {
    min-width: 0;
    flex:      1 1 100%;
  }

  [data-template="signature-story"] footer {
    flex-direction: column;
    gap:            1rem;
    text-align:     center;
  }

  /* Font scale -15% on mobile for headings */
  [data-template="signature-story"] h1,
  [data-template="signature-story"] .h1 {
    font-size: clamp(2.4rem, 8vw, 3.8rem);
  }

  [data-template="signature-story"] h2,
  [data-template="signature-story"] .h2 {
    font-size: clamp(1.9rem, 7vw, 2.8rem);
  }

  [data-template="signature-story"] .landing-page-hero,
  [data-template="signature-story"] .landing-page-hero__content {
    min-height: 70svh;
  }

  /* Image scenes 70vh */
  [data-template="signature-story"] .scene-image-70 {
    height: 70vh;
  }

  /* Letterbox reduced to simple image on mobile */
  [data-template="signature-story"] .letterbox {
    aspect-ratio:        auto;
    height:              70vh;
    border-top-width:    0;
    border-bottom-width: 0;
  }
}
