/*
Theme Name: MyTheme resort
Theme URI: https://resort.com.ua/
Author: Mr Digital
Author URI: https://resort.com.ua
Description: Concierge theme for resort
Version: 1.0.0
Text Domain: mytheme-resort
*/

/* ============================================================================
   DESIGN TOKENS — DESIGN-SYSTEM.md §2 (single source of truth)
   ============================================================================ */

:root {
    /* --- Color — role tokens (light) --- */
    --rv-color-paper: #F7F2E8;
    --rv-color-surface-raised: #FFFFFF;
    --rv-color-surface-sunken: #EFE8DA;
    --rv-color-ink: #1A1713;
    --rv-color-muted: #6B645A;
    --rv-color-rule: #D9D1BF;
    --rv-color-primary: #B54A2C;
    --rv-color-accent: #4F5D3C;
    --rv-color-primary-soft: #EACFBE;
    --rv-color-accent-soft: #D8DCC7;
    --rv-color-success: #3F6B4E;
    --rv-color-warning: #A8741C;
    --rv-color-danger: #9B3B2A;
    --rv-color-focus: #1A1713;

    /* --- Type families --- */
    --rv-font-serif: "Fraunces", "Cormorant Garamond", Georgia, serif;
    --rv-font-sans: "Public Sans", "Plus Jakarta Sans", -apple-system, "Segoe UI", Roboto, sans-serif;
    --rv-font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

    /* --- Type scale --- */
    --rv-text-xs: 0.75rem;
    --rv-text-sm: 0.875rem;
    --rv-text-base: 1rem;
    --rv-text-lg: 1.125rem;
    --rv-text-xl: 1.375rem;
    --rv-text-2xl: 1.75rem;
    --rv-text-3xl: clamp(2rem, 1.5rem + 1.6vw, 2.75rem);
    --rv-text-4xl: clamp(2.5rem, 1.8rem + 2.8vw, 3.75rem);
    --rv-text-5xl: clamp(3rem, 2rem + 4vw, 5rem);
    --rv-text-display: clamp(3.5rem, 2rem + 6.4vw, 7rem);

    /* --- Line heights & tracking --- */
    --rv-leading-tight: 1.05;
    --rv-leading-snug: 1.2;
    --rv-leading-normal: 1.5;
    --rv-leading-relaxed: 1.65;
    --rv-tracking-tight: -0.02em;
    --rv-tracking-wide: 0.02em;
    --rv-tracking-caps: 0.08em;

    /* --- Spacing (4-step) --- */
    --rv-space-0: 0;
    --rv-space-1: 4px;
    --rv-space-2: 8px;
    --rv-space-3: 12px;
    --rv-space-4: 16px;
    --rv-space-5: 24px;
    --rv-space-6: 32px;
    --rv-space-7: 48px;
    --rv-space-8: 64px;
    --rv-space-9: 96px;
    --rv-space-10: 128px;

    /* --- Radii --- */
    --rv-radius-sm: 4px;
    --rv-radius-md: 8px;
    --rv-radius-lg: 16px;
    --rv-radius-pill: 999px;

    /* --- Shadows (editorial, low — overlays only) --- */
    --rv-shadow-sm: 0 1px 2px rgba(26, 23, 19, .06);
    --rv-shadow-md: 0 4px 12px rgba(26, 23, 19, .08);
    --rv-shadow-lg: 0 12px 32px rgba(26, 23, 19, .10);
    --rv-shadow-xl: 0 24px 64px rgba(26, 23, 19, .14);

    /* --- Motion --- */
    --rv-motion-fast: 120ms;
    --rv-motion-base: 220ms;
    --rv-motion-slower: 480ms;
    --rv-ease-out-soft: cubic-bezier(.22, .8, .36, 1);

    /* --- Containers --- */
    --rv-container-prose: 46rem;
    --rv-container-text: 64rem;
    --rv-container-wide: 84rem;
}

/* --- Color tokens (dark) — via [data-theme="dark"] OR system pref --- */
[data-theme="dark"] {
    --rv-color-paper: #141210;
    --rv-color-surface-raised: #1D1B18;
    --rv-color-surface-sunken: #0F0D0B;
    --rv-color-ink: #F3EBDA;
    --rv-color-muted: #9A9082;
    --rv-color-rule: #2C2823;
    --rv-color-primary-soft: #4C2419;
    --rv-color-accent-soft: #2A3122;
    --rv-color-focus: #F3EBDA;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --rv-color-paper: #141210;
        --rv-color-surface-raised: #1D1B18;
        --rv-color-surface-sunken: #0F0D0B;
        --rv-color-ink: #F3EBDA;
        --rv-color-muted: #9A9082;
        --rv-color-rule: #2C2823;
        --rv-color-primary-soft: #4C2419;
        --rv-color-accent-soft: #2A3122;
        --rv-color-focus: #F3EBDA;
    }
}

/* ============================================================================
   RESET & BASE
   ============================================================================ */

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

html {
    -webkit-text-size-adjust: 100%;
    line-height: var(--rv-leading-normal);
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-base);
    line-height: var(--rv-leading-normal);
    color: var(--rv-color-ink);
    background: var(--rv-color-paper);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: inherit;
    text-decoration-color: var(--rv-color-primary);
    text-underline-offset: 2px;
    text-decoration-thickness: 1px;
    transition: text-decoration-thickness var(--rv-motion-fast) var(--rv-ease-out-soft);
}

a:hover { text-decoration-thickness: 2px; }

/* Skip link (DS §8) */
.rv-skip {
    position: absolute;
    top: -100vh;
    left: 0;
    padding: var(--rv-space-3) var(--rv-space-5);
    background: var(--rv-color-ink);
    color: var(--rv-color-paper);
    z-index: 9999;
    font-family: var(--rv-font-sans);
}
.rv-skip:focus { top: 0; }

/* Focus rings — DS §8 */
:focus-visible {
    outline: 2px solid var(--rv-color-focus);
    outline-offset: 2px;
}

/* ============================================================================
   TYPOGRAPHY — DS §2 (type scale + families)
   ============================================================================ */

h1, h2, h3, h4, h5, h6,
.rv-h1, .rv-h2, .rv-h3, .rv-h4, .rv-h5, .rv-h6 {
    font-family: var(--rv-font-serif);
    font-weight: 400;
    line-height: var(--rv-leading-snug);
    letter-spacing: var(--rv-tracking-tight);
    margin: 0 0 var(--rv-space-4);
    color: var(--rv-color-ink);
}

h1, .rv-h1 { font-size: var(--rv-text-4xl); line-height: var(--rv-leading-tight); }
h2, .rv-h2 { font-size: var(--rv-text-3xl); }
h3, .rv-h3 { font-size: var(--rv-text-2xl); }
h4, .rv-h4 { font-size: var(--rv-text-xl); }
h5, .rv-h5 { font-size: var(--rv-text-lg); }
h6, .rv-h6 { font-size: var(--rv-text-base); }

.rv-eyebrow {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-muted);
}

.rv-display {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-display);
    font-weight: 400;
    line-height: var(--rv-leading-tight);
    letter-spacing: var(--rv-tracking-tight);
    /* DS §2 — Fraunces variable axes */
    font-variation-settings: "opsz" 144, "SOFT" 50;
}

p { margin: 0 0 var(--rv-space-4); line-height: var(--rv-leading-relaxed); }
small, .rv-text-sm { font-size: var(--rv-text-sm); }

/* ============================================================================
   LAYOUT PRIMITIVES — containers (DS §2)
   ============================================================================ */

.rv-container,
.rv-container--wide {
    width: 100%;
    max-width: var(--rv-container-wide);
    margin-inline: auto;
    padding-inline: var(--rv-space-5);
}
.rv-container--text { max-width: var(--rv-container-text); }
.rv-container--prose { max-width: var(--rv-container-prose); }

@media (min-width: 768px) {
    .rv-container,
    .rv-container--wide,
    .rv-container--text,
    .rv-container--prose { padding-inline: var(--rv-space-7); }
}

/* ============================================================================
   COMPONENT — rv-button (DS §3 — variants --primary, --secondary, --ghost, --link)
   ============================================================================ */

.rv-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--rv-space-2);
    min-height: 44px;
    padding: var(--rv-space-3) var(--rv-space-5);
    border: 1px solid transparent;
    border-radius: var(--rv-radius-pill);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-base);
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    transition:
        background-color var(--rv-motion-base) var(--rv-ease-out-soft),
        color var(--rv-motion-base) var(--rv-ease-out-soft),
        border-color var(--rv-motion-base) var(--rv-ease-out-soft);
}

.rv-button__icon { width: 1em; height: 1em; flex-shrink: 0; }

.rv-button--primary { background: var(--rv-color-ink); color: var(--rv-color-paper); }
.rv-button--primary:hover,
.rv-button--primary:focus-visible { background: var(--rv-color-primary); }

.rv-button--secondary { background: transparent; color: var(--rv-color-ink); border-color: var(--rv-color-ink); }
.rv-button--secondary:hover,
.rv-button--secondary:focus-visible { background: var(--rv-color-ink); color: var(--rv-color-paper); }

.rv-button--ghost { background: transparent; color: var(--rv-color-ink); }
.rv-button--ghost:hover,
.rv-button--ghost:focus-visible { background: var(--rv-color-surface-sunken); }

.rv-button--link {
    min-height: 0;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--rv-color-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.rv-button--sm { padding: var(--rv-space-2) var(--rv-space-4); font-size: var(--rv-text-sm); min-height: 36px; }
.rv-button--lg { padding: var(--rv-space-4) var(--rv-space-7); font-size: var(--rv-text-lg); min-height: 52px; }

/* ============================================================================
   COMPONENT — rv-input, rv-select, rv-textarea, rv-checkbox, rv-radio, rv-switch
   ============================================================================ */

.rv-input,
.rv-select,
.rv-textarea {
    display: block;
    width: 100%;
    min-height: 44px;
    padding: var(--rv-space-3) var(--rv-space-4);
    background: var(--rv-color-surface-raised);
    color: var(--rv-color-ink);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-base);
    line-height: var(--rv-leading-normal);
    border: 1px solid var(--rv-color-rule);
    border-radius: var(--rv-radius-md);
    transition: border-color var(--rv-motion-fast) var(--rv-ease-out-soft);
}

.rv-input:focus,
.rv-select:focus,
.rv-textarea:focus {
    border-color: var(--rv-color-ink);
    outline: 2px solid var(--rv-color-focus);
    outline-offset: 2px;
}

.rv-textarea { min-height: 7rem; resize: vertical; }

.rv-select {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%231A1713' stroke-width='1.5'><path d='M3 6l5 5 5-5'/></svg>");
    background-repeat: no-repeat;
    background-position: right var(--rv-space-4) center;
    background-size: 1em;
    padding-right: var(--rv-space-7);
}

.rv-checkbox, .rv-radio {
    width: 18px;
    height: 18px;
    appearance: none;
    border: 1.5px solid var(--rv-color-ink);
    background: var(--rv-color-surface-raised);
    cursor: pointer;
    flex-shrink: 0;
}
.rv-checkbox { border-radius: var(--rv-radius-sm); }
.rv-radio { border-radius: 50%; }
.rv-checkbox:checked, .rv-radio:checked { background: var(--rv-color-ink); }

.rv-switch {
    appearance: none;
    width: 36px;
    height: 20px;
    background: var(--rv-color-rule);
    border-radius: var(--rv-radius-pill);
    position: relative;
    cursor: pointer;
    transition: background var(--rv-motion-base) var(--rv-ease-out-soft);
}
.rv-switch::after {
    content: "";
    position: absolute;
    top: 2px; left: 2px;
    width: 16px; height: 16px;
    background: var(--rv-color-paper);
    border-radius: 50%;
    transition: transform var(--rv-motion-base) var(--rv-ease-out-soft);
}
.rv-switch:checked { background: var(--rv-color-ink); }
.rv-switch:checked::after { transform: translateX(16px); }

/* ============================================================================
   COMPONENT — rv-tag, rv-chip, rv-badge
   ============================================================================ */

.rv-tag {
    display: inline-flex;
    align-items: center;
    padding: var(--rv-space-1) var(--rv-space-3);
    background: var(--rv-color-surface-sunken);
    color: var(--rv-color-ink);
    border-radius: var(--rv-radius-pill);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
}
.rv-tag--accent { background: var(--rv-color-accent-soft); }

.rv-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--rv-space-2);
    padding: var(--rv-space-2) var(--rv-space-4);
    background: var(--rv-color-surface-raised);
    color: var(--rv-color-ink);
    border: 1px solid var(--rv-color-rule);
    border-radius: var(--rv-radius-pill);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    cursor: pointer;
    transition: background var(--rv-motion-base) var(--rv-ease-out-soft);
}
.rv-chip:hover { background: var(--rv-color-surface-sunken); }
.rv-chip--active { background: var(--rv-color-ink); color: var(--rv-color-paper); border-color: var(--rv-color-ink); }
.rv-chip__count { font-size: var(--rv-text-xs); color: var(--rv-color-muted); }
.rv-chip--active .rv-chip__count { color: var(--rv-color-paper); opacity: .7; }

.rv-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px var(--rv-space-2);
    border-radius: var(--rv-radius-sm);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
}
.rv-badge--primary { background: var(--rv-color-primary); color: var(--rv-color-paper); }
.rv-badge--accent  { background: var(--rv-color-accent);  color: var(--rv-color-paper); }
.rv-badge--muted   { background: var(--rv-color-surface-sunken); color: var(--rv-color-muted); }

/* ============================================================================
   COMPONENT — rv-rating (NUMERIC Booking-style score, NOT stars per DS §3)
   ============================================================================ */

.rv-rating {
    display: inline-flex;
    align-items: center;
    gap: var(--rv-space-2);
    font-family: var(--rv-font-sans);
}
.rv-rating__score {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5em;
    padding: var(--rv-space-1) var(--rv-space-2);
    background: var(--rv-color-surface-sunken);
    color: var(--rv-color-ink);
    border-radius: var(--rv-radius-sm);
    font-weight: 600;
    font-size: var(--rv-text-base);
}
.rv-rating__score--high { background: var(--rv-color-accent-soft); color: var(--rv-color-accent); }
.rv-rating__label { font-size: var(--rv-text-sm); color: var(--rv-color-ink); }
.rv-rating__count { font-size: var(--rv-text-sm); color: var(--rv-color-muted); }

/* ============================================================================
   COMPONENT — rv-breadcrumb
   ============================================================================ */

.rv-breadcrumb {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
}
.rv-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    list-style: none;
    margin: 0; padding: 0;
    gap: var(--rv-space-2);
}
.rv-breadcrumb__item { display: inline-flex; align-items: center; }
.rv-breadcrumb__item:not(:last-child)::after {
    content: "·";
    margin-left: var(--rv-space-2);
    color: var(--rv-color-rule);
}
.rv-breadcrumb__link { color: var(--rv-color-muted); text-decoration: none; }
.rv-breadcrumb__link:hover { color: var(--rv-color-ink); }
.rv-breadcrumb__item[aria-current="page"] { color: var(--rv-color-ink); }

/* ============================================================================
   COMPONENT — rv-pagination
   ============================================================================ */

.rv-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--rv-space-2);
    list-style: none;
    margin: var(--rv-space-7) 0;
    padding: 0;
    font-family: var(--rv-font-sans);
}
.rv-pagination__item,
.rv-pagination a,
.rv-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    min-height: 36px;
    padding: 0 var(--rv-space-2);
    border: 1px solid var(--rv-color-rule);
    border-radius: var(--rv-radius-sm);
    color: var(--rv-color-ink);
    text-decoration: none;
    transition: background var(--rv-motion-fast) var(--rv-ease-out-soft);
}
.rv-pagination a:hover { background: var(--rv-color-surface-sunken); }
.rv-pagination .current,
.rv-pagination__item--current { background: var(--rv-color-ink); color: var(--rv-color-paper); border-color: var(--rv-color-ink); }
.rv-pagination__ellipsis { border: none; }

/* ============================================================================
   COMPONENT — rv-link, rv-divider
   ============================================================================ */

.rv-link {
    color: var(--rv-color-ink);
    text-decoration: underline;
    text-decoration-color: var(--rv-color-primary);
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    transition: text-decoration-thickness var(--rv-motion-fast) var(--rv-ease-out-soft);
}
.rv-link:hover { text-decoration-thickness: 2px; }

.rv-divider {
    border: none;
    border-top: 1px solid var(--rv-color-rule);
    margin: var(--rv-space-7) 0;
}

/* ============================================================================
   COMPONENT — rv-card-grid (responsive 2/3/4 → 2 → 1)
   ============================================================================ */

.rv-card-grid { display: grid; gap: var(--rv-space-5); grid-template-columns: 1fr; }

@media (min-width: 768px) {
    .rv-card-grid--2,
    .rv-card-grid--3,
    .rv-card-grid--4 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
    .rv-card-grid--3 { grid-template-columns: repeat(3, 1fr); }
    .rv-card-grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* ============================================================================
   COMPONENT — rv-country-card (image 4:5)
   ============================================================================ */

.rv-country-card { display: block; text-decoration: none; color: inherit; }
.rv-country-card__image {
    aspect-ratio: 4/5;
    overflow: hidden;
    border-radius: var(--rv-radius-md);
    background: var(--rv-color-surface-sunken);
}
.rv-country-card__image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform var(--rv-motion-slower) var(--rv-ease-out-soft);
}
.rv-country-card:hover .rv-country-card__image img { transform: scale(1.04); }
.rv-country-card__name {
    margin: var(--rv-space-3) 0 var(--rv-space-1);
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-xl);
    color: var(--rv-color-ink);
}
.rv-country-card__count {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
}
.rv-country-card__tagline {
    font-family: var(--rv-font-serif);
    font-style: italic;
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
    margin: var(--rv-space-1) 0 0;
}

/* ============================================================================
   COMPONENT — rv-hotel-card (image 3:2; --featured 16:10; --compact no desc)
   ============================================================================ */

.rv-hotel-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    background: var(--rv-color-surface-raised);
    border-radius: var(--rv-radius-md);
    overflow: hidden;
}
.rv-hotel-card__image {
    aspect-ratio: 3/2;
    overflow: hidden;
    background: var(--rv-color-surface-sunken);
}
.rv-hotel-card__image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform var(--rv-motion-slower) var(--rv-ease-out-soft);
}
.rv-hotel-card:hover .rv-hotel-card__image img { transform: scale(1.03); }

.rv-hotel-card__body {
    padding: var(--rv-space-5);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--rv-space-3);
}
.rv-hotel-card__eyebrow {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-muted);
    margin: 0;
}
.rv-hotel-card__title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-xl);
    line-height: var(--rv-leading-snug);
    margin: 0;
    color: var(--rv-color-ink);
}
.rv-hotel-card__location {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
}
.rv-hotel-card__desc {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-base);
    line-height: var(--rv-leading-normal);
    color: var(--rv-color-ink);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.rv-hotel-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: var(--rv-space-4);
    border-top: 1px solid var(--rv-color-rule);
}
.rv-hotel-card__price {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-lg);
    color: var(--rv-color-ink);
}

.rv-hotel-card--featured .rv-hotel-card__image { aspect-ratio: 16/10; }
.rv-hotel-card--featured .rv-hotel-card__title { font-size: var(--rv-text-2xl); }
.rv-hotel-card--compact  .rv-hotel-card__desc  { display: none; }

/* ============================================================================
   COMPONENT — rv-blog-card (image 3:2; --featured 16:9)
   ============================================================================ */

.rv-blog-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.rv-blog-card__image {
    aspect-ratio: 3/2;
    overflow: hidden;
    border-radius: var(--rv-radius-md);
    background: var(--rv-color-surface-sunken);
}
.rv-blog-card__image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform var(--rv-motion-slower) var(--rv-ease-out-soft);
}
.rv-blog-card:hover .rv-blog-card__image img { transform: scale(1.03); }
.rv-blog-card__category {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-accent);
    margin: var(--rv-space-3) 0 var(--rv-space-2);
}
.rv-blog-card__title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-xl);
    line-height: var(--rv-leading-snug);
    color: var(--rv-color-ink);
    margin: 0 0 var(--rv-space-2);
}
.rv-blog-card__deck {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-base);
    color: var(--rv-color-ink);
    line-height: var(--rv-leading-normal);
    margin: 0 0 var(--rv-space-3);
}
.rv-blog-card__meta {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-muted);
}
.rv-blog-card__meta-sep::before { content: "·"; margin: 0 var(--rv-space-2); }

.rv-blog-card--featured .rv-blog-card__image { aspect-ratio: 16/9; }
.rv-blog-card--featured .rv-blog-card__title { font-size: var(--rv-text-3xl); }

/* ============================================================================
   COMPONENT — rv-hero (variants --image-full, --split, --minimal)
   ============================================================================ */

.rv-hero { position: relative; overflow: hidden; }

.rv-hero--image-full {
    min-height: 72vh;
    display: flex;
    align-items: flex-end;
    color: var(--rv-color-paper);
}
.rv-hero--image-full .rv-hero__image { position: absolute; inset: 0; z-index: 0; }
.rv-hero--image-full .rv-hero__image img { width: 100%; height: 100%; object-fit: cover; }
.rv-hero--image-full::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 30%, rgba(20, 18, 16, 0.7) 100%);
    z-index: 1;
}
.rv-hero--image-full .rv-hero__content {
    position: relative;
    z-index: 2;
    padding: var(--rv-space-8) var(--rv-space-5);
    width: 100%;
    max-width: var(--rv-container-wide);
    margin-inline: auto;
}

.rv-hero__title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-display);
    line-height: var(--rv-leading-tight);
    letter-spacing: var(--rv-tracking-tight);
    margin: 0 0 var(--rv-space-4);
    font-variation-settings: "opsz" 144, "SOFT" 50;
}
.rv-hero__deck {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-xl);
    line-height: var(--rv-leading-normal);
    max-width: 40rem;
    margin: 0;
}

.rv-hero--split { display: grid; gap: var(--rv-space-6); align-items: center; padding: var(--rv-space-7) var(--rv-space-5); }

@media (min-width: 1024px) {
    .rv-hero--split { grid-template-columns: 4fr 5fr; }
}

.rv-hero--minimal {
    padding: var(--rv-space-7) var(--rv-space-5) var(--rv-space-5);
    border-bottom: 1px solid var(--rv-color-rule);
}

/* ============================================================================
   COMPONENT — rv-editorial-block (drop-cap on first lead paragraph)
   ============================================================================ */

.rv-editorial-block {
    max-width: var(--rv-container-prose);
    margin-inline: auto;
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-lg);
    line-height: var(--rv-leading-relaxed);
    color: var(--rv-color-ink);
}
.rv-editorial-block p { margin: 0 0 var(--rv-space-5); }
.rv-editorial-block__lead::first-letter {
    font-family: var(--rv-font-serif);
    color: var(--rv-color-primary);
    float: left;
    font-size: 4em;
    line-height: 0.85;
    margin: 0.05em var(--rv-space-3) 0 0;
    font-variation-settings: "opsz" 144, "SOFT" 50;
}
.rv-editorial-block h2 { font-size: var(--rv-text-2xl); margin: var(--rv-space-7) 0 var(--rv-space-4); }
.rv-editorial-block h3 { font-size: var(--rv-text-xl); margin: var(--rv-space-6) 0 var(--rv-space-3); }

/* ============================================================================
   COMPONENT — rv-figure
   ============================================================================ */

.rv-figure { margin: var(--rv-space-7) 0; }
.rv-figure__image {
    overflow: hidden;
    border-radius: var(--rv-radius-md);
    background: var(--rv-color-surface-sunken);
}
.rv-figure__image img { width: 100%; height: auto; display: block; }
.rv-figure__caption {
    margin-top: var(--rv-space-3);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
    line-height: var(--rv-leading-normal);
}
.rv-figure__credit {
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    margin-right: var(--rv-space-2);
}

/* ============================================================================
   COMPONENT — rv-pull-quote (24ch measure, 3xl serif, attribution caps)
   ============================================================================ */

.rv-pull-quote {
    border-top: 1px solid var(--rv-color-rule);
    border-bottom: 1px solid var(--rv-color-rule);
    padding: var(--rv-space-7) 0;
    margin: var(--rv-space-7) 0;
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-3xl);
    line-height: var(--rv-leading-snug);
    max-width: 24ch;
    color: var(--rv-color-ink);
}
.rv-pull-quote__attribution {
    display: block;
    margin-top: var(--rv-space-4);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-muted);
}

/* ============================================================================
   COMPONENT — rv-stat-band (4-col, big serif numbers, muted labels)
   ============================================================================ */

.rv-stat-band {
    display: grid;
    gap: var(--rv-space-5);
    grid-template-columns: 1fr;
    padding: var(--rv-space-7) var(--rv-space-5);
    border-block: 1px solid var(--rv-color-rule);
}
@media (min-width: 768px)  { .rv-stat-band { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .rv-stat-band { grid-template-columns: repeat(4, 1fr); } }

.rv-stat-band__value {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-5xl);
    line-height: var(--rv-leading-tight);
    color: var(--rv-color-ink);
    font-variation-settings: "opsz" 144, "SOFT" 50;
}
.rv-stat-band__label {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
    margin-top: var(--rv-space-2);
}

/* ============================================================================
   COMPONENT — rv-cta-band (ink bg cream text, inverted primary button)
   ============================================================================ */

.rv-cta-band {
    background: var(--rv-color-ink);
    color: var(--rv-color-paper);
    padding: var(--rv-space-8) var(--rv-space-5);
    text-align: center;
    border-radius: var(--rv-radius-md);
}
.rv-cta-band__heading {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-3xl);
    color: var(--rv-color-paper);
    margin: 0 0 var(--rv-space-4);
}
.rv-cta-band__body {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-lg);
    color: var(--rv-color-paper);
    max-width: 40rem;
    margin: 0 auto var(--rv-space-5);
}
.rv-cta-band .rv-button--primary { background: var(--rv-color-paper); color: var(--rv-color-ink); }
.rv-cta-band .rv-button--primary:hover { background: var(--rv-color-primary); color: var(--rv-color-paper); }

/* ============================================================================
   COMPONENT — rv-newsletter-signup
   ============================================================================ */

.rv-newsletter-signup {
    display: grid;
    gap: var(--rv-space-5);
    padding: var(--rv-space-7) 0;
    border-block: 1px solid var(--rv-color-rule);
}
@media (min-width: 768px) {
    .rv-newsletter-signup { grid-template-columns: 1fr 1fr; align-items: center; }
}
.rv-newsletter-signup__title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-2xl);
    margin: 0 0 var(--rv-space-3);
}
.rv-newsletter-signup__desc {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-base);
    color: var(--rv-color-muted);
    margin: 0;
}
.rv-newsletter-signup__form { display: flex; gap: var(--rv-space-2); }

/* ============================================================================
   COMPONENT — rv-ai-finder-inline (the ONE allowed gradient band per DS §11)
   ============================================================================ */

.rv-ai-finder-inline {
    background: linear-gradient(135deg, var(--rv-color-primary-soft) 0%, var(--rv-color-accent-soft) 100%);
    padding: var(--rv-space-7) var(--rv-space-5);
    border-radius: var(--rv-radius-md);
    display: grid;
    gap: var(--rv-space-5);
}
@media (min-width: 1024px) {
    .rv-ai-finder-inline { grid-template-columns: 3fr 2fr; align-items: end; }
}
.rv-ai-finder-inline__eyebrow {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    text-transform: uppercase;
    letter-spacing: var(--rv-tracking-caps);
    color: var(--rv-color-ink);
    opacity: .7;
}
.rv-ai-finder-inline__title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-3xl);
    margin: var(--rv-space-2) 0 var(--rv-space-3);
}
.rv-ai-finder-inline__desc {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-base);
    color: var(--rv-color-ink);
    margin: 0;
    max-width: 40ch;
}
.rv-ai-finder-inline__form { display: flex; gap: var(--rv-space-2); }

/* ============================================================================
   CHROME — rv-site-header (sticky, paper-blur)
   ============================================================================ */

.rv-site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(247, 242, 232, 0.85);
    backdrop-filter: saturate(150%) blur(12px);
    -webkit-backdrop-filter: saturate(150%) blur(12px);
    border-bottom: 1px solid var(--rv-color-rule);
}
.rv-site-header__container {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--rv-space-5);
    max-width: var(--rv-container-wide);
    margin-inline: auto;
    padding: var(--rv-space-3) var(--rv-space-5);
}
.rv-site-header__logo {
    display: inline-flex;
    align-items: center;
    gap: var(--rv-space-2);
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-xl);
    color: var(--rv-color-ink);
    text-decoration: none;
}
.rv-nav { display: flex; gap: var(--rv-space-5); justify-content: center; }
.rv-nav__link {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-base);
    color: var(--rv-color-ink);
    text-decoration: none;
    padding: var(--rv-space-2) var(--rv-space-3);
}
.rv-nav__link:hover { color: var(--rv-color-primary); }
.rv-site-header__actions { display: flex; align-items: center; gap: var(--rv-space-4); }

/* ============================================================================
   CHROME — rv-site-footer (ink bg, cream text, 4-col countries grid)
   ============================================================================ */

.rv-site-footer {
    background: var(--rv-color-ink);
    color: var(--rv-color-paper);
    padding: var(--rv-space-8) var(--rv-space-5) var(--rv-space-5);
}
.rv-site-footer__container { max-width: var(--rv-container-wide); margin-inline: auto; }
.rv-site-footer__top {
    display: grid;
    gap: var(--rv-space-7);
    padding-bottom: var(--rv-space-7);
    border-bottom: 1px solid rgba(247, 242, 232, 0.15);
}
@media (min-width: 1024px) {
    .rv-site-footer__top { grid-template-columns: 1.2fr 2fr; }
}
.rv-site-footer__brand { font-family: var(--rv-font-serif); }
.rv-site-footer__tagline {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-base);
    color: var(--rv-color-paper);
    opacity: .7;
    margin-top: var(--rv-space-3);
}
.rv-site-footer__countries {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--rv-space-3) var(--rv-space-5);
    list-style: none;
    margin: 0; padding: 0;
}
@media (min-width: 768px) {
    .rv-site-footer__countries { grid-template-columns: repeat(4, 1fr); }
}
.rv-site-footer__countries a {
    color: var(--rv-color-paper);
    opacity: .85;
    text-decoration: none;
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
}
.rv-site-footer__countries a:hover { opacity: 1; }
.rv-site-footer__bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: var(--rv-space-4);
    padding-top: var(--rv-space-5);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-xs);
    color: var(--rv-color-paper);
    opacity: .7;
}

/* ============================================================================
   BRIDGE LAYER — bind existing template-parts/functions.php class names to DS tokens.
   Remove rules below as template-parts migrate to rv-* BEM classes.
   ============================================================================ */

/* Containers — bridge .container (main.css uses 1600px) to wide token */
.container { max-width: var(--rv-container-wide); }

/* Section bg alternation (single-hotels.php) */
.container-bg { background: var(--rv-color-surface-sunken); }

/* Body type — apply DS fonts/colors to existing rules */
body {
    font-family: var(--rv-font-sans);
    color: var(--rv-color-ink);
    background: var(--rv-color-paper);
}
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--rv-font-serif);
    color: var(--rv-color-ink);
}
p, .p { font-family: var(--rv-font-serif); }

/* Site header (header.php — .header / .menu) */
.main-header { background: var(--rv-color-paper); border-bottom: 1px solid var(--rv-color-rule); }
.menu li a { color: var(--rv-color-ink); font-family: var(--rv-font-sans); }
.menu li a:hover,
.menu .submenu li a:hover { color: var(--rv-color-primary); }
.menu .submenu {
    background: var(--rv-color-surface-raised);
    box-shadow: var(--rv-shadow-md);
    border-radius: var(--rv-radius-md);
    border: 1px solid var(--rv-color-rule);
}

/* Footer (footer.php) */
.footer { background: var(--rv-color-ink); color: var(--rv-color-paper); }
.footer-column a { color: var(--rv-color-paper); opacity: .85; }
.footer-column a:hover { opacity: 1; }
.footer-bottom { border-top-color: rgba(247, 242, 232, 0.15); }

/* Hotel article (single-hotels.php) */
.hotel { color: var(--rv-color-ink); }
.post-header .post-title {
    font-family: var(--rv-font-serif);
    font-size: var(--rv-text-display);
    line-height: var(--rv-leading-tight);
    color: var(--rv-color-ink);
}

/* Address */
.address {
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-sm);
    color: var(--rv-color-muted);
    font-style: normal;
}

/* CTA buttons (display_cta() — must keep .btn-book class for gtag conversion) */
.cta-buttons .button {
    background: var(--rv-color-ink);
    color: var(--rv-color-paper);
    border-radius: var(--rv-radius-pill);
    padding: var(--rv-space-3) var(--rv-space-5);
    font-family: var(--rv-font-sans);
    font-size: var(--rv-text-base);
    transition: background var(--rv-motion-base) var(--rv-ease-out-soft);
}
.cta-buttons .button:hover { background: var(--rv-color-primary); }

/* Sticky mobile CTA */
#lastcta {
    background: var(--rv-color-surface-raised);
    border-top: 1px solid var(--rv-color-rule);
    box-shadow: var(--rv-shadow-md);
}

/* Listing — hotel-item card */
.hotel-item {
    background: var(--rv-color-surface-raised);
    border: 1px solid var(--rv-color-rule);
    border-radius: var(--rv-radius-md);
}
.hotel-info h3,
.hotel-info .h4 { font-family: var(--rv-font-serif); color: var(--rv-color-ink); }
.hotel-content { font-family: var(--rv-font-serif); color: var(--rv-color-ink); line-height: var(--rv-leading-normal); }

/* Single-hotel rating bars (.base-rating, .guest-review) */
.base-rating .wrap,
.guest-review .wrap {
    background: var(--rv-color-surface-sunken);
    border-color: var(--rv-color-rule);
    border-radius: var(--rv-radius-pill);
    overflow: hidden;
}
.base-rating .val,
.guest-review .val {
    background: var(--rv-color-accent);
    color: var(--rv-color-paper);
}

/* Reviews carousel */
.single-review {
    background: var(--rv-color-surface-raised);
    border-radius: var(--rv-radius-md);
    border: 1px solid var(--rv-color-rule);
}
.single-review .title { font-family: var(--rv-font-serif); color: var(--rv-color-ink); }
.single-review .score { border-radius: var(--rv-radius-sm); font-family: var(--rv-font-sans); font-size: var(--rv-text-sm); font-weight: 600; }

/* Filter form (display_sorting_options() in functions.php) */
#hotel-filter-form select,
#hotel-filter-form button {
    font-family: var(--rv-font-sans);
    border-radius: var(--rv-radius-md);
    border-color: var(--rv-color-rule);
}
#hotel-filter-form .submit-button {
    background: var(--rv-color-ink);
    color: var(--rv-color-paper);
    border-color: var(--rv-color-ink);
}

/* Featured-image hero (page.php / page-countries.php → shared template-part) */
.featured-image.wide { border-radius: var(--rv-radius-lg); overflow: hidden; }
.single-page-title { font-family: var(--rv-font-serif); font-variation-settings: "opsz" 144, "SOFT" 50; }

/* Breadcrumbs (functions.php generate_breadcrumbs() → .breadcrumbs) */
.breadcrumbs { font-family: var(--rv-font-sans); font-size: var(--rv-text-sm); color: var(--rv-color-muted); border-top-color: var(--rv-color-rule); }
.breadcrumbs ol { gap: var(--rv-space-2); }
.breadcrumbs li:not(:last-child)::after { content: "·"; color: var(--rv-color-rule); }
.breadcrumbs a { color: var(--rv-color-muted); }
.breadcrumbs a:hover { color: var(--rv-color-ink); }

/* Pagination (paginate_links output) */
.pagination a,
.pagination span { border-color: var(--rv-color-rule); border-radius: var(--rv-radius-sm); font-family: var(--rv-font-sans); }
.pagination .current { background: var(--rv-color-ink); color: var(--rv-color-paper); border-color: var(--rv-color-ink); }

/* Find-hotels button (get_footer_check_label()) */
.find-hotels-container { background: var(--rv-color-ink); }
.find-hotels-button { color: var(--rv-color-paper); font-family: var(--rv-font-serif); }

/* ============================================================================
   ANIMATIONS — DS §2 motion + scroll-reveal helpers (consumed by JS via [data-animate])
   ============================================================================ */

@keyframes rv-fade-in {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes rv-fade-in-down {
    from { opacity: 0; transform: translateY(-12px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes rv-zoom-in {
    from { opacity: 0; transform: scale(0.96); }
    to   { opacity: 1; transform: scale(1); }
}

/* Scroll-reveal: elements with [data-animate] start hidden; .is-visible reveals */
[data-animate] {
    opacity: 0;
    transform: translateY(16px);
    transition:
        opacity var(--rv-motion-slower) var(--rv-ease-out-soft),
        transform var(--rv-motion-slower) var(--rv-ease-out-soft);
    will-change: opacity, transform;
}
[data-animate].is-visible { opacity: 1; transform: translateY(0); }

[data-animate="fade-in-down"] { transform: translateY(-16px); }
[data-animate="fade-in-down"].is-visible { transform: translateY(0); }

[data-animate="zoom-in"] { transform: scale(0.96); }
[data-animate="zoom-in"].is-visible { transform: scale(1); }

[data-animate-delay="100"] { transition-delay: 100ms; }
[data-animate-delay="200"] { transition-delay: 200ms; }
[data-animate-delay="300"] { transition-delay: 300ms; }
[data-animate-delay="400"] { transition-delay: 400ms; }

/* JS-toggleable global states */
body.is-menu-open,
body.menu-opened { overflow: hidden; }

/* Loading skeleton */
.rv-skeleton {
    background: linear-gradient(90deg,
        var(--rv-color-surface-sunken) 0%,
        var(--rv-color-rule) 50%,
        var(--rv-color-surface-sunken) 100%);
    background-size: 200% 100%;
    animation: rv-skeleton-pulse 1.4s ease-in-out infinite;
    border-radius: var(--rv-radius-md);
}
@keyframes rv-skeleton-pulse {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Reduced motion — disable all animations & transitions per DS §2 */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    [data-animate] { opacity: 1; transform: none; }
}

/* ============================================================================
   UTILITIES (the ONE place where !important is allowed)
   ============================================================================ */

.u-hidden { display: none !important; }
.u-visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}
.u-text-center { text-align: center !important; }
.u-text-muted  { color: var(--rv-color-muted) !important; }

/* ============================================================================
   RESPONSIVE — DS §2 breakpoints (768, 1024). Mobile-first.
   ============================================================================ */

/* Below 1024 — mega-menu / filters collapse to bottom-sheet (DS §8).
   JS hook: [data-open="true"] toggles modal-style display. */
@media (max-width: 1023.98px) {
    .rv-nav[data-open="true"] {
        position: fixed;
        inset: 0;
        background: var(--rv-color-paper);
        flex-direction: column;
        justify-content: center;
        align-items: stretch;
        padding: var(--rv-space-7);
        z-index: 1000;
    }
}
