/* =================================================================
   Visual Nails — components.css
   Header, botones, cards, pasos, testimonios, FAQ, footer,
   WhatsApp flotante, formularios, precios, galería grid.
   ================================================================= */

/* ---------- Botones ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .92rem 1.6rem;
  min-height: 48px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: .98rem;
  letter-spacing: .01em;
  line-height: 1;
  text-align: center;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), background-color .2s var(--ease), color .2s var(--ease);
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--cta);
  color: var(--cta-ink);
  box-shadow: 0 8px 22px rgba(192, 67, 111, 0.32);
}
.btn--primary:hover { background: var(--cta-hover); color: #fff; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(192, 67, 111, 0.42); }

.btn--ghost {
  background: rgba(255, 255, 255, 0.75);
  color: var(--ink);
  border: 1.5px solid var(--line);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}
.btn--ghost:hover { background: #fff; border-color: var(--lavender); transform: translateY(-2px); }

.btn--whatsapp { background: #25D366; color: #093d20; box-shadow: 0 8px 22px rgba(37, 211, 102, 0.32); }
.btn--whatsapp:hover { background: #1ebe5a; color: #093d20; transform: translateY(-2px); }

.btn--ig {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 22%, #dc2743 50%, #cc2366 74%, #bc1888 100%);
  color: #fff; box-shadow: 0 8px 22px rgba(220, 39, 67, 0.32);
}
.btn--ig:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(220, 39, 67, 0.42); }

.btn--light { background: var(--cream); color: var(--ink); }
.btn--light:hover { background: #fff; }

.btn--block { width: 100%; }
.btn--lg { padding: 1.1rem 2.2rem; font-size: 1.05rem; min-height: 56px; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  height: var(--header-h);
  display: flex;
  align-items: center;
  transition: background-color .35s var(--ease), box-shadow .35s var(--ease), backdrop-filter .35s var(--ease);
}
.site-header__inner {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
/* Estado por defecto (sobre hero claro) y estado "scrolled" */
.site-header.is-scrolled {
  background: rgba(251, 246, 239, 0.86);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--line), var(--shadow-sm);
}

.brand { display: inline-flex; align-items: center; }
.brand__mark {
  height: 48px; width: auto;
  display: block;
  background: none; /* logo transparente: sin caja de fondo */
}

.nav { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2rem); }
.nav__list { display: flex; align-items: center; gap: clamp(1rem, 2vw, 1.9rem); }
.nav__link {
  font-weight: 500;
  font-size: .95rem;
  color: var(--ink);
  position: relative;
  padding: .35rem 0;
}
.nav__link::after {
  content: "";
  position: absolute; left: 0; bottom: -2px;
  width: 0; height: 2px; border-radius: 2px;
  background: var(--cta);
  transition: width .25s var(--ease);
}
.nav__link:hover { color: var(--cta); }
.nav__link:hover::after, .nav__link.is-active::after { width: 100%; }
.nav__link.is-active { color: var(--cta); }

.nav__cta { margin-left: .4rem; }

/* Botón hamburguesa */
.nav-toggle {
  display: none;
  width: 46px; height: 46px;
  border-radius: var(--radius-sm);
  align-items: center; justify-content: center;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--line);
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content: ""; display: block; width: 22px; height: 2px; border-radius: 2px;
  background: var(--ink); transition: transform .3s var(--ease), opacity .2s var(--ease);
  position: relative;
}
.nav-toggle span::before { position: absolute; top: -7px; }
.nav-toggle span::after  { position: absolute; top: 7px; }
.nav-toggle[aria-expanded="true"] span { background: transparent; }
.nav-toggle[aria-expanded="true"] span::before { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after  { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 920px) {
  .nav-toggle { display: inline-flex; }
  .nav {
    position: fixed;
    inset: var(--header-h) 0 auto 0;
    flex-direction: column;
    align-items: stretch;
    gap: .25rem;
    background: rgba(251, 246, 239, 0.98);
    -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
    padding: 1rem var(--gutter) 1.6rem;
    box-shadow: var(--shadow-md);
    transform: translateY(-12px);
    opacity: 0; visibility: hidden;
    transition: opacity .3s var(--ease), transform .3s var(--ease), visibility .3s;
  }
  .nav.is-open { opacity: 1; visibility: visible; transform: none; }
  .nav__list { flex-direction: column; align-items: stretch; gap: 0; }
  .nav__link { padding: .9rem .4rem; border-bottom: 1px solid var(--line); font-size: 1.05rem; }
  .nav__link::after { display: none; }
  .nav__cta { margin: .9rem 0 0; }
  .nav__cta .btn { width: 100%; }
}

/* ---------- Cards genéricas ---------- */
.card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }

/* ---------- "Cómo funciona" — pasos ---------- */
.steps { counter-reset: step; }
.step {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 2rem 1.4rem 1.6rem;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.step__num {
  counter-increment: step;
  position: absolute; top: -18px; left: 50%; transform: translateX(-50%);
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--cta); color: #fff; font-weight: 700; font-size: .9rem;
  box-shadow: 0 4px 12px rgba(192,67,111,.35);
}
.step__num::before { content: counter(step); }
.step__icon {
  width: 64px; height: 64px; margin: .4rem auto 1rem;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(150deg, var(--blush-soft), var(--lavender-soft));
  color: var(--cta);
}
.step__icon svg { width: 30px; height: 30px; }
.step h3 { font-size: 1.18rem; margin-bottom: .4rem; }
.step p { font-size: .92rem; }

/* ---------- Servicios destacados ---------- */
.service-card { display: flex; flex-direction: column; }
.service-card__media { aspect-ratio: 4 / 3; overflow: hidden; }
.service-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.service-card:hover .service-card__media img { transform: scale(1.06); }
.service-card__body { padding: 1.3rem 1.4rem 1.5rem; display: flex; flex-direction: column; flex: 1; }
.service-card__body h3 { font-size: 1.25rem; margin-bottom: .4rem; }
.service-card__meta {
  margin-top: auto; padding-top: 1rem;
  display: flex; align-items: baseline; justify-content: space-between; gap: .6rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
}
.service-card__price { font-family: var(--font-serif); font-weight: 700; font-size: 1.3rem; color: var(--ink); white-space: nowrap; }
.service-card__dur { font-size: .82rem; color: var(--ink-faint); white-space: nowrap; flex-shrink: 0; }
.tag {
  display: inline-block; font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--lavender-deep); background: var(--lavender-soft);
  padding: .25rem .6rem; border-radius: var(--radius-pill); margin-bottom: .8rem; align-self: flex-start;
}

/* ---------- Prueba social ---------- */
.testimonial {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.8rem 1.6rem;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 1rem;
}
.testimonial__stars { color: var(--gold); letter-spacing: 2px; font-size: 1rem; }
.testimonial__quote { font-family: var(--font-serif); font-size: 1.08rem; font-style: italic; color: var(--ink); line-height: 1.5; }
.testimonial__author { display: flex; align-items: center; gap: .7rem; margin-top: auto; }
.testimonial__avatar {
  width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center; font-weight: 700; color: #fff;
  background: linear-gradient(140deg, var(--blush-deep), var(--lavender-deep));
}
.testimonial__name { display: block; font-weight: 600; color: var(--ink); font-size: .95rem; line-height: 1.2; }
.testimonial__role { display: block; }
.testimonial__role { font-size: .8rem; color: var(--ink-faint); }

/* Marcas premium */
.brand-strip {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: clamp(1.5rem, 5vw, 3.5rem);
}
.brand-strip__item {
  font-family: var(--font-serif);
  font-weight: 700; font-size: clamp(1.1rem, 2.4vw, 1.6rem);
  letter-spacing: .04em; color: var(--ink-soft);
  opacity: .75; transition: opacity .3s var(--ease), color .3s var(--ease);
}
.brand-strip__item span { font-family: var(--font-sans); font-weight: 500; font-size: .68em; display: block; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }
.brand-strip__item:hover { opacity: 1; color: var(--cta); }

/* ---------- Muro de reseñas (marquee auto-scroll) ---------- */
.stars-gold { color: var(--gold); letter-spacing: 2px; }
.reviews {
  position: relative;
  overflow: hidden;
  /* difumina los bordes para que entren/salgan suavemente */
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.reviews__row {
  display: flex;
  width: max-content;
  animation: reviews-scroll var(--rev-dur, 52s) linear infinite;
  will-change: transform;
}
.reviews__row--reverse { animation-direction: reverse; --rev-dur: 60s; }
.reviews__row + .reviews__row { margin-top: 1.3rem; }
.reviews:hover .reviews__row,
.reviews:focus-within .reviews__row { animation-play-state: paused; }
@keyframes reviews-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
/* Tarjeta dentro del marquee (reutiliza estilos .testimonial) */
.reviews__row .testimonial {
  flex: 0 0 auto;
  width: clamp(270px, 78vw, 350px);
  margin-right: 1.3rem;          /* el margen permite el bucle perfecto al -50% */
  white-space: normal;
  min-height: 100%;
}
.reviews .testimonial__quote { font-size: 1rem; }

@media (prefers-reduced-motion: reduce) {
  .reviews { overflow: visible; -webkit-mask-image: none; mask-image: none; }
  .reviews__row {
    animation: none; width: auto;
    flex-wrap: wrap; justify-content: center; gap: 1.2rem;
  }
  .reviews__row .testimonial { margin-right: 0; }
  .reviews__row + .reviews__row { margin-top: 1.2rem; }
  .testimonial[aria-hidden="true"] { display: none; }  /* ocultar duplicados del bucle */
}

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q {
  width: 100%; text-align: left;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.3rem .2rem;
  font-family: var(--font-serif); font-size: 1.12rem; font-weight: 600; color: var(--ink);
}
.faq__q:hover { color: var(--cta); }
.faq__icon { flex-shrink: 0; width: 24px; height: 24px; position: relative; }
.faq__icon::before, .faq__icon::after {
  content: ""; position: absolute; top: 50%; left: 50%; background: var(--cta);
  transform: translate(-50%, -50%); border-radius: 2px;
}
.faq__icon::before { width: 14px; height: 2px; }
.faq__icon::after  { width: 2px; height: 14px; transition: transform .3s var(--ease); }
.faq__q[aria-expanded="true"] .faq__icon::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }
.faq__a { overflow: hidden; max-height: 0; transition: max-height .35s var(--ease); }
.faq__a-inner { padding: 0 .2rem 1.3rem; color: var(--ink-soft); }

/* ---------- Banda CTA ---------- */
.cta-band {
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--blush) 0%, var(--lavender) 100%);
  padding: clamp(2.2rem, 5vw, 3.6rem);
  text-align: center;
  color: var(--ink);
  box-shadow: var(--shadow-md);
  position: relative; overflow: hidden;
}
.cta-band::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(60% 80% at 80% 0%, rgba(255,255,255,.5), transparent 60%);
  pointer-events: none;
}
.cta-band h2 { position: relative; }
.cta-band p { position: relative; color: rgba(46,39,48,.78); margin: .8rem auto 1.6rem; max-width: 560px; }
.cta-band__actions { position: relative; display: flex; flex-wrap: wrap; gap: .9rem; justify-content: center; }

/* ---------- Formularios ---------- */
.form { display: grid; gap: 1.1rem; }
.form__row { display: grid; gap: .4rem; }
.form__label { font-weight: 600; font-size: .9rem; color: var(--ink); }
.form__control {
  width: 100%;
  padding: .9rem 1rem; min-height: 50px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--ink); font-size: 1rem;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.form__control:focus { outline: none; border-color: var(--lavender-deep); box-shadow: 0 0 0 3px rgba(139,127,208,.18); }
textarea.form__control { min-height: 110px; resize: vertical; }
.form__hint { font-size: .82rem; color: var(--ink-faint); }

/* ---------- Precios (servicios) ---------- */
.price-cat { margin-bottom: clamp(2rem, 4vw, 3rem); }
.price-cat__head { display: flex; align-items: center; gap: .9rem; margin-bottom: 1.2rem; }
.price-cat__head h3 { font-size: 1.5rem; }
.price-cat__head .tag { margin: 0; }
.price-list { display: grid; gap: .2rem; }
.price-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .4rem 1.4rem;
  align-items: baseline;
  padding: 1.1rem .4rem;
  border-bottom: 1px dashed var(--line);
}
.price-row__main { display: flex; flex-direction: column; gap: .25rem; }
.price-row__name { font-weight: 600; font-size: 1.06rem; color: var(--ink); }
.price-row__desc { font-size: .9rem; color: var(--ink-soft); }
.price-row__dur { font-size: .82rem; color: var(--lavender-deep); font-weight: 600; }
.price-row__price { font-family: var(--font-serif); font-weight: 700; font-size: 1.3rem; color: var(--cta); white-space: nowrap; }

/* ---------- Galería grid ---------- */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(.6rem, 1.5vw, 1rem);
}
.gallery-grid__item {
  position: relative; overflow: hidden; border-radius: var(--radius-sm);
  aspect-ratio: 1; background: var(--surface-2);
}
.gallery-grid__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.gallery-grid__item:hover img { transform: scale(1.08); }
.gallery-grid__item--tall { grid-row: span 2; aspect-ratio: 1 / 2; }
@media (max-width: 900px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }

/* Antes / Después */
.ba { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.ba figure { position: relative; margin: 0; aspect-ratio: 3 / 4; }
.ba img { width: 100%; height: 100%; object-fit: cover; }
.ba figcaption {
  position: absolute; left: .7rem; top: .7rem;
  background: rgba(46,39,48,.72); color: #fff; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  padding: .3rem .7rem; border-radius: var(--radius-pill);
}

/* ---------- Tarjetas de info (bioseguridad / contacto) ---------- */
.info-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.6rem 1.5rem; box-shadow: var(--shadow-sm); height: 100%;
}
.info-card__icon {
  width: 52px; height: 52px; border-radius: 14px; margin-bottom: 1rem;
  display: grid; place-items: center; color: #fff;
  background: linear-gradient(140deg, var(--blush-deep), var(--lavender-deep));
}
.info-card__icon svg { width: 26px; height: 26px; }
.info-card h3 { font-size: 1.2rem; margin-bottom: .4rem; }
.info-card p { font-size: .94rem; }

.contact-list { display: grid; gap: 1.1rem; }
.contact-list li { display: flex; gap: .9rem; align-items: flex-start; }
.contact-list .ci {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 12px;
  display: grid; place-items: center; color: var(--cta); background: var(--blush-soft);
}
.contact-list .ci svg { width: 20px; height: 20px; }
.contact-list b { display: block; color: var(--ink); }
.contact-list a:hover { color: var(--cta); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--plum-deep);
  color: rgba(251,246,239,.74);
  padding-block: clamp(3rem, 6vw, 4.5rem) 2rem;
}
.site-footer a { color: rgba(251,246,239,.74); }
.site-footer a:hover { color: var(--blush); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2rem; }
.footer__brand-mark { height: 56px; width: auto; margin-bottom: 1rem; background: none; }
.footer__about { color: rgba(251,246,239,.74); max-width: 30ch; }
.site-footer h4 { color: var(--on-dark); font-family: var(--font-sans); font-weight: 700; font-size: .82rem; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 1.1rem; }
.footer ul { display: grid; gap: .6rem; font-size: .95rem; }
.footer__social { display: flex; gap: .7rem; margin-top: 1rem; }
.footer__social a {
  width: 42px; height: 42px; border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1);
  transition: background-color .25s var(--ease), transform .25s var(--ease);
}
.footer__social a:hover { background: rgba(255,255,255,.16); transform: translateY(-2px); }
.footer__social svg { width: 20px; height: 20px; }
.footer__bottom {
  margin-top: 2.6rem; padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.1);
  display: flex; flex-wrap: wrap; gap: .6rem 1.4rem; justify-content: space-between; align-items: center;
  font-size: .85rem;
}
.footer__credit-link { color: inherit; font-weight: inherit; }
@media (max-width: 820px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .footer-grid { grid-template-columns: 1fr; } }

/* ---------- WhatsApp flotante ---------- */
.wa-float {
  position: fixed; right: 18px; bottom: 18px; z-index: 180;
  display: inline-flex; align-items: center; gap: .6rem;
  background: #25D366; color: #06351c;
  padding: .8rem 1.1rem .8rem .85rem; border-radius: var(--radius-pill);
  font-weight: 600; font-size: .95rem;
  box-shadow: 0 10px 28px rgba(37,211,102,.4);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.wa-float:hover { transform: translateY(-3px) scale(1.02); color: #06351c; }
.wa-float svg { width: 26px; height: 26px; }
.wa-float__txt { white-space: nowrap; }
.wa-float::after {
  content: ""; position: absolute; inset: -4px; border-radius: inherit;
  border: 2px solid #25D366; opacity: .55; animation: wa-pulse 2.4s var(--ease) infinite;
}
@keyframes wa-pulse { 0% { transform: scale(1); opacity: .5; } 70%,100% { transform: scale(1.35); opacity: 0; } }
@media (max-width: 560px) { .wa-float__txt { display: none; } .wa-float { padding: .85rem; } }
@media (prefers-reduced-motion: reduce) { .wa-float::after { animation: none; display: none; } }

/* ---------- Breadcrumb ---------- */
.breadcrumb { font-size: .85rem; color: var(--ink-faint); display: flex; gap: .5rem; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--cta); }
.breadcrumb [aria-current] { color: var(--ink-soft); }

/* ---------- Page hero (páginas internas) ---------- */
.page-hero {
  padding-top: calc(var(--header-h) + clamp(2rem, 6vw, 4rem));
  padding-bottom: clamp(2rem, 5vw, 3.5rem);
  background: linear-gradient(160deg, var(--blush-soft), var(--lavender-soft));
  text-align: center;
}
.page-hero .container { max-width: 760px; }
.page-hero p { margin-top: .9rem; font-size: 1.08rem; }

/* ---------- Page hero animado (paginas internas) ---------- */
.page-hero--animated {
  position: relative;
  min-height: clamp(520px, 68svh, 720px);
  display: flex;
  align-items: center;
  overflow: hidden;
  text-align: left;
  isolation: isolate;
}

.page-hero--animated .container {
  max-width: var(--container);
}

.page-hero__layout {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  align-items: center;
  min-height: inherit;
}

.page-hero__copy {
  position: relative;
  z-index: 1;
  max-width: 640px;
  padding-block: clamp(1rem, 4vw, 3rem);
}

.page-hero--animated .breadcrumb {
  justify-content: flex-start;
  margin-bottom: 1rem;
}

.page-hero--animated h1 {
  max-width: 11ch;
}

.page-hero--animated p {
  max-width: 560px;
}

.page-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  perspective: 1000px;
}

.page-hero__media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(100% 80% at 18% 48%, rgba(251,246,239,.96) 0%, rgba(251,246,239,.82) 38%, rgba(251,246,239,.42) 58%, rgba(251,246,239,.08) 82%, transparent 100%),
    linear-gradient(90deg, rgba(251,246,239,.95) 0%, rgba(251,246,239,.68) 42%, rgba(251,246,239,.12) 78%, rgba(251,246,239,.35) 100%);
}

.page-hero__media::after {
  content: "";
  position: absolute;
  inset: auto -8% 6% -8%;
  height: 1px;
  z-index: 1;
  background: rgba(46, 39, 48, 0.08);
  transform: rotate(5deg);
}

.page-hero__columns {
  --tile: clamp(118px, 11vw, 188px);
  --gap: clamp(.38rem, .8vw, .7rem);
  --travel: clamp(260px, 28vw, 430px);
  --travel-neg: clamp(-430px, -28vw, -260px);
  position: absolute;
  top: 50%;
  right: clamp(-180px, -8vw, -70px);
  z-index: 0;
  display: grid;
  grid-template-columns: repeat(5, var(--tile));
  gap: var(--gap);
  width: max-content;
  height: clamp(420px, 56vh, 560px);
  transform: translateY(-50%) rotateX(48deg) rotateY(18deg) rotateZ(-24deg) translate3d(-3vw, 2vw, 0);
  transform-origin: 50% 50%;
  transform-style: preserve-3d;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.22) 8%, #000 22%, #000 82%, rgba(0,0,0,.18) 94%, transparent 100%);
          mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.22) 8%, #000 22%, #000 82%, rgba(0,0,0,.18) 94%, transparent 100%);
}

.page-hero__column {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  will-change: transform;
}

.page-hero__column:nth-child(1),
.page-hero__column:nth-child(4) {
  padding-top: clamp(76px, 7vw, 122px);
}

.page-hero__column:nth-child(2),
.page-hero__column:nth-child(5) {
  padding-top: clamp(42px, 4vw, 70px);
}

.page-hero__column img {
  width: var(--tile);
  height: var(--tile);
  object-fit: cover;
  border-radius: 14px;
  background: var(--cream-2);
  box-shadow: 0 18px 36px rgba(46,39,48,.18);
  filter: saturate(.98) contrast(.98);
}

.page-hero__column--up {
  animation: page-hero-scroll-up 26s linear infinite alternate;
}

.page-hero__column--down {
  animation: page-hero-scroll-down 26s linear infinite alternate;
}

@keyframes page-hero-scroll-up {
  from { transform: translateY(0); }
  to { transform: translateY(var(--travel-neg)); }
}

@keyframes page-hero-scroll-down {
  from { transform: translateY(var(--travel-neg)); }
  to { transform: translateY(0); }
}

@media (min-width: 901px) {
  .page-hero--animated {
    min-height: clamp(460px, 58svh, 620px);
    align-items: flex-start;
    padding-top: calc(var(--header-h) + clamp(2.2rem, 7vh, 4rem));
    padding-bottom: clamp(2rem, 4vh, 3rem);
  }

  .page-hero__layout {
    min-height: auto;
  }

  .page-hero__copy {
    padding-block: 0;
  }

  .page-hero__columns {
    top: 56%;
  }
}

@media (max-width: 900px) {
  .page-hero--animated {
    min-height: clamp(560px, 78svh, 720px);
    text-align: center;
  }

  .page-hero__layout {
    display: block;
    min-height: auto;
  }

  .page-hero__copy {
    max-width: 680px;
    margin-inline: auto;
    padding-block: clamp(2.5rem, 12vw, 5rem);
  }

  .page-hero__copy::before {
    content: "";
    position: absolute;
    inset: -1.2rem -1rem;
    z-index: -1;
    border-radius: 32px;
    background: radial-gradient(ellipse at center, rgba(251,246,239,.78) 0%, rgba(251,246,239,.58) 48%, rgba(251,246,239,.22) 72%, rgba(251,246,239,0) 100%);
    transform: translateY(1rem);
    pointer-events: none;
  }

  .page-hero--animated .breadcrumb {
    justify-content: center;
  }

  .page-hero--animated h1,
  .page-hero--animated p {
    margin-inline: auto;
  }

  .page-hero__media::before {
    background:
      radial-gradient(100% 58% at 50% 42%, rgba(251,246,239,.56) 0%, rgba(251,246,239,.34) 42%, rgba(251,246,239,.1) 70%, transparent 100%),
      linear-gradient(180deg, rgba(251,246,239,.08) 0%, rgba(251,246,239,.18) 48%, rgba(251,246,239,.34) 100%);
  }

  .page-hero__columns {
    --tile: clamp(92px, 25vw, 135px);
    --travel: 260px;
    --travel-neg: -260px;
    top: 54%;
    left: 50%;
    right: auto;
    opacity: .8;
    transform: translate(-50%, -50%) rotateX(52deg) rotateY(14deg) rotateZ(-24deg) scale(1.08);
  }
}

@media (max-width: 520px) {
  .page-hero--animated {
    min-height: 560px;
  }

  .page-hero__copy {
    padding-block: 2.4rem 3rem;
  }

  .page-hero__columns {
    --tile: 108px;
    --gap: .38rem;
    --travel-neg: -260px;
    top: 57%;
    grid-template-columns: repeat(5, var(--tile));
    opacity: .74;
    transform: translate(-50%, -50%) rotateX(52deg) rotateY(14deg) rotateZ(-24deg) scale(1.06);
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-hero__column--up,
  .page-hero__column--down {
    animation: none;
  }
}
