/* ============================================================
   Reservaria — Marketing Website Styles
   ============================================================ */

/* --- Riatrix-style accent (Rubik ExtraBold) — kept ONLY for sprinkles --- */
@font-face {
  font-family: "Rubik";
  src: url("fonts/Rubik-Regular.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Rubik";
  src: url("fonts/Rubik-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Rubik";
  src: url("fonts/Rubik-ExtraBold.ttf") format("truetype");
  font-weight: 800; font-style: normal; font-display: swap;
}

:root {
  /* Brand */
  --rv-red: #DD1420;
  --rv-red-deep: #B30E18;
  --rv-red-dark: #7E0A11;
  --rv-red-hover: #C0111B;
  --rv-red-soft: #FCE7E8;

  --rv-black: #000000;
  --rv-ink: #111111;
  --rv-charcoal: #1F1F1F;
  --rv-graphite: #2C2C2C;

  --rv-white: #FFFFFF;
  --rv-bone: #F6F6F4;
  --rv-paper: #EDEDEA;
  --rv-rule: #E2E2DF;
  --rv-rule-strong: #C9C9C5;

  --rv-fg-1: #111111;
  --rv-fg-2: #444444;
  --rv-fg-3: #6B6B6B;
  --rv-fg-4: #9A9A9A;

  --rv-gradient-red:
    radial-gradient(120% 120% at 8% 8%, #6B080E 0%, #A50C16 35%, #DD1420 100%);

  /* Corporate font (serious & readable) */
  --font-corp: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  /* Riatrix-style accent (the geometric voice of the logo) */
  --font-accent: "Rubik", "Inter", sans-serif;

  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;
  --sp-8: 64px;
  --sp-9: 96px;
  --sp-10: 128px;

  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 28px;
  --r-pill: 999px;

  --shadow-1: 0 1px 2px rgba(17,17,17,0.06), 0 1px 1px rgba(17,17,17,0.04);
  --shadow-2: 0 6px 18px rgba(17,17,17,0.08), 0 1px 2px rgba(17,17,17,0.05);
  --shadow-3: 0 18px 48px rgba(17,17,17,0.14), 0 4px 10px rgba(17,17,17,0.06);
  --shadow-red: 0 14px 32px rgba(221,20,32,0.32);

  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-corp);
  font-size: 16px;
  line-height: 1.6;
  color: var(--rv-ink);
  background: var(--rv-bone);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
  /* Evita el scroll lateral por desbordes decorativos/animaciones de entrada.
     'clip' no crea contenedor de scroll, así que el eje vertical sigue normal. */
  overflow-x: clip;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ---------- Riatrix accent & asterisk helpers ---------- */
.acc {
  font-family: var(--font-accent);
  font-weight: 800;
  letter-spacing: -0.01em;
}
.acc-red { color: var(--rv-red); }
.acc-it { font-style: italic; }

.ast {
  display: inline-block;
  color: var(--rv-red);
  font-family: var(--font-accent);
  font-weight: 800;
  line-height: 1;
  transform: translateY(-0.05em);
}

.ast-svg {
  display: inline-block;
  width: 1em;
  height: 1em;
  color: var(--rv-red);
  vertical-align: -0.12em;
}

/* ---------- Layout ---------- */
.wrap {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}
.wrap-tight {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px;
}

section { position: relative; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-corp);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rv-red);
}
.eyebrow .ast { font-size: 14px; }
.eyebrow.on-red { color: rgba(255,255,255,0.85); }
.eyebrow.on-red .ast { color: #fff; }

h1, h2, h3, h4, p { margin: 0; }

.h1 {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(44px, 6.4vw, 88px);
  line-height: 1.02;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.h2 {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-wrap: balance;
}
.h3 {
  font-family: var(--font-corp);
  font-weight: 700;
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 1.2;
  letter-spacing: -0.015em;
}
.h4 {
  font-family: var(--font-corp);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.3;
}

.lead {
  font-weight: 300;
  font-size: clamp(17px, 1.4vw, 21px);
  line-height: 1.55;
  color: var(--rv-fg-2);
  max-width: 64ch;
  text-wrap: pretty;
}
.lead.on-red { color: rgba(255,255,255,0.86); }

.body { font-weight: 400; font-size: 16px; line-height: 1.65; color: var(--rv-fg-2); }
.body.on-red { color: rgba(255,255,255,0.8); }
.meta { font-size: 13px; font-weight: 500; color: var(--rv-fg-3); letter-spacing: 0.02em; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-corp);
  font-size: 15px; font-weight: 600;
  padding: 14px 22px;
  border-radius: var(--r-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform var(--ease) 120ms, background var(--ease) 200ms, color var(--ease) 200ms, border-color var(--ease) 200ms, box-shadow var(--ease) 200ms;
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.btn:active { transform: scale(0.98); }
.btn .ast { font-size: 17px; }

.btn-primary {
  background: var(--rv-red);
  color: var(--rv-white);
  box-shadow: var(--shadow-red);
}
.btn-primary:hover { background: var(--rv-red-hover); }
.btn-primary .ast { color: #fff; }

.btn-ghost {
  background: transparent;
  color: var(--rv-ink);
  border-color: var(--rv-rule-strong);
}
.btn-ghost:hover { background: var(--rv-ink); color: #fff; border-color: var(--rv-ink); }

.btn-on-red {
  background: #fff; color: var(--rv-red);
}
.btn-on-red:hover { background: var(--rv-ink); color: #fff; }
.btn-on-red .ast { color: var(--rv-red); }
.btn-on-red:hover .ast { color: #fff; }

.btn-ghost-on-red {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.5);
}
.btn-ghost-on-red:hover { background: rgba(255,255,255,0.1); border-color: #fff; }

.btn-dark {
  background: var(--rv-ink);
  color: #fff;
}
.btn-dark:hover { background: var(--rv-red); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 50;
  padding: 22px 0;
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.nav-brand {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none;
}
.nav-logo {
  display: block;
  height: 34px;
  width: auto;
}
.nav-logo-dark { display: none; }
.nav.is-scrolled .nav-logo-light { display: none; }
.nav.is-scrolled .nav-logo-dark { display: block; }
.footer-logo {
  display: block;
  height: 42px;
  width: auto;
  margin-bottom: 18px;
}

.nav-links {
  display: flex; align-items: center; gap: 4px;
  list-style: none; margin: 0; padding: 0;
}
.nav-links a {
  display: inline-block;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  border-radius: var(--r-pill);
  transition: background var(--ease) 200ms, color var(--ease) 200ms;
  white-space: nowrap;
}
.nav-links a:hover { background: rgba(255,255,255,0.12); color: #fff; }

.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-cta .btn { padding: 10px 18px; font-size: 14px; box-shadow: none; }

/* En escritorio el contenedor no rompe el layout flex de .nav-inner. */
.nav-menu { display: contents; }

/* Botón hamburguesa (sólo visible en móvil/tablet). */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px; height: 44px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.nav-toggle-bar {
  display: block;
  width: 24px; height: 2px;
  margin: 0 auto;
  background: #fff;
  border-radius: 2px;
  transition: transform var(--ease) 220ms, opacity var(--ease) 180ms, background var(--ease) 200ms;
}
.nav.is-scrolled .nav-toggle-bar { background: var(--rv-ink); }
.nav.is-open .nav-toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.is-open .nav-toggle-bar:nth-child(2) { opacity: 0; }
.nav.is-open .nav-toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.nav.is-scrolled {
  position: fixed;
  background: rgba(246,246,244,0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  padding: 12px 0;
}
.nav.is-scrolled .nav-links a { color: var(--rv-fg-1); }
.nav.is-scrolled .nav-links a:hover { background: rgba(0,0,0,0.06); color: var(--rv-ink); }
.nav.is-scrolled .btn-ghost-on-red { color: var(--rv-ink); border-color: var(--rv-rule-strong); }
.nav.is-scrolled .btn-ghost-on-red:hover { background: var(--rv-ink); color: #fff; border-color: var(--rv-ink); }
.nav.is-scrolled .btn-on-red { background: var(--rv-red); color: #fff; }
.nav.is-scrolled .btn-on-red:hover { background: var(--rv-red-hover); }
.nav.is-scrolled .btn-on-red .ast { color: #fff; }
.nav.is-scrolled .nav-logo { height: 28px; }

@media (max-width: 880px) {
  .nav-inner { position: relative; }
  .nav-toggle { display: flex; }

  /* Panel desplegable que reemplaza la barra horizontal. */
  .nav-menu {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    position: absolute;
    top: calc(100% + 14px);
    left: 0; right: 0;
    padding: 14px;
    background: var(--rv-red-deep);
    border-radius: 18px;
    box-shadow: 0 24px 60px rgba(0,0,0,0.32);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: opacity var(--ease) 200ms, transform var(--ease) 220ms, visibility 0s linear 220ms;
  }
  .nav.is-scrolled .nav-menu {
    background: rgba(246,246,244,0.98);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 24px 60px rgba(0,0,0,0.18);
  }
  .nav.is-open .nav-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition-delay: 0s;
  }

  .nav-links {
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    width: 100%;
  }
  .nav-links a { display: block; padding: 12px 14px; font-size: 16px; }

  .nav-cta {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    width: 100%;
    margin-top: 8px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.16);
  }
  .nav.is-scrolled .nav-cta { border-top-color: rgba(0,0,0,0.08); }
  .nav-cta .btn { width: 100%; text-align: center; justify-content: center; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  background: var(--rv-gradient-red);
  color: #fff;
  overflow: hidden;
  padding: 130px 0 90px;
  isolation: isolate;
}
.hero::after {
  /* gentle vignette at bottom */
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 160px;
  background: linear-gradient(to bottom, transparent, rgba(0,0,0,0.18));
  pointer-events: none;
  z-index: 1;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 64px;
  align-items: center;
  position: relative;
  z-index: 2;
}
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 56px; }
}

.hero-title {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(48px, 7.2vw, 104px);
  line-height: 0.98;
  letter-spacing: -0.04em;
  color: #fff;
  margin-bottom: 28px;
  text-wrap: balance;
}
.hero-title .acc {
  display: inline;
  font-family: var(--font-accent);
  font-weight: 800;
  font-style: italic;
}
.hero-title .ast-inline {
  display: inline-block;
  font-family: var(--font-accent);
  font-weight: 800;
  color: #000;
  transform: translateY(-0.18em);
  margin: 0 0.05em;
  font-size: 0.55em;
}

.hero-sub {
  font-size: clamp(17px, 1.4vw, 21px);
  font-weight: 300;
  line-height: 1.55;
  color: rgba(255,255,255,0.88);
  max-width: 56ch;
  margin-bottom: 36px;
  text-wrap: pretty;
}

.hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 40px; }

.hero-trust {
  display: flex; gap: 24px; align-items: center; flex-wrap: wrap;
  font-size: 13px;
  color: rgba(255,255,255,0.78);
}
.hero-trust .dot { width: 5px; height: 5px; background: rgba(255,255,255,0.5); border-radius: 50%; flex: none; }

/* En móvil se oculta para no recargar el hero. */
@media (max-width: 600px) {
  .hero-trust { display: none; }
}

/* Floating asterisks scattered in hero */
.scatter-ast {
  position: absolute;
  pointer-events: none;
  color: rgba(0,0,0,0.6);
  z-index: 1;
}
.scatter-ast.white { color: rgba(255,255,255,0.14); }
.hero .scatter-ast { animation: floatAst 8s ease-in-out infinite; }

@keyframes floatAst {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-8px) rotate(8deg); }
}

/* ---------- Hero chat mockup ---------- */
.chat-card {
  position: relative;
  background: #fff;
  border-radius: 28px;
  box-shadow: var(--shadow-3), 0 40px 80px rgba(0,0,0,0.35);
  padding: 18px 16px 16px;
  max-width: 420px;
  margin-left: auto;
  color: var(--rv-ink);
  transform: rotate(1.2deg);
}
@media (max-width: 980px) {
  .chat-card { margin: 0 auto; max-width: 380px; }
}
.chat-card::before {
  /* pinned asterisk */
  content: "";
  position: absolute;
  top: -24px; right: -24px;
  width: 64px; height: 64px;
  background: url("assets/asterisk.svg") center/contain no-repeat;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.35));
  z-index: 2;
  animation: floatAst 5s ease-in-out infinite;
}

.chat-head {
  display: flex; align-items: center; gap: 12px;
  padding: 6px 8px 14px;
  border-bottom: 1px solid var(--rv-rule);
  margin-bottom: 14px;
}
.chat-avatar {
  width: 40px; height: 40px;
  background: var(--rv-ink);
  border-radius: 50%;
  display: grid; place-items: center;
  position: relative;
}
.chat-avatar img { width: 22px; height: 22px; }
.chat-avatar::after {
  content: ""; position: absolute; bottom: -2px; right: -2px;
  width: 12px; height: 12px;
  background: #22C55E;
  border-radius: 50%;
  border: 2px solid #fff;
}
.chat-name { font-weight: 700; font-size: 15px; }
.chat-meta-text { font-size: 12px; color: var(--rv-fg-3); }

.chat-thread {
  display: flex; flex-direction: column; gap: 8px;
  padding: 6px;
  min-height: 360px;
}

.bubble {
  max-width: 78%;
  padding: 10px 14px;
  border-radius: 16px;
  font-size: 14.5px;
  line-height: 1.4;
  box-shadow: 0 1px 1px rgba(0,0,0,0.04);
}
.bubble.in {
  background: #fff;
  border: 1px solid var(--rv-rule);
  border-bottom-left-radius: 4px;
  align-self: flex-start;
}
.bubble.out {
  background: var(--rv-ink);
  color: #fff;
  border-bottom-right-radius: 4px;
  align-self: flex-end;
}
.bubble small { display: block; font-size: 10px; opacity: 0.6; margin-top: 4px; }

.bubble .check { color: #22C55E; font-weight: 700; }

/* ============================================================
   Logo strip (verticales)
   ============================================================ */
.strip {
  background: var(--rv-ink);
  color: #fff;
  padding: 36px 0;
  overflow: hidden;
}
.strip-row {
  display: flex; align-items: center; gap: 56px; flex-wrap: wrap;
  justify-content: center;
}
.strip-label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.2em;
  text-transform: uppercase; color: rgba(255,255,255,0.6);
}
.strip-row .ast { color: #fff; opacity: 0.5; }
.strip-item {
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: rgba(255,255,255,0.88);
}

/* ============================================================
   Section base
   ============================================================ */
.section {
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
}
.section-dark { background: var(--rv-ink); color: #fff; }
.section-red { background: var(--rv-gradient-red); color: #fff; overflow: hidden; }
.section-paper { background: var(--rv-paper); }

.section-head {
  max-width: 760px;
  margin-bottom: 56px;
}
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head .eyebrow { margin-bottom: 18px; }
.section-head .lead { margin-top: 20px; }
.section-head.center .lead { margin-left: auto; margin-right: auto; }

/* ============================================================
   THREE-STEP "Cómo funciona"
   ============================================================ */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 880px) { .steps { grid-template-columns: 1fr; } }

.step {
  background: #fff;
  border-radius: var(--r-lg);
  padding: 36px 32px 32px;
  box-shadow: var(--shadow-2);
  position: relative;
  display: flex; flex-direction: column;
  min-height: 280px;
}
.step-num {
  font-family: var(--font-accent);
  font-weight: 300;
  font-size: 64px;
  line-height: 0.9;
  color: var(--rv-rule-strong);
  letter-spacing: -0.04em;
  margin-bottom: 24px;
}
.step .h3 { margin-bottom: 12px; }
.step .body { color: var(--rv-fg-2); font-size: 15.5px; }
.step .ast-corner {
  position: absolute;
  top: 24px; right: 24px;
  width: 22px; height: 22px;
  color: var(--rv-red);
}

/* ============================================================
   FEATURES — alternating layout sections
   ============================================================ */
.feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: center;
  padding: clamp(60px, 8vw, 100px) 0;
  border-top: 1px solid var(--rv-rule);
}
.feature:first-of-type { border-top: 0; }
.feature.reverse { direction: rtl; }
.feature.reverse > * { direction: ltr; }

@media (max-width: 980px) {
  .feature { grid-template-columns: 1fr; gap: 40px; }
  .feature.reverse { direction: ltr; }
}

/* Items de grid: permitir que encojan por debajo del ancho mínimo de su
   contenido. Sin esto, un mock ancho (tabla, dashboard…) empuja el ancho de
   toda la página y aparece scroll horizontal en móvil ("grid blowout"). */
.feature-visual, .feature-body { min-width: 0; }

.feature-body .eyebrow { margin-bottom: 16px; }
.feature-body .h2 { margin-bottom: 18px; }
.feature-body .lead { margin-bottom: 24px; }

/* Dos columnas en escritorio; se apilan en móvil/tablet. */
.split-2 {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 980px) {
  .split-2 { grid-template-columns: 1fr; gap: 40px; }
}

/* Tarjetas de precios: tres columnas en escritorio, apiladas en móvil/tablet. */
.pricing-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}
@media (max-width: 880px) {
  .pricing-grid { grid-template-columns: 1fr; max-width: 460px; }
}

.fbullets {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 12px;
}
.fbullets li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 15.5px; line-height: 1.5; color: var(--rv-fg-2);
}
.fbullets li::before {
  content: "*";
  font-family: var(--font-accent);
  font-weight: 800;
  color: var(--rv-red);
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: -2px;
  transform: translateY(2px);
}
.fbullets li b { color: var(--rv-ink); font-weight: 700; }

/* Mockup visual frame */
.mock {
  background: #fff;
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-3);
  overflow: hidden;
  position: relative;
}
.mock-dark {
  background: var(--rv-ink); color: #fff;
}
.mock-head {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--rv-rule);
  background: var(--rv-bone);
}
.mock-dark .mock-head { border-bottom-color: rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); }
.mock-dots { display: flex; gap: 6px; }
.mock-dots span {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--rv-rule-strong);
}
.mock-title {
  font-size: 12px; font-weight: 600; color: var(--rv-fg-3);
  margin-left: 8px;
}
.mock-dark .mock-title { color: rgba(255,255,255,0.6); }

/* ============================================================
   MOCKUP: Reservations table
   ============================================================ */
.tbl-mock { padding: 0; }
.tbl-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--rv-rule);
}
.tbl-title { font-weight: 700; font-size: 15px; }
.tbl-filter {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--rv-bone);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 12px;
  border: 1px solid var(--rv-rule);
  color: var(--rv-fg-2);
}
.tbl-filter.active { background: var(--rv-ink); color: #fff; border-color: var(--rv-ink); }

.tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.tbl th, .tbl td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--rv-rule);
}
.tbl th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--rv-fg-3);
  background: var(--rv-bone);
}
.tbl td { color: var(--rv-fg-2); }
.tbl td b { color: var(--rv-ink); font-weight: 600; }
.tbl .check {
  width: 14px; height: 14px;
  border: 1.5px solid var(--rv-rule-strong);
  border-radius: 3px;
  display: inline-block;
  vertical-align: middle;
}
.tbl .check.on { background: var(--rv-ink); border-color: var(--rv-ink); position: relative; }
.tbl .check.on::after {
  content: ""; position: absolute;
  inset: 2px 3px 3px 2px;
  border-right: 1.5px solid #fff; border-bottom: 1.5px solid #fff;
  transform: rotate(45deg) translate(-1px, -2px);
  width: 4px; height: 8px;
}

/* Mockups en móvil/tablet (donde las columnas .feature ya se apilan):
   la tabla (varias columnas) no cabe reflowada, así que se desplaza en
   horizontal dentro de su propio marco (min-width fuerza scroll solo cuando
   el contenedor es más estrecho que la tabla). El reflow a 1 columna de
   .form-mock y .ch-grid vive junto a sus reglas base por orden de cascada. */
@media (max-width: 980px) {
  .tbl-bar, .bulk-bar { flex-wrap: wrap; gap: 8px; padding: 12px 14px; }

  .mock-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .mock-scroll .tbl { min-width: 520px; white-space: nowrap; }
}

/* En móviles estrechos no queremos scroll horizontal dentro de la tabla:
   ocultamos las columnas secundarias de cada mockup y dejamos que la tabla
   ocupe el ancho disponible reflowando el texto. Las columnas se identifican
   por posición (nth-child) para no ensuciar el HTML celda a celda. */
@media (max-width: 600px) {
  .mock-scroll { overflow-x: hidden; }
  .mock-scroll .tbl { min-width: 0; white-space: normal; }
  .tbl th, .tbl td { padding: 10px 12px; }

  /* Reservas → ✓ · Cliente · Fecha·Hora · Estado (oculta Código, Recurso, Pax, Pago) */
  .tbl-reservas th:nth-child(2), .tbl-reservas td:nth-child(2),
  .tbl-reservas th:nth-child(4), .tbl-reservas td:nth-child(4),
  .tbl-reservas th:nth-child(6), .tbl-reservas td:nth-child(6),
  .tbl-reservas th:nth-child(8), .tbl-reservas td:nth-child(8) { display: none; }

  /* Recursos → Nombre · Categoría · Estado (oculta Unidades, Horario, acciones) */
  .tbl-recursos th:nth-child(3), .tbl-recursos td:nth-child(3),
  .tbl-recursos th:nth-child(4), .tbl-recursos td:nth-child(4),
  .tbl-recursos th:nth-child(6), .tbl-recursos td:nth-child(6) { display: none; }

  /* Pagos → Nombre · No-show · Estado (oculta Cancel., Ventana) */
  .tbl-pagos th:nth-child(3), .tbl-pagos td:nth-child(3),
  .tbl-pagos th:nth-child(4), .tbl-pagos td:nth-child(4) { display: none; }

  /* Operativa del día (plano de sala): la barra deja sus chips en varias
     líneas y baja el CTA a fila propia para que no se corte contra el marco;
     el plano se compacta para que los tiles no queden ahogados. */
  .plan-toolbar { flex-wrap: wrap; padding: 10px 12px; }
  .plan-toolbar .toolbar-cta { margin-left: 0; width: 100%; text-align: center; }
  .plan { padding: 16px 12px; }
  .plan-grid { gap: 5px; }
  .plan-tile small { display: none; }
  .plan-legend { flex-wrap: wrap; gap: 8px 14px; }
  .plan-legend > span:last-child { margin-left: 0; }

  /* Tu día de un vistazo (dashboard): las rejillas internas no caben en
     móvil (los accesos y "Completadas" no encogen y desbordan el marco).
     Apilamos los accesos directos y pasamos las cifras a 2×2. */
  .dash { padding: 16px; }
  .dash-row { grid-template-columns: 1fr; }
  .dash-cells { grid-template-columns: 1fr 1fr; }
}

.chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px;
  border-radius: var(--r-pill);
  font-size: 11px;
  font-weight: 600;
}
.chip-success { background: #E8F3EC; color: #1A6A3A; }
.chip-warn { background: #FFF2E2; color: #7A4500; }
.chip-info { background: #E8EEF7; color: #244A8B; }
.chip-red { background: var(--rv-red-soft); color: var(--rv-red); }
.chip-dark { background: var(--rv-ink); color: #fff; }
.chip-ghost { background: var(--rv-bone); color: var(--rv-fg-2); border: 1px solid var(--rv-rule); }

.bulk-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px;
  background: var(--rv-ink);
  color: #fff;
  font-size: 12.5px;
}
.bulk-bar .pill {
  background: rgba(255,255,255,0.14);
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-weight: 600;
}
.bulk-bar .bulk-action {
  background: var(--rv-red);
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: 12px;
}
.bulk-bar .bulk-action.ghost { background: rgba(255,255,255,0.1); }
.bulk-bar .spacer { flex: 1; }

/* ============================================================
   MOCKUP: floor plan (sala)
   ============================================================ */
.plan {
  background: linear-gradient(180deg, #EFEFEC 0%, #E5E5E1 100%);
  padding: 24px 18px;
  position: relative;
  border-bottom: 1px solid var(--rv-rule);
}
.plan-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
}
.plan-tile {
  aspect-ratio: 1;
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-size: 9.5px;
  font-weight: 700;
  color: #fff;
  position: relative;
  letter-spacing: 0.04em;
}
.plan-tile small { display: block; font-weight: 500; opacity: 0.85; font-size: 8.5px; margin-top: 2px; }
.plan-tile.free { background: #2EAC65; }
.plan-tile.busy { background: var(--rv-red); }
.plan-tile.bar { background: #8B5A30; grid-column: span 2; aspect-ratio: 2; }
.plan-tile.wall { background: #2C2C2C; }
.plan-tile.stairs { background: #2C2C2C; grid-column: span 2; aspect-ratio: 2; font-size: 9px; }
.plan-tile.round { border-radius: 50%; background: #2EAC65; aspect-ratio: 1; }
.plan-tile.empty { background: transparent; }

.plan-legend {
  display: flex; align-items: center; gap: 16px;
  font-size: 11px; color: var(--rv-fg-3);
  margin-top: 16px;
}
.legend-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 4px; vertical-align: middle; }
.legend-dot.free { background: #2EAC65; }
.legend-dot.busy { background: var(--rv-red); }

.plan-toolbar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: #fff;
  border-bottom: 1px solid var(--rv-rule);
  font-size: 12px;
}
.plan-toolbar .toolbar-cta {
  margin-left: auto;
  padding: 6px 12px;
  background: var(--rv-red);
  color: #fff;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: 11.5px;
}

/* ============================================================
   FAQs preview card grid
   ============================================================ */
.faq-list {
  background: #fff;
  border-radius: var(--r-md);
  overflow: hidden;
}
.faq-list-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  padding: 14px 18px;
  align-items: center;
  border-bottom: 1px solid var(--rv-rule);
}
.faq-list-row:last-child { border-bottom: 0; }
.faq-list-num {
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: 16px;
  color: var(--rv-red);
}
.faq-q { font-weight: 600; font-size: 14px; }
.faq-a { font-size: 12.5px; color: var(--rv-fg-3); margin-top: 2px; }
.toggle {
  width: 28px; height: 16px;
  background: var(--rv-ink);
  border-radius: 999px;
  position: relative;
}
.toggle::after {
  content: ""; position: absolute;
  top: 2px; right: 2px;
  width: 12px; height: 12px;
  background: #fff;
  border-radius: 50%;
}
.toggle.off { background: var(--rv-rule-strong); }
.toggle.off::after { left: 2px; right: auto; }

/* ============================================================
   Channels card
   ============================================================ */
.ch-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: 1fr;
  gap: 16px;
}
/* En móvil: una sola columna y altura natural. Va aquí (después de la base)
   para ganar la cascada; el override agrupado arriba quedaba por delante de
   esta regla y no se aplicaba. */
@media (max-width: 980px) {
  .ch-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
}
.ch-card {
  background: #fff;
  border-radius: var(--r-md);
  padding: 22px 22px;
  border: 1px solid var(--rv-rule);
  position: relative;
  display: flex;
  flex-direction: column;
}
/* El pie (code) se ancla abajo para que las 4 tarjetas queden uniformes
   aunque tengan distinto texto o falte el code (Instagram). */
.ch-card code { margin-top: auto; align-self: flex-start; }
.ch-card .ch-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: grid; place-items: center;
  margin-bottom: 14px;
  font-size: 22px;
  color: #fff;
}
.ch-card.tg .ch-icon { background: #229ED9; }
.ch-card.wa .ch-icon { background: #25D366; }
.ch-card.web .ch-icon { background: var(--rv-ink); }
.ch-card .ch-status {
  position: absolute;
  top: 18px; right: 18px;
  font-size: 10.5px;
  padding: 3px 9px;
  border-radius: var(--r-pill);
  font-weight: 700;
}
.ch-card .ch-status.on { background: #E8F3EC; color: #1A6A3A; }
.ch-card .ch-status.off { background: var(--rv-bone); color: var(--rv-fg-3); border: 1px solid var(--rv-rule); }
.ch-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.ch-card p { font-size: 13px; color: var(--rv-fg-3); margin-bottom: 14px; }
.ch-card code {
  font-family: ui-monospace, monospace;
  font-size: 12px;
  background: var(--rv-bone);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--rv-fg-2);
}

/* ============================================================
   Negocio form preview
   ============================================================ */
.form-mock {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 22px;
}
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-field.full { grid-column: span 2; }
/* En móvil: una sola columna (mismo motivo de cascada que .ch-grid). */
@media (max-width: 980px) {
  .form-mock { grid-template-columns: 1fr; padding: 16px; }
  .form-field.full { grid-column: auto; }
}
.form-field label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--rv-fg-3);
}
.form-field .input {
  background: #fff;
  border: 1px solid var(--rv-rule);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--rv-ink);
}
.form-field .input.prefix {
  display: flex; align-items: center; gap: 0; padding: 0;
}
.form-field .input.prefix .px { padding: 10px 12px; background: var(--rv-bone); border-right: 1px solid var(--rv-rule); color: var(--rv-fg-3); font-size: 13px; }
.form-field .input.prefix .vx { padding: 10px 12px; }

/* ============================================================
   Stripe / Pagos card
   ============================================================ */
.pay-card {
  padding: 24px;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  align-items: flex-start;
}
.pay-icon {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, #635BFF, #00D4FF);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  color: #fff; font-weight: 800;
  font-family: var(--font-accent);
  font-size: 22px;
  letter-spacing: -0.02em;
}
.pay-body h4 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.pay-body p { font-size: 13px; color: var(--rv-fg-3); margin-bottom: 14px; }
.pay-cells {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
}
.pay-cell .lbl { font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--rv-fg-3); }
.pay-cell .val { font-size: 13px; font-weight: 600; color: var(--rv-ink); font-family: ui-monospace, monospace; }
.pay-cell .val.ok { color: #1A6A3A; font-family: var(--font-corp); }

/* ============================================================
   Dashboard preview
   ============================================================ */
.dash {
  padding: 22px;
  display: flex; flex-direction: column; gap: 18px;
}
.dash-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
}
.dash-shortcut {
  padding: 16px;
  border-radius: var(--r-md);
  background: var(--rv-bone);
  border: 1px solid var(--rv-rule);
  display: flex; align-items: center; gap: 10px;
  font-weight: 600;
  font-size: 13px;
}
.dash-shortcut .ico {
  width: 28px; height: 28px;
  background: var(--rv-ink);
  color: #fff;
  border-radius: 6px;
  display: grid; place-items: center;
  font-size: 13px;
  font-weight: 800;
}
.dash-summary {
  background: var(--rv-bone);
  border-radius: var(--r-md);
  padding: 16px;
}
.dash-summary-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.dash-summary-head h5 { font-size: 13px; font-weight: 700; margin: 0; }
.dash-summary-head .when { font-size: 11px; color: var(--rv-fg-3); }
.dash-cells {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
}
.dash-cell {
  background: #fff;
  border-radius: var(--r-sm);
  padding: 12px;
  text-align: left;
  border: 1px solid var(--rv-rule);
}
.dash-cell .n {
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: 26px;
  line-height: 1;
  letter-spacing: -0.03em;
}
.dash-cell .lbl { font-size: 10.5px; color: var(--rv-fg-3); margin-top: 4px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.dash-cell.red .n { color: var(--rv-red); }

/* ============================================================
   Featured Quote / Bold statement
   ============================================================ */
.statement {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--rv-ink);
  color: #fff;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.statement-text {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  max-width: 920px;
  margin: 0 auto;
  text-wrap: balance;
}
.statement-text .acc {
  font-family: var(--font-accent);
  font-style: italic;
  color: var(--rv-red);
}
.statement .ast-bg {
  position: absolute;
  font-family: var(--font-accent);
  font-weight: 800;
  color: rgba(255,255,255,0.04);
  user-select: none;
}

/* ============================================================
   CTA final
   ============================================================ */
.cta-final {
  padding: clamp(80px, 10vw, 140px) 0;
  background: var(--rv-gradient-red);
  color: #fff;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.cta-final .h1 { color: #fff; margin-bottom: 18px; }
.cta-final .lead { color: rgba(255,255,255,0.85); margin: 0 auto 32px; }
.cta-final-ctas { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.cta-final .ast-bg {
  position: absolute;
  font-family: var(--font-accent);
  font-weight: 800;
  color: rgba(0,0,0,0.08);
  user-select: none;
}

/* ============================================================
   FAQ
   ============================================================ */
.faqs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rv-rule);
}
.faq-item {
  padding: 24px 0;
  border-bottom: 1px solid var(--rv-rule);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: start;
  cursor: pointer;
  position: relative;
}
.faq-item .ast-bullet {
  font-family: var(--font-accent); font-weight: 800;
  color: var(--rv-red);
  font-size: 24px;
  line-height: 1;
  margin-top: 4px;
}
.faq-item h4 {
  font-size: 19px; font-weight: 600; line-height: 1.3; margin-bottom: 8px;
  color: var(--rv-ink);
}
.faq-item p {
  font-size: 15px; color: var(--rv-fg-2); line-height: 1.55;
  display: none;
}
.faq-item.open p { display: block; }
.faq-plus {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--rv-rule-strong);
  display: grid; place-items: center;
  font-size: 16px; color: var(--rv-ink);
  transition: transform var(--ease) 220ms, background var(--ease) 220ms;
  margin-top: 2px;
}
.faq-item.open .faq-plus { background: var(--rv-ink); color: #fff; transform: rotate(45deg); border-color: var(--rv-ink); }

/* ============================================================
   Footer
   ============================================================ */
.footer {
  background: var(--rv-black);
  color: #fff;
  padding: 80px 0 32px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 56px;
}
@media (max-width: 880px) {
  /* El espaciador sólo sirve para separar columnas en escritorio. */
  .footer-spacer { display: none; }
  /* Marca a ancho completo arriba; las dos columnas de enlaces, una al lado de la otra. */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px 40px; }
  .footer-brand { grid-column: 1 / -1; }
}
.footer-brand p { color: rgba(255,255,255,0.6); font-size: 14px; max-width: 36ch; line-height: 1.6; }
.footer h5 {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin: 0 0 18px;
}
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer ul a {
  color: rgba(255,255,255,0.85);
  font-size: 14px;
}
.footer ul a:hover { color: var(--rv-red); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  flex-wrap: wrap; gap: 16px;
}
.footer-bottom a { color: rgba(255,255,255,0.7); }
.footer-bottom a:hover { color: #fff; }

/* ============================================================
   MARQUEE — verticales en cinta animada con fotos
   ============================================================ */
.marquee {
  background: var(--rv-ink);
  color: #fff;
  overflow: hidden;
  padding: 64px 0;
  position: relative;
  isolation: isolate;
}
.marquee-label {
  text-align: center;
  margin-bottom: 36px;
}
.marquee-rows {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.marquee-row {
  display: flex;
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.marquee-track {
  display: flex;
  gap: 56px;
  align-items: center;
  animation: scrollX 44s linear infinite;
  width: max-content;
  flex-shrink: 0;
  padding-right: 56px;
}
.marquee-track.reverse { animation-direction: reverse; animation-duration: 56s; }
.marquee-row:hover .marquee-track { animation-play-state: paused; }

.marquee-item {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(54px, 8vw, 112px);
  letter-spacing: -0.035em;
  line-height: 1;
  white-space: nowrap;
  color: #fff;
  flex-shrink: 0;
}
.marquee-item.outline {
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(255,255,255,0.45);
}
.marquee-item.acc {
  font-family: var(--font-accent);
  font-style: italic;
  color: var(--rv-red);
  font-weight: 800;
}
.marquee-ast {
  color: var(--rv-red);
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: clamp(52px, 7.6vw, 104px);
  line-height: 1;
  flex-shrink: 0;
  transform: translateY(-0.05em);
}
.marquee-ast.outline {
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(221,20,32,0.7);
}
.marquee-photo {
  height: clamp(86px, 9vw, 116px);
  aspect-ratio: 16/11;
  border-radius: 14px;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 10px 28px rgba(0,0,0,0.5);
  position: relative;
}
.marquee-photo img { width: 100%; height: 100%; object-fit: cover; }
.marquee-photo .lbl {
  position: absolute;
  bottom: 8px; left: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
@keyframes scrollX {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ============================================================
   SECTORES — grid de fotos con etiquetas
   ============================================================ */
.sector-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 980px) { .sector-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .sector-grid { grid-template-columns: repeat(2, 1fr); } }

.sector-card {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--rv-ink);
  cursor: pointer;
  transition: transform 380ms var(--ease-out);
}
.sector-card:hover { transform: translateY(-4px); }
.sector-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 600ms var(--ease-out), filter 380ms;
  filter: saturate(0.95);
}
.sector-card:hover img { transform: scale(1.06); filter: saturate(1.05); }
.sector-card::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.78) 100%);
}
.sector-card .sector-label {
  position: absolute;
  left: 18px; right: 18px; bottom: 18px;
  z-index: 2;
  color: #fff;
  display: flex; align-items: flex-end; justify-content: space-between; gap: 8px;
}
.sector-card .sector-name {
  font-family: var(--font-corp);
  font-weight: 700;
  font-size: 17px;
  letter-spacing: -0.01em;
  line-height: 1.15;
  text-wrap: balance;
}
.sector-card .sector-meta {
  font-size: 11.5px;
  font-weight: 500;
  color: rgba(255,255,255,0.75);
  margin-top: 4px;
}
.sector-card .sector-ast {
  font-family: var(--font-accent);
  font-weight: 800;
  color: var(--rv-red);
  font-size: 20px;
  line-height: 1;
  background: #fff;
  width: 32px; height: 32px;
  border-radius: 50%;
  display: grid; place-items: center;
  flex-shrink: 0;
  transition: transform 380ms var(--ease-out);
}
.sector-card:hover .sector-ast { transform: rotate(120deg); }

/* ============================================================
   PHOTO BAND — full-bleed photo context
   ============================================================ */
.photo-band {
  position: relative;
  padding: clamp(80px, 12vw, 160px) 0;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.photo-band-bg {
  position: absolute; inset: 0; z-index: -2;
}
.photo-band-bg img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.5) saturate(1.05);
}
.photo-band::before {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(110deg, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.25) 55%, rgba(126,10,17,0.55) 100%);
}
.photo-band .pb-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 980px) { .photo-band .pb-grid { grid-template-columns: 1fr; } }
.photo-band .pb-quote {
  font-family: var(--font-corp);
  font-weight: 300;
  font-size: clamp(26px, 3.4vw, 46px);
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: #fff;
  text-wrap: balance;
}
.photo-band .pb-quote .acc {
  font-family: var(--font-accent);
  font-weight: 800;
  font-style: italic;
  color: #fff;
}
.photo-band .pb-quote .ast {
  color: var(--rv-red);
  font-size: 1.05em;
  vertical-align: -0.1em;
}
.photo-band .pb-meta {
  margin-top: 32px;
  display: flex; align-items: center; gap: 14px;
  color: rgba(255,255,255,0.85);
  font-size: 14px;
}
.photo-band .pb-meta-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  display: grid; place-items: center;
  font-weight: 800; font-size: 18px;
  font-family: var(--font-accent);
  color: #fff;
}
.photo-band .pb-meta-name { font-weight: 700; color: #fff; }
.photo-band .pb-meta-role { color: rgba(255,255,255,0.65); font-size: 13px; margin-top: 2px; }
.photo-band .pb-chat-card { margin-left: auto; max-width: 400px; }

/* ============================================================
   PHOTO MOSAIC — venues collage
   ============================================================ */
.mosaic {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 150px;
  gap: 12px;
}
@media (max-width: 880px) { .mosaic { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 130px; } }

.mosaic-tile {
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--rv-paper);
}
.mosaic-tile img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 500ms var(--ease-out);
}
.mosaic-tile:hover img { transform: scale(1.05); }
.mosaic-tile.tall { grid-row: span 2; }
.mosaic-tile.wide { grid-column: span 2; }
.mosaic-tile.big { grid-column: span 2; grid-row: span 2; }
.mosaic-tile.text {
  background: var(--rv-ink); color: #fff;
  padding: 22px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.mosaic-tile.text .big-num {
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--rv-red);
}
.mosaic-tile.text .lbl { font-size: 13px; font-weight: 600; line-height: 1.35; color: rgba(255,255,255,0.85); }
.mosaic-tile .badge {
  position: absolute;
  top: 12px; left: 12px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(4px);
  z-index: 2;
}

/* Responsive break for feature-card-photo testimonial */
@media (max-width: 880px) {
  .feature-card-photo { grid-template-columns: 1fr !important; }
  .feature-card-photo > div:first-child { min-height: 300px; }
}

/* ============================================================
   PAGE HEADER — small hero for inner pages
   ============================================================ */
.page-header {
  position: relative;
  background: var(--rv-gradient-red);
  color: #fff;
  overflow: hidden;
  padding: clamp(140px, 18vw, 200px) 0 clamp(70px, 9vw, 110px);
  isolation: isolate;
}
.page-header::after {
  content: "";
  position: absolute; inset: auto 0 0 0;
  height: 80px;
  background: linear-gradient(to bottom, transparent, rgba(0,0,0,0.18));
  pointer-events: none;
}
.page-header .ph-inner {
  position: relative; z-index: 2;
  max-width: 880px;
}
.page-header h1 {
  font-family: var(--font-corp);
  font-weight: 800;
  font-size: clamp(44px, 6.4vw, 88px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  color: #fff;
  margin: 16px 0 22px;
  text-wrap: balance;
}
.page-header .lead { color: rgba(255,255,255,0.88); max-width: 60ch; }
.page-header .scatter-ast { animation: floatAst 8s ease-in-out infinite; }

/* Active nav state */
.nav-links a.is-active {
  color: #fff;
  background: rgba(255,255,255,0.16);
}
.nav-links a.is-active::before {
  content: "*";
  color: var(--rv-red);
  margin-right: 4px;
  font-family: var(--font-accent);
  font-weight: 800;
}
.nav.is-scrolled .nav-links a.is-active {
  color: var(--rv-ink);
  background: rgba(0,0,0,0.06);
}
.nav.is-scrolled .nav-links a.is-active::before {
  color: var(--rv-red);
}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid {
  display: grid;
  grid-template-columns: 1.25fr 0.95fr;
  gap: clamp(40px, 5vw, 72px);
  align-items: flex-start;
}
@media (max-width: 980px) { .contact-grid { grid-template-columns: 1fr; } }

.contact-form {
  background: #fff;
  border-radius: var(--r-xl);
  padding: clamp(28px, 4vw, 48px);
  box-shadow: var(--shadow-3);
  position: relative;
}
.contact-form::before {
  content: "";
  position: absolute;
  top: -22px; right: -22px;
  width: 64px; height: 64px;
  background: url("assets/asterisk.svg") center/contain no-repeat;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.18));
  z-index: 2;
  animation: floatAst 6s ease-in-out infinite;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 18px;
}
.form-row.full { grid-template-columns: 1fr; }
@media (max-width: 580px) { .form-row { grid-template-columns: 1fr; } }

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.field label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--rv-fg-3);
}
.field input,
.field select,
.field textarea {
  font-family: var(--font-corp);
  font-size: 15px;
  font-weight: 500;
  color: var(--rv-ink);
  background: var(--rv-bone);
  border: 1.5px solid transparent;
  border-radius: var(--r-sm);
  padding: 14px 16px;
  outline: none;
  transition: border-color var(--ease) 180ms, background var(--ease) 180ms, box-shadow var(--ease) 180ms;
  -webkit-appearance: none;
  width: 100%;
  font-family: var(--font-corp);
}
.field input::placeholder,
.field textarea::placeholder {
  color: var(--rv-fg-4);
  font-weight: 400;
}
.field input:hover,
.field select:hover,
.field textarea:hover {
  background: var(--rv-paper);
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  background: #fff;
  border-color: var(--rv-red);
  box-shadow: 0 0 0 4px rgba(221,20,32,0.12);
}
.field textarea { min-height: 140px; resize: vertical; line-height: 1.5; }
.field select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23111' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px;
  padding-right: 44px;
}

.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 13.5px;
  color: var(--rv-fg-2);
  line-height: 1.5;
  margin: 6px 0 24px;
  cursor: pointer;
}
.form-checkbox input { display: none; }
.form-checkbox .box {
  width: 20px; height: 20px;
  border: 1.5px solid var(--rv-rule-strong);
  border-radius: 5px;
  flex-shrink: 0;
  display: grid; place-items: center;
  margin-top: 2px;
  transition: background var(--ease) 180ms, border-color var(--ease) 180ms;
}
.form-checkbox input:checked + .box {
  background: var(--rv-ink);
  border-color: var(--rv-ink);
}
.form-checkbox input:checked + .box::after {
  content: "";
  width: 6px; height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg) translate(-1px, -1px);
}
.form-checkbox a { color: var(--rv-red); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }

.form-submit {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  border-top: 1px solid var(--rv-rule);
  padding-top: 24px;
}
.form-submit .note { font-size: 12.5px; color: var(--rv-fg-3); }

/* Right-side info card */
.contact-info {
  background: var(--rv-ink);
  color: #fff;
  border-radius: var(--r-xl);
  padding: clamp(28px, 4vw, 44px);
  position: relative;
  overflow: hidden;
}
.contact-info::before {
  content: "*";
  position: absolute;
  top: -50px; right: -30px;
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: 280px;
  color: rgba(221,20,32,0.18);
  line-height: 1;
  user-select: none;
}
.contact-info .ci-eyebrow {
  color: var(--rv-red);
  margin-bottom: 18px;
}
.contact-info h3 {
  font-family: var(--font-corp);
  font-weight: 700;
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: #fff;
  margin-bottom: 24px;
  text-wrap: balance;
}
.ci-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 20px; position: relative; z-index: 2; }
.ci-item { display: flex; gap: 14px; align-items: flex-start; }
.ci-icon {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  display: grid; place-items: center;
  flex-shrink: 0;
  color: #fff;
}
.ci-icon svg { width: 18px; height: 18px; }
.ci-item .ci-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 2px;
}
.ci-item .ci-value {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  line-height: 1.3;
}
.ci-item .ci-meta {
  font-size: 12.5px;
  color: rgba(255,255,255,0.6);
  margin-top: 2px;
}

.ci-channels { display: flex; gap: 8px; margin-top: 24px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.1); position: relative; z-index: 2; }
.ci-channel {
  flex: 1;
  background: rgba(255,255,255,0.08);
  border-radius: var(--r-md);
  padding: 14px 12px;
  text-align: center;
  font-size: 12px;
  color: rgba(255,255,255,0.85);
  font-weight: 500;
  transition: background var(--ease) 200ms, transform var(--ease) 200ms;
  cursor: pointer;
  text-decoration: none;
}
.ci-channel:hover { background: rgba(255,255,255,0.14); transform: translateY(-2px); }
.ci-channel-icon { display: block; margin: 0 auto 6px; font-size: 18px; }

/* Next steps timeline */
.next-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: clamp(60px, 8vw, 96px);
}
@media (max-width: 880px) { .next-steps { grid-template-columns: 1fr; } }
.next-step {
  background: #fff;
  border-radius: var(--r-lg);
  padding: 28px;
  box-shadow: var(--shadow-1);
  position: relative;
}
.next-step .num {
  font-family: var(--font-accent);
  font-weight: 800;
  font-size: 36px;
  line-height: 1;
  color: var(--rv-red);
  margin-bottom: 14px;
  letter-spacing: -0.03em;
}
.next-step h4 { font-size: 17px; font-weight: 700; margin: 0 0 6px; color: var(--rv-ink); }
.next-step p { font-size: 14px; color: var(--rv-fg-2); line-height: 1.55; margin: 0; }

/* ============================================================
   PAGE HEADER big asterisk
   ============================================================ */
.big-ast {
  position: absolute;
  font-family: var(--font-accent);
  font-weight: 800;
  user-select: none;
  pointer-events: none;
  line-height: 1;
}

/* ============================================================
   Small helpers / utility
   ============================================================ */
.flex { display: flex; }
.gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; }
.mt-4 { margin-top: 16px; } .mt-5 { margin-top: 24px; } .mt-6 { margin-top: 32px; }
.center { text-align: center; }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: #fff;
  border: 1px solid var(--rv-rule);
  border-radius: var(--r-pill);
  font-size: 13px; font-weight: 500;
  color: var(--rv-fg-2);
}
.tag .ast { font-size: 14px; }
.tag.on-red { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.25); }
.tag.on-red .ast { color: #fff; }
.tag.dark { background: var(--rv-ink); color: #fff; border-color: var(--rv-ink); }
.tag.dark .ast { color: #fff; }

/* Scroll reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.is-in { opacity: 1; transform: none; }
