/* ═══════════════════════════════════════════════════════════
   ARI QIPAY — SISTEMA DE ESTILOS PREMIUM
   Versión: 1.0 — Refactor Senior
   Autor: Claude (Director Creativo)
   ═══════════════════════════════════════════════════════════ */

/* ─── VARIABLES ─────────────────────────────────────────── */
:root {
  --c-espresso:   #1a1209;
  --c-charcoal:   #2c2416;
  --c-stone:      #e8e0d4;
  --c-linen:      #f0ebe2;
  --c-ivory:      #f9f5ef;
  --c-olive:      #6b7a3a;
  --c-olive-soft: #a8b576;
  --c-bronze:     #8b6e3c;
  --c-border:     rgba(44,36,22,.12);

  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans:  'Jost', system-ui, sans-serif;

  --space-xs:  .5rem;
  --space-sm:  1rem;
  --space-md:  2rem;
  --space-lg:  4rem;
  --space-xl:  6rem;
  --space-2xl: 10rem;

  --max-w: 1320px;
  --gutter: clamp(1.5rem, 5vw, 4rem);

  --ease-out: cubic-bezier(0.22,1,0.36,1);
  --ease-in-out: cubic-bezier(0.4,0,0.2,1);
  --dur-med: 600ms;
  --dur-slow: 900ms;

  --header-h: 5rem;
}

/* ─── RESET & BASE ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-sans);
  font-weight: 300;
  color: var(--c-charcoal);
  background: var(--c-ivory);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { background: none; border: none; cursor: pointer; font: inherit; }
address { font-style: normal; }
em { font-style: italic; }

/* ─── TEXT SELECTION ────────────────────────────────────── */
::selection {
  background: var(--c-olive);
  color: var(--c-ivory);
}
::-moz-selection {
  background: var(--c-olive);
  color: var(--c-ivory);
}

/* ─── TIPOGRAFÍA ────────────────────────────────────────── */
.eyebrow {
  font-family: var(--font-sans);
  font-size: .65rem;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--c-charcoal);
  opacity: .7;
}
.eyebrow-bronze { color: var(--c-bronze); opacity: 1; }
.eyebrow-olive  { color: var(--c-olive-soft); opacity: 1; }

.section-title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  font-weight: 300;
  line-height: 1.06;
  color: var(--c-charcoal);
}
.section-title em { color: var(--c-olive); }

.body-text {
  font-size: 1rem;
  line-height: 1.75;
  color: color-mix(in srgb, var(--c-charcoal) 70%, transparent);
  font-weight: 300;
}

/* ─── LAYOUT ────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.grid-12 {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(2rem,4vw,4rem);
  align-items: start;
}
.col-5 { grid-column: span 5; }
.col-7 { grid-column: span 7; }
.sticky-col { position: sticky; top: calc(var(--header-h) + 1.5rem); }

.section { padding-block: clamp(5rem, 12vw, 10rem); }
.section-linen    { background: var(--c-linen); }
.section-ivory    { background: var(--c-ivory); }
.section-stone    { background: var(--c-stone); }
.section-espresso { background: var(--c-espresso); color: var(--c-ivory); }

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  margin-bottom: clamp(2.5rem, 5vw, 5rem);
}
.section-header .eyebrow { margin-bottom: 1rem; }

.section-aside {
  font-size: .875rem;
  line-height: 1.75;
  color: color-mix(in srgb, var(--c-charcoal) 60%, transparent);
  max-width: 22rem;
  text-align: right;
}

.hairline { width: 100%; height: 1px; background: var(--c-border); }
.my-4  { margin-block: 1rem; }
.my-5  { margin-block: 1.25rem; }
.my-8  { margin-block: 2rem; }
.my-10 { margin-block: 2.5rem; }
.mb-2  { margin-bottom: .5rem; }
.mb-4  { margin-bottom: 1rem; }
.mt-4  { margin-top: 1rem; }
.mt-8  { margin-top: 2rem; }

/* ─── BUTTONS ───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  padding: 1rem 2rem;
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  transition: background var(--dur-med) var(--ease-out),
              color var(--dur-med) var(--ease-out),
              border-color var(--dur-med) var(--ease-out);
}
.btn-arrow { transition: transform var(--dur-med) var(--ease-out); }
.btn:hover .btn-arrow { transform: translateX(4px); }

.btn-primary { background: var(--c-olive); color: var(--c-ivory); }
.btn-primary:hover { background: var(--c-charcoal); }

.btn-secondary {
  border: 1px solid color-mix(in srgb, var(--c-charcoal) 30%, transparent);
  color: var(--c-charcoal);
}
.btn-secondary:hover {
  background: var(--c-charcoal);
  color: var(--c-ivory);
  border-color: var(--c-charcoal);
}

/* FIX: botón formulario → verde oliva */
.btn-dark { background: var(--c-olive); color: var(--c-ivory); }
.btn-dark:hover { background: var(--c-charcoal); }

.btn-nav {
  width: 3rem; height: 3rem;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--c-charcoal) 20%, transparent);
  color: var(--c-charcoal);
  font-size: 1.1rem;
  transition: background var(--dur-med), color var(--dur-med), border-color var(--dur-med);
}
.btn-nav:hover { background: var(--c-olive); color: var(--c-ivory); border-color: var(--c-olive); }
.btn-nav-light { border-color: rgba(249,245,239,.25); color: var(--c-ivory); }
.btn-nav-light:hover { background: var(--c-olive); border-color: var(--c-olive); }

/* ─── HEADER ────────────────────────────────────────────── */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: var(--header-h);
  transition: background var(--dur-slow) var(--ease-out),
              backdrop-filter var(--dur-slow) var(--ease-out),
              box-shadow var(--dur-slow) var(--ease-out);
}
.site-header.scrolled {
  background: color-mix(in srgb, var(--c-espresso) 85%, transparent);
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  box-shadow: 0 1px 0 rgba(249,245,239,.06);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--gutter);
  gap: 2rem;
}

.brand { display: flex; flex-direction: column; line-height: 1; gap: .3rem; }
.brand-name {
  font-family: var(--font-serif);
  font-size: 1.55rem;
  font-weight: 300;
  letter-spacing: -.01em;
  color: var(--c-ivory);
}
.brand-ari   { color: var(--c-ivory);      transition: color var(--dur-med); }
.brand-qipay { color: var(--c-olive-soft); transition: color var(--dur-med); }
.brand:hover .brand-ari   { color: var(--c-olive-soft); }
.brand:hover .brand-qipay { color: var(--c-ivory); }
.brand-tagline {
  font-size: .52rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(249,245,239,.6);
  font-family: var(--font-sans);
}

.nav-primary { display: none; align-items: center; gap: 2.25rem; }
.nav-primary a {
  font-size: .78rem;
  letter-spacing: .1em;
  color: rgba(249,245,239,.82);
  position: relative;
  transition: color var(--dur-med);
}
.nav-primary a::after {
  content: '';
  position: absolute;
  bottom: -.3rem; left: 0;
  height: 1px; width: 0;
  background: var(--c-olive-soft);
  transition: width var(--dur-med) var(--ease-out);
}
.nav-primary a:hover { color: var(--c-ivory); }
.nav-primary a:hover::after { width: 100%; }

.btn-reservar {
  display: none;
  align-items: center;
  padding: .6rem 1.4rem;
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  border: 1px solid rgba(249,245,239,.5);
  color: var(--c-ivory);
  transition: background var(--dur-med), color var(--dur-med);
}
.btn-reservar:hover { background: var(--c-ivory); color: var(--c-charcoal); }

.nav-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: .5rem;
  color: var(--c-ivory);
  z-index: 101;
  position: relative;
}
.nav-toggle span {
  display: block;
  width: 1.5rem; height: 1.5px;
  background: currentColor;
  transition: transform var(--dur-med), opacity var(--dur-med), width var(--dur-med);
}
.nav-toggle span:last-child { width: 1rem; align-self: flex-end; }
.nav-toggle.open span:first-child { transform: translateY(6px) rotate(45deg); width: 1.5rem; }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:last-child  { transform: translateY(-6.5px) rotate(-45deg); width: 1.5rem; }

@media (max-width: 767px) {
  .site-header {
    background: transparent !important;
    backdrop-filter: none !important;
  }
  .site-header.scrolled {
    background: color-mix(in srgb, var(--c-espresso) 88%, transparent) !important;
    backdrop-filter: blur(16px) saturate(1.2) !important;
    -webkit-backdrop-filter: blur(16px) saturate(1.2) !important;
  }
  .brand-name {
    font-size: 1.8rem !important;
  }
  .brand-tagline {
    display: none;
  }
}

.nav-mobile {
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0;
  z-index: 98;
  background: var(--c-espresso);
  border-bottom: 1px solid rgba(249,245,239,.08);
  padding: 1.5rem var(--gutter) 2rem;
  box-shadow: 0 20px 40px -10px rgba(10,8,5,.6);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-.75rem);
  transition: opacity var(--dur-med) var(--ease-out), transform var(--dur-med) var(--ease-out);
}
.nav-mobile.open { opacity: 1; pointer-events: auto; transform: none; }
.nav-mobile nav { display: flex; flex-direction: column; align-items: flex-start; gap: 0; }
.nav-mobile a {
  font-family: var(--font-sans);
  font-size: .9rem;
  font-weight: 300;
  letter-spacing: .08em;
  color: rgba(249,245,239,.75);
  padding: .75rem 0;
  border-bottom: 1px solid rgba(249,245,239,.06);
  width: 100%;
  transition: color var(--dur-med), padding-left var(--dur-med);
}
.nav-mobile a:last-child { border-bottom: none; }
.nav-mobile a:hover { color: var(--c-olive-soft); padding-left: .5rem; }
.nav-mobile-close { display: none; }

/* ─── HERO ──────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100svh;
  background: var(--c-espresso);
  overflow: hidden;
  display: grid;
  place-items: center;
}
.hero-media { position: absolute; inset: 0; }
.hero-img {
  width: 100%; height: 115%;
  object-fit: cover;
  object-position: center;
  will-change: transform;
  animation: heroScale 12s ease-out forwards;
}
@keyframes heroScale {
  from { transform: scale(1.08); }
  to   { transform: scale(1.0); }
}
.hero-overlay-b {
  position: absolute; inset: 0;
  background: linear-gradient(to top,
    rgba(10,8,5,.78) 0%, rgba(10,8,5,.18) 45%, rgba(10,8,5,.30) 100%);
}
.hero-overlay-l {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(10,8,5,.50) 0%, transparent 55%);
}
.hero-grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: .5;
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100svh;
  padding-top: calc(var(--header-h) + clamp(3rem, 8vw, 7rem));
  padding-bottom: clamp(6rem, 10vw, 9rem);
}
.hero-content .eyebrow {
  color: rgba(249,245,239,.85);
  opacity: 1;
  margin-bottom: 1.75rem;
}
.hero-title {
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 6.5vw, 5.8rem);
  font-weight: 300;
  line-height: 1.02;
  letter-spacing: -.01em;
  color: var(--c-ivory);
  max-width: 18ch;
}
.hero-title em { color: var(--c-olive-soft); }

/* FIX: hero-bottom alineado izquierda, columna, debajo del texto */
.hero-bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2rem;
  margin-top: 3.5rem;
}
.hero-desc {
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(249,245,239,.72);
  max-width: 36ch;
}

.hero-scroll {
  position: absolute;
  bottom: 1.75rem; left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
  color: rgba(249,245,239,.55);
}
.scroll-label { font-size: .55rem; letter-spacing: .3em; text-transform: uppercase; }
.scroll-line {
  width: 1px; height: 3rem;
  background: linear-gradient(to bottom, rgba(249,245,239,.55), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity: .55; transform: scaleY(1); }
  50%      { opacity: 1;   transform: scaleY(1.1); }
}
.hero-ornament {
  position: absolute;
  bottom: 6rem; left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: 7rem;
  color: var(--c-ivory);
}

/* ─── REVEAL ANIMATION ──────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(2rem);
  filter: blur(4px);
  transition:
    opacity 1s var(--ease-out) var(--delay, 0s),
    transform 1s var(--ease-out) var(--delay, 0s),
    filter 1s ease var(--delay, 0s);
}
.reveal.visible { opacity: 1; transform: none; filter: none; }

/* ─── EXPERIENCIA ───────────────────────────────────────── */
.col-offset { padding-left: clamp(2rem, 4vw, 4rem); }
.img-portrait { aspect-ratio: 3/4; overflow: hidden; }
.img-portrait img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 2s var(--ease-out);
}
.img-portrait:hover img { transform: scale(1.04); }
.col-7 .eyebrow { margin-bottom: 1.5rem; }

.atributos-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem 3.5rem;
  margin-top: 1.5rem;
}
.atributo { display: flex; gap: 1.5rem; }
.atributo-num {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-style: italic;
  color: var(--c-olive);
  line-height: 1;
  padding-top: .1rem;
  flex-shrink: 0;
}
.atributo h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--c-charcoal);
  margin-bottom: .5rem;
}
.atributo p {
  font-size: .875rem;
  color: color-mix(in srgb, var(--c-charcoal) 60%, transparent);
  line-height: 1.65;
}

.quote-strip {
  display: flex;
  align-items: center;
  gap: 2rem;
  margin-top: 4rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--c-border);
}
.quote-strip img { width: 5.5rem; height: 7.5rem; object-fit: cover; flex-shrink: 0; }
.quote-strip blockquote {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-style: italic;
  color: rgba(44,36,22,.8);
  line-height: 1.55;
}
.quote-strip cite {
  display: block;
  margin-top: .7rem;
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--c-bronze);
}

/* ─── DESTACADOS ────────────────────────────────────────── */
.productos-grid {
  display: grid;
  grid-template-columns: 7fr 5fr;
  grid-template-rows: auto auto;
  gap: .75rem;
}
.producto-lg {
  grid-column: 1; grid-row: 1 / 3;
  position: relative; overflow: hidden; cursor: pointer;
}
.producto-lg .producto-img { width: 100%; height: 100%; min-height: 560px; }
.producto-top-right { grid-column: 2; grid-row: 1; position: relative; overflow: hidden; cursor: pointer; }
.producto-top-right .producto-img { aspect-ratio: 4/3; }
.producto-mid-right { grid-column: 2; grid-row: 2; position: relative; overflow: hidden; cursor: pointer; }
.producto-mid-right .producto-img { aspect-ratio: 4/3; }
.productos-bottom {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
}
.producto-bottom { position: relative; overflow: hidden; cursor: pointer; }
.producto-bottom .producto-img { aspect-ratio: 4/3; }
.producto-img { overflow: hidden; width: 100%; height: 100%; }
.producto-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.8s var(--ease-out);
}
.producto-lg:hover .producto-img img,
.producto-top-right:hover .producto-img img,
.producto-mid-right:hover .producto-img img,
.producto-bottom:hover .producto-img img { transform: scale(1.07); }

.producto-lg figcaption,
.producto-top-right figcaption,
.producto-mid-right figcaption,
.producto-bottom figcaption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 3rem 1.75rem 1.25rem;
  color: var(--c-ivory);
  background: linear-gradient(to top, rgba(10,8,5,.92) 0%, rgba(10,8,5,.50) 55%, transparent 100%);
}
.producto-lg figcaption h3,
.producto-top-right figcaption h3,
.producto-mid-right figcaption h3,
.producto-bottom figcaption h3 {
  font-family: var(--font-serif);
  font-size: clamp(1.15rem, 2.2vw, 1.65rem);
  font-weight: 300;
  margin-block: .2rem .25rem;
}
.producto-lg figcaption p,
.producto-top-right figcaption p,
.producto-mid-right figcaption p,
.producto-bottom figcaption p { font-size: .78rem; color: rgba(249,245,239,.7); }

/* ─── MENÚ SLIDER ───────────────────────────────────────── */
.menu-slider { overflow: hidden; }
.menu-track {
  display: flex;
  transition: transform var(--dur-slow) var(--ease-out);
  will-change: transform;
}
.menu-slide {
  width: 100%; flex-shrink: 0;
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(1.5rem, 3vw, 3.5rem);
  align-items: stretch;
}
.menu-label {
  display: flex; flex-direction: column;
  background: var(--c-ivory);
  padding: clamp(2rem, 4vw, 3.5rem);
  box-shadow: 0 30px 60px -20px rgba(40,30,20,.2);
}
.menu-brand {
  display: flex; flex-direction: column;
  line-height: 1;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--c-border);
}
.menu-label h3 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 300; line-height: 1.1;
  color: var(--c-charcoal);
  margin-bottom: 1rem;
}
.menu-label p {
  font-size: .875rem;
  color: color-mix(in srgb, var(--c-charcoal) 60%, transparent);
  line-height: 1.6; flex: 1;
}
.menu-page-num {
  font-size: .65rem; letter-spacing: .18em; text-transform: uppercase;
  color: color-mix(in srgb, var(--c-charcoal) 35%, transparent);
  margin-top: 2.5rem;
}
.menu-items {
  list-style: none;
  background: var(--c-linen);
  padding: clamp(2rem, 4vw, 3.5rem);
  box-shadow: 0 30px 60px -20px rgba(40,30,20,.2);
}
.menu-items li {
  padding-block: 1.2rem;
  border-bottom: 1px solid color-mix(in srgb, var(--c-charcoal) 10%, transparent);
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  align-items: baseline;
  gap: 0 .75rem;
}
.menu-items li:last-child { border-bottom: none; }
.item-name { font-family: var(--font-serif); font-size: clamp(1.1rem, 2vw, 1.4rem); font-weight: 300; color: var(--c-charcoal); }
.dots { flex: 1; border-bottom: 1px dotted color-mix(in srgb, var(--c-charcoal) 22%, transparent); transform: translateY(-.25rem); }
.item-price { font-family: var(--font-serif); font-size: 1.1rem; color: var(--c-olive); white-space: nowrap; }
.menu-items li p { grid-column: 1/-1; font-size: .8rem; color: color-mix(in srgb, var(--c-charcoal) 50%, transparent); margin-top: .2rem; }

.menu-controls {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-top: 2.5rem;
  flex-wrap: wrap; gap: 1rem;
}
.menu-dots { display: flex; gap: .5rem; align-items: center; }
.menu-dot {
  height: 1px;
  background: color-mix(in srgb, var(--c-charcoal) 22%, transparent);
  transition: width var(--dur-med) var(--ease-out), background var(--dur-med);
  cursor: pointer; width: 1.5rem;
}
.menu-dot.active { width: 3rem; background: var(--c-olive); }
.menu-nav { display: flex; align-items: center; gap: 1rem; }
.menu-counter { font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: color-mix(in srgb, var(--c-charcoal) 45%, transparent); }
.menu-download { margin-top: 2.5rem; display: flex; justify-content: center; }

/* ─── GALERÍA ───────────────────────────────────────────── */
.galeria-masonry { columns: 2; column-gap: 1rem; }
.galeria-item {
  display: block; width: 100%;
  position: relative; overflow: hidden;
  break-inside: avoid; margin-bottom: 1rem; cursor: pointer;
}
.galeria-item img { width: 100%; display: block; object-fit: cover; transition: transform 2s var(--ease-out); }
.galeria-ratio-tall  { aspect-ratio: 3/4; }
.galeria-ratio-wide  { aspect-ratio: 4/3; }
.galeria-item:hover img { transform: scale(1.06); }
.galeria-label {
  position: absolute; bottom: 1rem; left: 1rem;
  font-size: .65rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--c-ivory); opacity: 0;
  transform: translateY(.4rem);
  transition: opacity var(--dur-med), transform var(--dur-med);
}
.galeria-item::before {
  content: ''; position: absolute; inset: 0;
  background: rgba(26,18,9,.32); opacity: 0;
  transition: opacity var(--dur-med); z-index: 1;
}
.galeria-item:hover::before { opacity: 1; }
.galeria-item:hover .galeria-label { opacity: 1; transform: none; z-index: 2; }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(26,18,9,.96);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 1.5rem;
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-med);
}
.lightbox.open { opacity: 1; pointer-events: auto; }
.lightbox-img { max-width: 82vw; max-height: 78vh; object-fit: contain; display: block; }
.lightbox-caption { font-size: .65rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(249,245,239,.45); }
.lightbox-close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-family: var(--font-serif); font-size: 2.5rem;
  color: var(--c-ivory); line-height: 1;
  transition: color var(--dur-med); z-index: 2;
}
.lightbox-close:hover { color: var(--c-olive-soft); }
.lightbox-prev, .lightbox-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 3rem; height: 3rem; border-radius: 50%;
  border: 1px solid rgba(249,245,239,.2);
  color: var(--c-ivory); font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-med), border-color var(--dur-med); z-index: 2;
}
.lightbox-prev { left: 1.5rem; }
.lightbox-next { right: 1.5rem; }
.lightbox-prev:hover, .lightbox-next:hover { background: var(--c-olive); border-color: var(--c-olive); }

/* ─── TESTIMONIOS ───────────────────────────────────────── */
/* ─── TESTIMONIOS BG ────────────────────────────────────── */
#testimonios { position: relative; overflow: hidden; }
.testimonios-bg {
  position: absolute;
  inset: -16% 0;        /* margen vertical = campo de movimiento */
  z-index: 0;
}
.testimonios-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;  /* ← baja el volcán, sube el cielo */
  will-change: transform;
  display: block;
}
.testimonios-bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg,
    rgba(10,8,5,.82) 0%,
    rgba(26,18,9,.68) 60%,
    rgba(10,8,5,.78) 100%);
}
#testimonios .container { position: relative; z-index: 1; }

/* FIX: eyebrow testimonios con más separación de las comillas */
#testimonios .eyebrow { margin-bottom: 3.5rem; }

.testimonios-slider { position: relative; min-height: 20rem; }
.testimonio {
  position: absolute; inset: 0;
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-slow) var(--ease-out);
}
.testimonio.active { opacity: 1; pointer-events: auto; position: relative; }
.testimonio:not(.active) { position: absolute; top: 0; left: 0; right: 0; }

.testimonio-mark {
  position: absolute;
  top: -2.5rem; left: -.5rem;
  font-family: var(--font-serif);
  font-size: clamp(5rem, 10vw, 9rem);
  line-height: 1;
  color: rgba(107,122,58,.2);
  pointer-events: none; user-select: none;
}
.testimonio blockquote {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem, 2.8vw, 2.4rem);
  font-weight: 300; font-style: italic; line-height: 1.35;
  color: rgba(249,245,239,.95);
  max-width: 50ch;
  position: relative; z-index: 1; padding-top: 1rem;
}
.testimonio footer {
  display: flex; justify-content: space-between;
  align-items: flex-end; flex-wrap: wrap;
  gap: 1.5rem; margin-top: 2.5rem;
}
.testimonio-autor { font-family: var(--font-serif); font-size: 1.1rem; color: var(--c-ivory); margin-bottom: .4rem; }
.testimonio-nav { display: flex; align-items: center; gap: 1rem; }
.testimonio-counter { font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(249,245,239,.45); }

/* ─── UBICACIÓN ─────────────────────────────────────────── */
.horarios { display: flex; flex-direction: column; gap: .5rem; }
.horarios div {
  display: flex; justify-content: space-between;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--c-border);
  font-size: .9rem;
}
.horarios dt { font-family: var(--font-serif); color: var(--c-charcoal); }
.horarios dd { color: color-mix(in srgb, var(--c-charcoal) 55%, transparent); }

.contacto-datos {
  margin-top: 2rem; display: flex; flex-direction: column;
  gap: .5rem; font-size: .875rem;
  color: color-mix(in srgb, var(--c-charcoal) 65%, transparent);
}
.contacto-datos .eyebrow { margin-right: .75rem; }

.redes-texto {
  margin-top: 1.5rem; font-size: .7rem;
  letter-spacing: .15em; text-transform: uppercase;
  display: flex; gap: .75rem; align-items: center;
}
.redes-sep { opacity: .35; }
.redes-texto a { transition: color var(--dur-med); }
.redes-texto a:hover { color: var(--c-olive); }

/* Formulario */
.formulario-card {
  background: var(--c-linen);
  padding: clamp(2rem, 5vw, 4rem);
  box-shadow: 0 30px 60px -20px rgba(40,30,20,.2);
}
.formulario-title {
  font-family: var(--font-serif);
  font-size: clamp(1.8rem, 3.5vw, 2.75rem);
  font-weight: 300; line-height: 1.1;
  color: var(--c-charcoal);
  margin-block: .5rem 2rem;
}
.formulario-title em { color: var(--c-olive); }
.formulario { display: flex; flex-direction: column; gap: 1.5rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-full { grid-column: 1/-1; }
.form-group { display: flex; flex-direction: column; gap: .5rem; }
.form-group input,
.form-group textarea {
  width: 100%; background: transparent;
  border: none;
  border-bottom: 1px solid color-mix(in srgb, var(--c-charcoal) 22%, transparent);
  padding: .6rem 0;
  font-family: var(--font-sans); font-size: .9rem; font-weight: 300;
  color: var(--c-charcoal); outline: none;
  transition: border-color var(--dur-med); resize: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: color-mix(in srgb, var(--c-charcoal) 35%, transparent); }
.form-group input:focus,
.form-group textarea:focus { border-color: var(--c-olive); }

/* FIX: date picker — fondo verde oliva oscuro */
.form-group input[type="date"] {
  color-scheme: light;
}
.form-group input[type="date"]::-webkit-calendar-picker-indicator {
  filter: opacity(0.5);
  cursor: pointer;
}
.form-group input[type="date"]::-webkit-datetime-edit { color: var(--c-charcoal); }

.form-submit { align-self: flex-start; margin-top: .5rem; }

/* Mapa */
.mapa-wrapper { margin-top: 5rem; }
.mapa-frame { aspect-ratio: 21/8; overflow: hidden; box-shadow: 0 30px 60px -20px rgba(40,30,20,.25); }
.mapa-frame iframe { width: 100%; height: 100%; border: none; filter: grayscale(40%) contrast(.95); }

/* ─── FOOTER ────────────────────────────────────────────── */
.site-footer { background: var(--c-espresso); color: rgba(249,245,239,.7); position: relative; }
.footer-inner {
  display: grid;
  grid-template-columns: 5fr 3fr 4fr;
  gap: 3rem;
  padding-top: 5rem; padding-bottom: 4rem;
  border-bottom: 1px solid rgba(249,245,239,.08);
}
.footer-logo { font-size: 1.75rem; margin-bottom: .75rem; }
.footer-desc { margin-top: 1.5rem; font-size: .875rem; line-height: 1.7; max-width: 22rem; color: rgba(249,245,239,.55); }
.footer-nav ul { list-style: none; }
.footer-nav li + li { margin-top: .6rem; }
.footer-nav a { font-size: .875rem; color: rgba(249,245,239,.6); transition: color var(--dur-med); }
.footer-nav a:hover { color: var(--c-olive-soft); }
.footer-contacto address { font-size: .875rem; line-height: 1.9; color: rgba(249,245,239,.6); }
.footer-redes { display: flex; gap: 1.25rem; margin-top: 1.25rem; font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; }
.footer-redes a { transition: color var(--dur-med); }
.footer-redes a:hover { color: var(--c-olive-soft); }

.footer-base {
  padding-block: 2rem;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  font-size: .75rem;
  color: rgba(249,245,239,.35);
  gap: .5rem;
}
.footer-base p:first-child { justify-self: start; }
.footer-credit { justify-self: center; text-align: center; }
.footer-credit a { color: rgba(249,245,239,.35); transition: color var(--dur-med); }
.footer-credit a:hover { color: var(--c-olive-soft); }
.footer-made { justify-self: end; text-align: right; }

.footer-ornament {
  position: absolute; top: 0; left: 50%;
  transform: translateX(-50%);
  width: 12rem; color: var(--c-ivory); pointer-events: none;
}

/* ─── FLOATING ACTIONS ──────────────────────────────────── */
.floating-actions {
  position: fixed; bottom: 1.5rem; right: 1.5rem;
  z-index: 50; display: flex; flex-direction: column;
  align-items: flex-end; gap: .75rem;
}
.fab-top {
  width: 2.75rem; height: 2.75rem; border-radius: 50%;
  background: rgba(249,245,239,.93); backdrop-filter: blur(8px);
  border: 1px solid rgba(44,36,22,.12);
  color: var(--c-charcoal); font-size: .9rem;
  transition: background var(--dur-med), color var(--dur-med), opacity var(--dur-med), transform var(--dur-med);
  opacity: 0; transform: translateY(.5rem); pointer-events: none;
}
.fab-top.visible { opacity: 1; transform: none; pointer-events: auto; }
.fab-top:hover { background: var(--c-olive); color: var(--c-ivory); }
.fab-whatsapp {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: 0 1.25rem; height: 3rem;
  background: var(--c-olive); color: var(--c-ivory);
  font-size: .65rem; letter-spacing: .18em; text-transform: uppercase;
  box-shadow: 0 14px 35px -10px rgba(50,60,30,.55);
  transition: background var(--dur-med);
}
.fab-whatsapp svg { width: 1.25rem; height: 1.25rem; }
.fab-whatsapp:hover { background: var(--c-charcoal); }

/* ─── RESPONSIVE ────────────────────────────────────────── */
@media (min-width: 768px) {
  .nav-primary { display: flex; }
  .btn-reservar { display: inline-flex; }
  .nav-toggle { display: none; }
  .galeria-masonry { columns: 4; }
}

@media (max-width: 1023px) {
  .grid-12 { grid-template-columns: 1fr; }
  .col-5, .col-7 { grid-column: span 1; }
  .sticky-col { position: static; }
  .col-offset { padding-left: 0; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1/-1; }
  .menu-slide { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .section-header { flex-direction: column; align-items: flex-start; }
  .section-aside { text-align: left; }
  .atributos-grid { grid-template-columns: 1fr; }

  .productos-grid { grid-template-columns: 1fr; }
  .producto-lg { grid-column: 1; grid-row: auto; }
  .producto-lg .producto-img { min-height: 280px; }
  .producto-top-right { grid-column: 1; }
  .producto-mid-right { grid-column: 1; }
  .productos-bottom { grid-template-columns: 1fr; }

  /* FIX: galería mobile — 1 sola columna */
  .galeria-masonry { columns: 1; }

  .form-row { grid-template-columns: 1fr; }

  /* FIX: footer mobile — centrado */
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 2rem;
    text-align: center;
  }
  .footer-brand { grid-column: auto; }
  .footer-redes { justify-content: center; }
  .footer-nav ul { display: flex; flex-direction: column; align-items: center; }
  .footer-base {
    grid-template-columns: 1fr;
    text-align: center;
    gap: .75rem;
  }
  .footer-base p:first-child { justify-self: center; }
  .footer-credit { justify-self: center; }
  .footer-made { justify-self: center; text-align: center; }

  .mapa-frame { aspect-ratio: 4/3; }
  .testimonio blockquote { font-size: 1.35rem; }
  .fab-whatsapp span { display: none; }
  .fab-whatsapp { padding: 0; width: 3rem; justify-content: center; }
}

/* ─── ACCESIBILIDAD ─────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; filter: none; }
}

/* ─── PIKADAY OVERRIDE ──────────────────────────────────── */

.pika-single,
.pika-single * {
  box-sizing: border-box;
}

.pika-single {
  font-family: var(--font-sans) !important;
  background: var(--c-olive) !important;
  border: none !important;
  border-radius: 4px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.15) !important;
  z-index: 9999 !important;
  color: #fff !important;
}

/* Header — mes y año */
.pika-single .pika-title {
  background: var(--c-olive) !important;
}

.pika-single .pika-label {
  background: var(--c-olive) !important;
  color: #fff !important;
  font-size: .85rem !important;
}

/* Flechas */
.pika-single .pika-prev,
.pika-single .pika-next {
  filter: brightness(0) invert(1) !important;
  opacity: 1 !important;
}

/* Días de la semana */
.pika-single .pika-table th,
.pika-single .pika-table th abbr {
  color: #fff !important;
  text-decoration: none !important;
  font-size: .65rem !important;
  letter-spacing: .08em !important;
}

/* Números de días */
.pika-single .pika-button {
  background: transparent !important;
  color: #fff !important;
  border-radius: 2px !important;
  text-align: center !important;
}

/* Días pasados */
.pika-single td.is-disabled,
.pika-single td.is-disabled .pika-button {
  opacity: .80 !important;
  color: #fff !important;
}

/* Hover */
.pika-single .pika-button:hover,
.pika-single .pika-button:focus {
  background: var(--c-ivory) !important;
  color: var(--c-olive) !important;
}

/* Día seleccionado */
.pika-single td.is-selected .pika-button,
.pika-single td.is-selected .pika-button:hover,
.pika-single td.is-selected .pika-button:focus {
  background: var(--c-ivory) !important;
  color: var(--c-olive) !important;
  box-shadow: none !important;
}

/* Día actual */
.pika-single td.is-today .pika-button {
  color: #fff !important;
  text-decoration: underline !important;
}

/* Día actual + hover */
.pika-single td.is-today .pika-button:hover,
.pika-single td.is-today .pika-button:focus {
  background: var(--c-ivory) !important;
  color: var(--c-olive) !important;
  text-decoration: none !important;
}