/* ===== hotel ===== */
.hotel-page .hotel-hero{
  min-height:calc(100vh - 80px);
  padding:80px 0 48px;
  display:grid;
  grid-template-columns:minmax(320px, .84fr) minmax(420px, 1.16fr);
  gap:clamp(40px,5vw,88px);
  align-items:end;
}

.hotel-hero-copy{
  padding-bottom:clamp(0px,4vw,56px);
}

.hotel-hero h1.display{
  margin-top:0;
  max-width:760px;
}

.hotel-hero .eyebrow{
  margin:0 0 28px;
}

.hotel-hero .eyebrow::before{
  width:7px;
  height:7px;
  background:var(--accent);
}

.hotel-hero .hero-intro{
  margin-top:30px;
  max-width:none;
}

.hero-actions{
  margin-top:40px;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:22px 28px;
}

.hero-primary{
  min-height:46px;
  padding:14px 18px;
  font-weight:500;
}

.hero-secondary{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:14px 0;
  font-family:var(--mono);
  font-size:var(--fs-small);
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.hero-secondary::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:8px;
  height:1px;
  background:currentColor;
  transform-origin:left;
  transition:transform .42s var(--ease);
}

.hero-secondary:hover::after,
.hero-secondary:focus-visible::after{
  transform:scaleX(.18);
}

.hero-primary .arr,
.hero-secondary .arr{
  display:inline-block;
  transition:transform .3s var(--ease);
}

.hero-primary:hover .arr,
.hero-primary:focus-visible .arr,
.hero-secondary:hover .arr,
.hero-secondary:focus-visible .arr{
  transform:translateX(6px);
}

.hero-primary:focus-visible,
.hero-secondary:focus-visible{
  outline:1px solid var(--ink);
  outline-offset:5px;
}

.hotel-hero-media{
  align-self:stretch;
  min-height:520px;
  display:grid;
  grid-template-rows:1fr auto;
  gap:12px;
}

.hotel-hero-media img{
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:cover;
  filter:saturate(var(--media-saturation));
}

.hotel-hero-media figcaption{
  margin:0;
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.16em;
  line-height:1.5;
  text-transform:uppercase;
  color:var(--muted);
}

.hotel-photo{
  margin:0 0 64px;
  width:100%;
  background:var(--bg-2);
}

.hotel-photo img{
  width:100%;
  height:auto;
  display:block;
  filter:saturate(var(--media-saturation));
}

.hotel-section{
  display:block;
  padding:0 0 96px;
}

.hotel-section + .hotel-photo{
  margin-top:-32px;
}

.hotel-section h2{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
  margin-bottom:28px;
}

.hotel-section .copy{
  max-width:none;
}

.hotel-section .copy p + p{
  margin-top:18px;
}

.hotel-section .amenities{
  margin-top:40px;
}

.hotel-cta{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-top:40px;
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.16em;
  text-transform:uppercase;
  padding-bottom:6px;
  border-bottom:1px solid var(--ink);
}

.hotel-cta .arr{
  transition:transform .35s var(--ease);
}

.hotel-cta:hover .arr{
  transform:translateX(6px);
}

@media (max-width:960px){
  .hotel-page .hotel-hero{
    min-height:auto;
    padding:48px 0 40px;
    grid-template-columns:1fr;
    gap:36px;
    align-items:start;
  }

  .hotel-hero-copy{
    padding-bottom:0;
  }

  .hotel-hero .eyebrow{
    margin-bottom:22px;
  }

  .hotel-hero .hero-intro{
    margin-top:24px;
  }

  .hero-actions{
    margin-top:30px;
    gap:14px 22px;
  }

  .hotel-hero-media{
    min-height:auto;
  }

  .hotel-hero-media img{
    min-height:54vh;
  }

  .hotel-photo{
    margin-bottom:48px;
  }

  .hotel-section{
    grid-template-columns:1fr;
    gap:24px;
    padding-bottom:72px;
  }

  .hotel-section + .hotel-photo{
    margin-top:-16px;
  }
}

@media (max-width:640px){
  .hotel-page .hotel-hero{
    padding-top:38px;
  }

  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
    align-items:stretch;
  }

  .hero-primary,
  .hero-secondary{
    width:100%;
  }

  .hero-secondary{
    justify-content:space-between;
    border-top:1px solid var(--hair);
    border-bottom:1px solid var(--hair);
  }

  .hero-secondary::after{
    display:none;
  }

  .hotel-hero-media img{
    min-height:64vw;
  }
}

body.mobile-preview.hotel-page .hotel-hero{
  min-height:auto;
  padding:48px 0 40px;
  grid-template-columns:1fr;
  gap:36px;
  align-items:start;
}

body.mobile-preview .hotel-hero-copy{
  padding-bottom:0;
}

body.mobile-preview .hotel-hero-media{
  min-height:auto;
}

body.mobile-preview .hotel-hero-media img{
  min-height:54vh;
}

body.mobile-preview .hotel-photo{
  margin-bottom:48px;
}

body.mobile-preview .hotel-section{
  grid-template-columns:1fr;
  gap:24px;
  padding-bottom:72px;
}

body.mobile-preview .hotel-section + .hotel-photo{
  margin-top:-16px;
}

/* ===== fotos ===== */
.photos-page .hero{
  padding-bottom:56px;
}

.photos-stream{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-bottom:120px;
}

.photos-stream figure{
  margin:0;
  background:var(--bg-2);
}

.photos-stream img{
  display:block;
  width:100%;
  height:auto;
  filter:saturate(var(--media-saturation));
}

.back-top{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:56px;
  height:56px;
  margin:64px auto 0;
  border:1px solid var(--ink);
  font-family:var(--mono);
  font-size:var(--fs-subtitle);
  line-height:1;
  transition:background .25s, color .25s, transform .35s var(--ease);
}

.back-top:hover{
  background:var(--ink);
  color:var(--bg);
  transform:translateY(-4px);
}

@media (max-width:960px){
  .photos-page .hero{
    padding-bottom:40px;
  }

  .photos-stream{
    gap:8px;
    padding-bottom:80px;
  }
}

body.mobile-preview.photos-page .hero{
  padding-bottom:40px;
}

body.mobile-preview .photos-stream{
  gap:8px;
  padding-bottom:80px;
}

body.mobile-preview .back-top{
  width:52px;
  height:52px;
  margin-top:48px;
}

/* ===== restaurante ===== */
/* Restaurante-specific styles. Loaded on top of borgia.css */

.restaurant-photo{
  margin-top:24px;
  aspect-ratio:16/9;
  background:var(--bg-2);
  overflow:hidden;
}
.restaurant-photo + .room-body,
.restaurant-photo + .restaurant-menu-strip{
  margin-top:80px;
}
.restaurant-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(var(--media-saturation));
}

.restaurant-menu-strip{
  margin-top:80px;
  padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
}
.restaurant-menu-strip .menu-cell{
  padding:28px 32px;
  border-right:1px solid var(--hair);
}
.restaurant-menu-strip .menu-cell:last-child{border-right:0}
.restaurant-menu-strip .label{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:18px;
}
.restaurant-menu-strip .headline{
  font-family:var(--serif);
  font-size:var(--fs-headline);
  line-height:1;
  letter-spacing:-0.03em;
  font-weight:300;
  max-width:12ch;
}
.restaurant-menu-strip .copy{
  font-family:var(--serif);
  font-size:var(--fs-serif-md);
  line-height:1.45;
  letter-spacing:-0.005em;
  color:var(--ink-2);
  max-width:none;
}

@media (max-width:760px){
  .restaurant-menu-strip{grid-template-columns:1fr}
  .restaurant-menu-strip .menu-cell{border-right:0;border-bottom:1px solid var(--hair)}
  .restaurant-menu-strip .menu-cell:last-child{border-bottom:0}
  .restaurant-photo{aspect-ratio:16/10}
}

body.mobile-preview .restaurant-menu-strip{grid-template-columns:1fr}
body.mobile-preview .restaurant-menu-strip .menu-cell{border-right:0;border-bottom:1px solid var(--hair)}
body.mobile-preview .restaurant-menu-strip .menu-cell:last-child{border-bottom:0}
body.mobile-preview .restaurant-photo{aspect-ratio:16/10}

/* ===== salones ===== */
/* Salones-specific styles. Loaded on top of styles.css */

/* Listing — single column, big photos */
.salones-filter .lbl{flex:1}
.salones-filter .code{margin-left:auto;border-right:0}
.salones-list{display:flex;flex-direction:column;gap:160px;padding-bottom:96px}
.salones-list--compact{gap:96px}
.salon-card{display:flex;flex-direction:column;gap:20px;container-type:inline-size}
.salon-card .img{
  position:relative;display:block;width:100%;aspect-ratio:16/9;
  background:var(--bg-2);overflow:hidden;
  transition:transform .6s var(--ease);
}
.salon-card .img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s var(--ease);filter:saturate(var(--media-saturation))}
.salon-card:hover .img img{transform:scale(1.02)}
.salon-card .meta{
  display:grid;
  grid-template-columns:minmax(220px,.72fr) minmax(0,1fr);
  column-gap:64px;
  row-gap:8px;
  align-items:start;
  max-width:none;
}
.salon-card .meta .head{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.salon-card .name{font-family:var(--serif);font-weight:300;font-size:var(--fs-cq-title);letter-spacing:-0.025em;line-height:0.95}
.salon-card .cap{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.salon-card .copy{font-family:var(--serif);font-weight:300;font-size:var(--fs-serif-md);line-height:1.5;letter-spacing:-0.005em;color:var(--ink-2);text-wrap:pretty;margin:0;max-width:none}
.salon-card .view{
  font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.16em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;position:relative;align-self:flex-start;justify-self:start;
  padding-bottom:4px;margin-top:6px;
  grid-column:2;
}
.salon-card .view::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);transform-origin:left;transform:scaleX(1);transition:transform .4s var(--ease)}
.salon-card:hover .view::after{transform:scaleX(0);animation:redraw 0.7s .25s var(--ease) forwards}
.salon-card .view .arr{display:inline-block;transition:transform .35s var(--ease)}
.salon-card:hover .view .arr{transform:translateX(6px)}
@media (max-width:960px){
  .salones-list{gap:120px}
}

@media (max-width:760px){
  .salones-list{gap:88px}
}

@media (max-width:640px){
  .salones-list{gap:56px}
  .salon-card .meta{grid-template-columns:1fr;gap:18px}
  .salon-card .meta .head{flex-direction:column;align-items:flex-start;gap:8px}
  .salon-card .view{grid-column:1;justify-self:start;margin-top:6px}
}

body.mobile-preview .salon-card .meta{grid-template-columns:1fr;gap:18px}
body.mobile-preview .salon-card .meta .head{flex-direction:column;align-items:flex-start;gap:8px}
body.mobile-preview .salon-card .view{grid-column:1;justify-self:start;margin-top:6px}
body.mobile-preview .salones-list{gap:56px}

/* Equipment block */
.equip{margin-top:96px;padding:64px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.equip-head{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--muted);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.equip-head::before{content:"";width:28px;height:1px;background:var(--ink)}
.equip h2{font-family:var(--serif);font-weight:300;font-size:var(--fs-display);letter-spacing:-0.025em;line-height:1;margin-bottom:48px;max-width:18ch}
.equip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 48px}
@media (max-width:640px){ .equip-grid{grid-template-columns:1fr} }
.equip-grid li{list-style:none;padding:10px 0;font-family:var(--serif);font-weight:300;font-size:var(--fs-serif-md);letter-spacing:-0.005em;display:flex;align-items:baseline;gap:14px}
.equip-grid li::before{content:"·";color:var(--muted);font-family:var(--mono);font-size:var(--fs-serif-md)}

/* Closing block */
.closing{margin-top:96px;padding:80px 0 96px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;border-top:1px solid var(--hair)}
.closing--compact{margin-top:32px}
@media (max-width:760px){ .closing{grid-template-columns:1fr;gap:24px} }
.closing .lbl{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px}
.closing .lbl::before{content:"";width:28px;height:1px;background:var(--ink)}
.closing h3{font-family:var(--serif);font-weight:300;font-size:var(--fs-display);letter-spacing:-0.03em;line-height:1;margin-top:18px;text-wrap:pretty}
.closing p{font-family:var(--serif);font-weight:300;font-size:var(--fs-serif-md);line-height:1.5;letter-spacing:-0.005em;color:var(--ink-2);text-wrap:pretty;max-width:none}
.closing .cta-row{margin-top:28px;display:flex;gap:16px;flex-wrap:wrap}
.closing .cta-row .cta{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.18em;text-transform:uppercase;padding:14px 22px;display:inline-flex;align-items:center;gap:10px;border:1px solid var(--accent);background:var(--accent);color:var(--bg);transition:background .25s,border-color .25s}
.closing .cta-row .cta.ghost{background:transparent;color:var(--ink)}
.closing .cta-row .cta:hover{background:var(--ink);border-color:var(--ink);color:var(--bg)}
.closing .cta-row .cta.ghost:hover{background:var(--ink);color:var(--bg)}

/* Setup tables (detail page) */
.setup{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid var(--hair)}
.setup .row{display:grid;grid-template-columns:1fr auto;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--hair)}
.setup .row .name{font-family:var(--serif);font-weight:300;font-size:var(--fs-serif-md);letter-spacing:-0.015em}
.setup .row .name small{display:block;font-family:var(--mono);font-size:var(--fs-micro);letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:500}
.setup .row .pax{font-family:var(--serif);font-weight:300;font-size:var(--fs-headline);letter-spacing:-0.02em;line-height:1}
.setup .row .pax small{font-family:var(--mono);font-size:var(--fs-micro);letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-left:8px;font-weight:500}

/* Contact form inside popup */
.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:520px){ .contact-form .row2{grid-template-columns:1fr} }
.contact-form label{display:flex;flex-direction:column;gap:6px}
.contact-form label > span{font-family:var(--mono);font-size:var(--fs-micro);letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.contact-form input, .contact-form select, .contact-form textarea{
  background:transparent;border:1px solid var(--hair-strong);
  padding:10px 12px;font-family:var(--serif);font-size:var(--fs-serif-md);font-weight:300;letter-spacing:-0.005em;color:var(--ink);
  outline:none;border-radius:0;
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{ border-color:var(--ink) }
.contact-form textarea{resize:vertical;min-height:60px}

/* ===== gimnasio ===== */
.gym-page main {
  padding-bottom: 96px;
}

.gym-shell {
  width: 100%;
  padding: 64px 0 120px;
}

.gym-hero {
  padding: 0 0 40px;
  gap: 18px;
}

.gym-hero .eyebrow {
  margin: 0;
}

.gym-hero h1.display {
  margin-top: 0;
}

.gym-hero .hero-intro {
  margin: 0;
}

.gym-photo {
  margin: 0 0 56px;
}

.gym-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  filter: saturate(var(--media-saturation));
}

.gym-photo figcaption {
  margin: 14px 0 0;
  font-family: var(--mono);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1.5;
  text-transform: uppercase;
  color: var(--muted);
}

.gym-block {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-bottom: 48px;
}

.gym-block h2,
.gym-final-note h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: var(--fs-headline);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.025em;
}

.gym-block p {
  max-width: none;
  margin: 0;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: -0.005em;
  color: var(--ink-2);
}

.gym-block strong,
.gym-conditions strong {
  font-weight: 500;
  color: var(--ink);
}

.gym-conditions {
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  margin-bottom: 56px;
}

.gym-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  align-items: baseline;
  gap: 24px;
  padding: 14px 0;
  border-bottom: 1px solid var(--hair);
}

.gym-row:last-child {
  border-bottom: 0;
}

.gym-row span {
  font-family: var(--mono);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--muted);
}

.gym-row strong {
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.35;
}

.gym-final-note {
  display: flex;
  flex-direction: column;
  gap: 12px;
  border-top: 1px solid var(--ink);
  padding-top: 32px;
}

.gym-final-note p {
  max-width: none;
  margin: 0;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.4;
  letter-spacing: -0.005em;
  color: var(--ink);
}

.gym-final-note a {
  border-bottom: 1px solid currentColor;
  text-decoration: none;
}

@media (max-width: 960px) {
  .gym-shell {
    padding: 48px 0 88px;
  }
}

@media (max-width: 640px) {
  .gym-page main {
    padding-bottom: 72px;
  }

  .gym-shell {
    padding-top: 40px;
  }

  .gym-photo img {
    aspect-ratio: 4 / 3;
  }

  .gym-row {
    grid-template-columns: 110px 1fr;
    gap: 16px;
  }
}

/* ===== directions ===== */
.directions-page main {
  padding-bottom: 96px;
}

.directions-map {
  margin: 0;
  width: 100%;
  aspect-ratio: 16 / 7;
  border: 1px solid var(--hair-strong);
  background: var(--bg-2);
  overflow: hidden;
  filter: saturate(var(--media-saturation));
}

.directions-map iframe,
.directions-map #borgia-map {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

.directions-map-caption {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.directions-map-caption a {
  color: var(--ink);
  position: relative;
  white-space: nowrap;
}

.directions-map-caption a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -3px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--ease);
}

.directions-map-caption a:hover::after {
  transform: scaleX(1);
}

.directions-section {
  padding: 96px 0;
  border-top: 1px solid var(--hair);
}

.directions-section h2 {
  font-family: var(--serif);
  font-size: var(--fs-headline);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.03em;
}

.directions-label,
.transport-card .num,
.coords-strip .label {
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.directions-label {
  margin-bottom: 14px;
}

.directions-copy {
  max-width: none;
}

.directions-copy p {
  margin: 0 0 18px;
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--ink-2);
}

.directions-copy p:last-child {
  margin-bottom: 0;
}

.address-line {
  margin: 0 0 28px;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.directions-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.directions-actions .booking-primary,
.directions-actions .booking-ghost {
  min-height: 52px;
}

.transport-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 0 0 96px;
}

.transport-card {
  min-height: 280px;
  padding: 32px 32px 0;
  border-left: 1px solid var(--hair);
}

.transport-card:first-child {
  padding-left: 0;
  border-left: 0;
}

.transport-card .num {
  display: flex;
  gap: 14px;
  margin-bottom: 18px;
}

.transport-card .num .n {
  color: var(--ink);
}

.transport-card h3 {
  margin: 0 0 16px;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.transport-card p {
  margin: 0 0 12px;
  font-size: var(--fs-body-sm);
  line-height: 1.6;
  color: var(--ink-2);
}

.transport-card .km {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--hair);
  display: flex;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.transport-card .km strong {
  color: var(--ink);
  font-weight: 500;
  white-space: nowrap;
}

.coords-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.coords-strip > div {
  padding: 28px 24px;
  border-left: 1px solid var(--hair);
}

.coords-strip > div:first-child {
  border-left: 0;
}

.coords-strip .label {
  margin-bottom: 10px;
}

.coords-strip .value {
  font-family: var(--mono);
  font-size: var(--fs-body);
  line-height: 1.3;
  color: var(--ink);
}

.coords-strip .value.serif {
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  letter-spacing: -0.01em;
}

@media (max-width: 960px) {
  .directions-page main {
    padding-bottom: 72px;
  }

  .directions-section {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 64px 0;
  }

  .transport-grid {
    grid-template-columns: 1fr;
    padding-bottom: 64px;
  }

  .transport-card {
    min-height: 0;
    padding: 32px 0 0;
    border-left: 0;
    border-top: 1px solid var(--hair);
  }

  .transport-card:first-child {
    padding-top: 0;
    border-top: 0;
  }

  .coords-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .coords-strip > div:nth-child(3) {
    border-left: 0;
  }

  .coords-strip > div:nth-child(n+3) {
    border-top: 1px solid var(--hair);
  }
}

@media (max-width: 520px) {
  .directions-map {
    aspect-ratio: 4 / 5;
  }

  .directions-map-caption {
    flex-direction: column;
  }

  .coords-strip {
    grid-template-columns: 1fr;
  }

  .coords-strip > div {
    border-left: 0;
    border-top: 1px solid var(--hair);
  }

  .coords-strip > div:first-child {
    border-top: 0;
  }
}

/* ===== contacto ===== */
.contact-page main {
  padding-bottom: 96px;
}

.contact-links {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: 96px;
}

.contact-link {
  min-height: 0;
  padding: 16px 0;
  border-right: 0;
  border-bottom: 1px solid var(--hair);
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 24px;
}

.contact-link:last-child {
  border-bottom: 0;
}

.contact-link .label,
.contact-form-section .label,
.contact-note .label {
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.contact-link .value {
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.contact-link .arrow {
  font-family: var(--mono);
  font-size: var(--fs-body);
  color: var(--accent);
}

.contact-form-section {
  padding: 0 0 96px;
}

.contact-form-section h2 {
  font-family: var(--serif);
  font-size: var(--fs-headline);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.03em;
  margin-top: 18px;
  margin-bottom: 10px;
}

.contact-form-section .sub {
  margin: 0;
  color: var(--muted);
}

.contact-form {
  display: grid;
  gap: 22px;
}

.contact-form .privacy {
  font-size: var(--fs-small);
  line-height: 1.55;
  color: var(--ink-2);
}

.contact-form .privacy a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.contact-check {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-family: var(--mono);
  font-size: var(--fs-small);
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.contact-check input {
  appearance: none;
  display: grid;
  place-content: center;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin: 0;
  margin-top: 1px;
  border: 1px solid var(--muted);
  background: transparent;
}

.contact-check input::before {
  content: "";
  width: 9px;
  height: 5px;
  border-left: 2px solid var(--bg);
  border-bottom: 2px solid var(--bg);
  transform: translateY(-1px) rotate(-45deg) scale(0);
  transition: transform .15s var(--ease);
}

.contact-check input:checked {
  border-color: var(--accent);
  background: var(--accent);
}

.contact-check input:checked::before {
  transform: translateY(-1px) rotate(-45deg) scale(1);
}

.contact-note {
  border-top: 1px solid var(--hair);
  padding-top: 28px;
  display: grid;
  grid-template-columns: minmax(180px, .32fr) minmax(0, 1fr);
  gap: 48px;
}

.contact-note p {
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.22;
  letter-spacing: -0.02em;
}

.contact-note a {
  border-bottom: 1px solid currentColor;
  text-decoration: none;
}

@media (max-width: 960px) {
  .contact-links {
    margin-bottom: 64px;
  }

  .contact-link {
    grid-template-columns: 104px minmax(0, 1fr) auto;
    gap: 16px;
  }

  .contact-form-section,
  .contact-note {
    grid-template-columns: 1fr;
    gap: 28px;
  }
}

@media (max-width: 640px) {
  .contact-page main {
    padding-bottom: 72px;
  }

  .contact-links {
    margin-bottom: 72px;
  }

  .contact-link {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 14px;
    min-height: 72px;
    padding: 20px 0;
  }

  .contact-link .label {
    grid-column: 1 / -1;
  }

  .contact-link .value {
    font-size: var(--fs-subtitle);
    overflow-wrap: anywhere;
  }

  .contact-link .arrow {
    align-self: center;
  }

  .contact-form .privacy,
  .grupos-form .privacy {
    text-wrap: pretty;
  }

  .contact-check {
    min-height: 40px;
    align-items: flex-start;
  }

  .contact-note p {
    line-height: 1.35;
    text-wrap: pretty;
  }

  .hero .crumbs,
  .nosotros-hero .crumbs {
    min-height: 40px;
    align-items: center;
    flex-wrap: wrap;
  }

  .hero .crumbs a,
  .nosotros-hero .crumbs a,
  .booking-ghost {
    display: inline-flex;
    min-height: 40px;
    align-items: center;
  }

  .booking-ghost {
    padding: 10px 0;
  }
}

/* ===== grupos ===== */
.grupos-page main {
  padding-bottom: 96px;
}

.grupos-hero {
  padding-bottom: 56px;
}

.grupos-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.38fr);
  gap: 56px;
  align-items: end;
}

.grupos-hero .eyebrow,
.grupos-form-section .label {
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.grupos-hero .eyebrow {
  margin: 0 0 22px;
}

.grupos-contact {
  display: grid;
}

.grupos-contact a {
  display: grid;
  gap: 12px;
  padding: 22px 0;
  border-bottom: 1px solid var(--hair);
}

.grupos-contact a:last-child {
  border-bottom: 0;
}

.grupos-contact span {
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.grupos-contact strong {
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.1;
}

.grupos-editorial {
  padding: 0 0 96px;
}

.grupos-copy {
  display: grid;
  gap: 20px;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.grupos-copy strong {
  font-weight: 500;
}

.grupos-photo {
  margin: 0;
  background: var(--bg-2);
}

.grupos-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  filter: saturate(var(--media-saturation));
}

.grupos-form-section {
  padding: 0 0 96px;
}

.grupos-form-section h2 {
  margin-top: 18px;
  font-family: var(--serif);
  font-size: var(--fs-headline);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.03em;
}

.grupos-form {
  display: grid;
  gap: 22px;
}

.grupos-form .privacy {
  font-size: var(--fs-small);
  line-height: 1.55;
  color: var(--ink-2);
}

.grupos-form .privacy a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.contact-check {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-family: var(--mono);
  font-size: var(--fs-small);
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.contact-check input {
  appearance: none;
  display: grid;
  place-content: center;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin: 0;
  margin-top: 1px;
  border: 1px solid var(--muted);
  background: transparent;
}

.contact-check input::before {
  content: "";
  width: 9px;
  height: 5px;
  border-left: 2px solid var(--bg);
  border-bottom: 2px solid var(--bg);
  transform: translateY(-1px) rotate(-45deg) scale(0);
  transition: transform .15s var(--ease);
}

.contact-check input:checked {
  border-color: var(--accent);
  background: var(--accent);
}

.contact-check input:checked::before {
  transform: translateY(-1px) rotate(-45deg) scale(1);
}

@media (max-width: 960px) {
  .grupos-hero-grid,
  .grupos-editorial,
  .grupos-form-section {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .grupos-editorial {
    padding-bottom: 72px;
  }

  .grupos-form-section {
    padding-bottom: 72px;
  }
}

@media (max-width: 640px) {
  .grupos-hero {
    padding-bottom: 44px;
  }

  .grupos-photo img {
    aspect-ratio: 4 / 3;
  }

  .grupos-contact a {
    min-height: 72px;
    padding: 20px 0;
  }

  .grupos-contact strong {
    overflow-wrap: anywhere;
  }

  .grupos-copy {
    line-height: 1.35;
    text-wrap: pretty;
  }
}

/* ===== faq ===== */
.faq-page main {
  padding-bottom: 96px;
}

.faq-hero h1.display {
  max-width: 16ch;
}

.faq-layout {
  display: grid;
  grid-template-columns: minmax(180px, .32fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 96px);
  padding: 0 0 96px;
}

.faq-index {
  position: sticky;
  top: 32px;
  align-self: start;
  border-top: 1px solid var(--ink);
  padding-top: 18px;
}

.faq-index h2,
.faq-section h2 {
  font-family: var(--mono);
  font-size: var(--fs-small);
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}

.faq-index ul {
  list-style: none;
  display: grid;
  gap: 8px;
  margin-top: 22px;
}

.faq-index a {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--serif);
  font-size: var(--fs-body);
  line-height: 1.25;
  color: var(--ink-2);
  transition: color .25s var(--ease), transform .25s var(--ease);
}

.faq-index a::before {
  content: "";
  width: var(--dot-sm);
  height: var(--dot-sm);
  background: var(--accent);
  flex: 0 0 auto;
  transform: translateY(-2px);
}

.faq-index a:hover,
.faq-index a:focus-visible {
  color: var(--ink);
  transform: translateX(4px);
}

.faq-content {
  display: grid;
  gap: 72px;
}

.faq-section {
  display: grid;
  gap: 18px;
}

.faq-section h2 {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--hair);
}

.faq-list {
  display: grid;
  gap: 0;
}

.faq-item {
  border-bottom: 1px solid var(--hair);
}

.faq-item:first-child {
  border-top: 1px solid var(--hair);
}

.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: baseline;
  padding: 20px 0;
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.22;
  letter-spacing: -.01em;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+";
  font-family: var(--mono);
  font-size: var(--fs-body);
  color: var(--accent);
  transition: transform .3s var(--ease);
}

.faq-item[open] summary::after {
  transform: rotate(45deg);
}

.faq-answer {
  max-width: 74ch;
  padding: 0 56px 24px 0;
  color: var(--ink-2);
}

.faq-answer p {
  font-size: var(--fs-body);
  line-height: 1.6;
}

.faq-answer a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.faq-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 96px;
}

.faq-action {
  min-height: 180px;
  padding: 28px;
  border-right: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 32px;
}

.faq-action:last-child {
  border-right: 0;
}

.faq-action .label {
  font-family: var(--mono);
  font-size: var(--fs-small);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
}

.faq-action .value {
  font-family: var(--serif);
  font-size: var(--fs-serif-md);
  font-weight: 300;
  line-height: 1.12;
  letter-spacing: -.02em;
}

.faq-action .arrow {
  font-family: var(--mono);
  color: var(--accent);
}

@media (max-width: 960px) {
  .faq-page main {
    padding-bottom: 72px;
  }

  .faq-layout {
    grid-template-columns: 1fr;
    gap: 48px;
    padding-bottom: 72px;
  }

  .faq-index {
    position: static;
  }

  .faq-content {
    gap: 56px;
  }

  .faq-actions {
    grid-template-columns: 1fr;
    margin-bottom: 72px;
  }

  .faq-action {
    min-height: 150px;
    border-right: 0;
    border-bottom: 1px solid var(--hair);
  }

  .faq-action:last-child {
    border-bottom: 0;
  }
}

@media (max-width: 640px) {
  .faq-index a,
  .faq-action {
    min-height: 40px;
  }

  .faq-index a {
    align-items: center;
  }

  .faq-item summary {
    gap: 18px;
    min-height: 58px;
    padding: 18px 0;
    align-items: center;
  }

  .faq-answer {
    padding-right: 0;
  }

  .faq-answer p {
    text-wrap: pretty;
  }
}

/* ===== legal ===== */
.legal-page .hero{
  padding-bottom:48px;
}

.legal-doc{
  padding:0 0 120px;
}

.legal-doc > h5{
  padding-top:48px;
  margin-top:48px;
  border-top:1px solid var(--hair);
}

.legal-doc > h5:first-child{
  padding-top:0;
  margin-top:0;
  border-top:0;
}

.legal-doc section{
  padding:48px 0;
  border-top:1px solid var(--hair);
}

.legal-doc section:first-child{
  border-top:0;
  padding-top:0;
}

.legal-doc h2,
.legal-doc h5{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
  margin-bottom:28px;
}

.legal-doc h3,
.legal-doc h6{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink);
  margin:32px 0 16px;
}

.legal-doc p,
.legal-doc li,
.legal-doc td,
.legal-doc th{
  font-family:var(--serif);
  font-weight:300;
  font-size:var(--fs-body);
  line-height:1.5;
  letter-spacing:-.005em;
  color:var(--ink-2);
}

.legal-doc p + p,
.legal-doc ul + p,
.legal-doc table + p,
.legal-doc p + ul{
  margin-top:18px;
}

.legal-doc ul{
  display:grid;
  gap:12px;
  margin:18px 0 0;
  padding-left:0;
  list-style:none;
}

.legal-doc li{
  position:relative;
  padding-left:24px;
}

.legal-doc li::before{
  content:"";
  position:absolute;
  left:0;
  top:.72em;
  width:6px;
  height:6px;
  background:var(--ink);
}

.legal-doc a{
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
}

.legal-doc strong{
  font-weight:400;
  color:var(--ink);
}

.legal-doc table{
  width:100%;
  border-collapse:collapse;
  margin:18px 0 28px;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
}

.legal-doc tr + tr{
  border-top:1px solid var(--hair);
}

.legal-doc th,
.legal-doc td{
  vertical-align:top;
  text-align:left;
  padding:16px 0;
}

.legal-doc th{
  width:34%;
  padding-right:32px;
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
}

.legal-doc code{
  font-family:var(--mono);
  font-size:.78em;
}

.legal-logos{
  display:flex;
  align-items:center;
  gap:32px;
  flex-wrap:wrap;
  margin-top:28px;
}

.legal-logos img{
  width:auto;
  max-width:min(320px,100%);
  max-height:90px;
  object-fit:contain;
}

.legal-updated{
  margin-top:48px;
  padding-top:24px;
  border-top:1px solid var(--hair);
}

@media (max-width:760px){
  .legal-page .hero{
    padding-bottom:36px;
  }

  .legal-doc{
    padding-bottom:80px;
  }

  .legal-doc section{
    padding:40px 0;
  }

  .legal-doc table,
  .legal-doc tbody,
  .legal-doc tr,
  .legal-doc th,
  .legal-doc td{
    display:block;
    width:100%;
  }

  .legal-doc th{
    padding:14px 0 4px;
  }

  .legal-doc td{
    padding:0 0 14px;
  }

  .legal-doc p,
  .legal-doc li,
  .legal-doc td,
  .legal-doc th{
    text-wrap:pretty;
  }

  .legal-doc a,
  .legal-doc code{
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .legal-doc li{
    padding-left:20px;
  }
}

/* ===== nosotros ===== */
.nosotros-page .nosotros-hero{
  padding-bottom:88px;
}

.nosotros-hero .crumbs{
  font-family:var(--mono);
  font-size:var(--fs-micro);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:4px;
}

.nosotros-hero .eyebrow{
  margin:0;
}

.nosotros-hero h1.display{
  max-width:760px;
}

.nosotros-hero .hero-intro{
  max-width:none;
}

.nosotros-section{
  padding:0 0 104px;
}

.section-kicker{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:18px;
}

.nosotros-section h2,
.work-section h2{
  margin:0;
  font-family:var(--serif);
  font-size:var(--fs-headline);
  line-height:1.04;
  font-weight:300;
  letter-spacing:-0.025em;
}

.hotel-group-list{
  margin-top:48px;
  border-top:1px solid var(--ink);
}

.group-hotel{
  display:grid;
  grid-template-columns:84px minmax(0, 1fr);
  gap:36px;
  padding:42px 0;
  border-bottom:1px solid var(--hair);
}

.group-hotel-featured{
  grid-template-columns:84px minmax(0, 1fr) minmax(320px, .72fr);
  align-items:start;
}

.group-number{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.16em;
  color:var(--muted);
}

.group-copy{
  max-width:980px;
}

.group-copy h3{
  margin:0 0 22px;
  font-family:var(--serif);
  font-size:var(--fs-serif-md);
  line-height:1.1;
  font-weight:300;
}

.group-copy p + p{
  margin-top:18px;
}

.group-media{
  margin:0;
  background:var(--bg-2);
}

.group-media img{
  width:100%;
  aspect-ratio:4 / 5;
  object-fit:cover;
  filter:saturate(var(--media-saturation));
}

.work-section{
  padding:0 0 112px;
  border-top:1px solid var(--ink);
  padding-top:48px;
}

.work-copy{
  max-width:860px;
}

.privacy-note{
  color:var(--muted);
  font-style:italic;
}

.cv-form{
  margin-top:36px;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:18px;
  align-items:end;
}

.file-field{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.file-field span{
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}

.file-field input{
  width:100%;
  border:1px solid var(--hair);
  padding:16px;
  background:transparent;
  font:inherit;
  color:var(--ink);
}

.file-field input::file-selector-button{
  margin-right:16px;
  border:1px solid var(--ink);
  background:transparent;
  color:var(--ink);
  padding:10px 14px;
  font-family:var(--mono);
  font-size:var(--fs-small);
  letter-spacing:.14em;
  text-transform:uppercase;
}

.cv-submit{
  min-height:56px;
  padding:14px 18px;
  font-weight:500;
  white-space:nowrap;
}

.cv-submit .arr{
  display:inline-block;
  transition:transform .35s var(--ease);
}

.cv-submit:hover .arr,
.cv-submit:focus-visible .arr{
  transform:translateX(6px);
}

@media (max-width:960px){
  .nosotros-page .nosotros-hero{
    padding:48px 0 64px;
  }

  .group-hotel,
  .group-hotel-featured,
  .work-section{
    grid-template-columns:1fr;
    gap:24px;
  }

  .group-hotel{
    padding:34px 0;
  }

  .group-number{
    margin-bottom:-4px;
  }

  .group-media img{
    aspect-ratio:16 / 10;
  }

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

  .cv-submit{
    width:100%;
  }
}

@media (max-width:640px){
  .nosotros-page .nosotros-hero{
    padding-top:38px;
  }

  .nosotros-section{
    padding-bottom:72px;
  }

  .hotel-group-list{
    margin-top:34px;
  }

  .work-section{
    padding-bottom:80px;
  }

  .file-field input::file-selector-button{
    display:block;
    width:100%;
    margin:0 0 12px;
  }

  .group-hotel{
    gap:18px;
  }

  .group-copy p,
  .work-copy p{
    text-wrap:pretty;
  }
}

/* ===== ofertas ===== */
.offers-page .offers-hero h1.display{max-width:16ch}
.offers-page .label{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}
.offers-contact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:32px}
.offers-contact a{display:flex;flex-direction:column;gap:8px;padding:18px 22px;border-right:1px solid var(--hair)}
.offers-contact a:last-child{border-right:0}
.offers-contact span{font-family:var(--mono);font-size:var(--fs-micro);letter-spacing:0.16em;text-transform:uppercase;color:var(--muted)}
.offers-contact strong{font-family:var(--serif);font-weight:300;font-size:var(--fs-serif-md);line-height:var(--lh-snug);letter-spacing:-0.01em}
.offers-content{padding:24px 0 96px}
.offers-empty{padding:48px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.offers-empty h2{font-family:var(--mono);font-size:var(--fs-small);font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.offers-empty p{font-family:var(--serif);font-weight:300;font-size:var(--fs-subtitle);line-height:1.5;letter-spacing:-0.005em;color:var(--ink-2)}
.offers-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:32px}
.offers-actions .btn-primary{padding:14px 18px;background:var(--ink);border-color:var(--ink);color:var(--bg)}
.offers-actions .btn-primary:hover{background:var(--bg);color:var(--ink)}
.offers-actions .arr{display:inline-block;transition:transform .35s var(--ease)}
.offers-actions a:hover .arr{transform:translateX(6px)}
.offers-link{font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;position:relative;padding-bottom:4px}
.offers-link::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);transform-origin:left;transition:transform .4s var(--ease)}
.offers-link:hover::after{transform:scaleX(0);animation:redraw .7s .25s var(--ease) forwards}
.offers-newsletter{padding:64px 0 96px;border-top:1px solid var(--ink)}
.offers-newsletter h2{font-family:var(--serif);font-weight:300;font-size:var(--fs-headline);line-height:var(--lh-snug);letter-spacing:-0.02em;max-width:none}
.offers-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:0;margin-top:32px;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.offers-form input{width:100%;min-width:0;border:0;border-right:1px solid var(--hair);background:transparent;padding:18px 22px;font:inherit;font-size:var(--fs-body);color:var(--ink)}
.offers-form input:focus{outline:1px solid var(--ink);outline-offset:-1px}
.offers-form button{padding:18px 22px;font-family:var(--mono);font-size:var(--fs-small);letter-spacing:0.16em;text-transform:uppercase;color:var(--bg);background:var(--ink);border-left:1px solid var(--ink)}
.offers-form button:hover{background:var(--bg);color:var(--ink)}
@media (max-width:760px){
  .offers-contact{grid-template-columns:1fr}
  .offers-contact a{border-right:0;border-bottom:1px solid var(--hair)}
  .offers-contact a:last-child{border-bottom:0}
  .offers-form{grid-template-columns:1fr}
  .offers-form input{border-right:0;border-bottom:1px solid var(--hair)}
  .offers-form button{min-height:58px}
}

@media (max-width:640px){
  .photos-stream img,
  .restaurant-photo img,
  .salon-card .img,
  .gym-photo img,
  .grupos-photo img,
  .group-media img{
    outline:1px solid rgba(0,0,0,.1);
    outline-offset:-1px;
  }

  .restaurant-photo + .room-body,
  .restaurant-photo + .restaurant-menu-strip{
    margin-top:56px;
  }

  .restaurant-menu-strip .menu-cell{
    padding:24px 0;
  }

  .offers-link,
  .offers-contact a,
  .offers-actions .btn-primary,
  .offers-form button,
  .directions-map-caption a,
  .gym-final-note a{
    min-height:40px;
    align-items:center;
  }

  .offers-link{
    padding:10px 0;
  }

  .offers-link::after{
    bottom:8px;
  }

  .offers-empty p,
  .offers-newsletter h2,
  .gym-block p,
  .gym-final-note p{
    text-wrap:pretty;
  }
}
body.mobile-preview.offers-page .offers-contact{grid-template-columns:1fr}
body.mobile-preview.offers-page .offers-contact a{border-right:0;border-bottom:1px solid var(--hair)}
body.mobile-preview.offers-page .offers-contact a:last-child{border-bottom:0}
body.mobile-preview.offers-page .offers-form{grid-template-columns:1fr}
body.mobile-preview.offers-page .offers-form input{border-right:0;border-bottom:1px solid var(--hair)}
body.mobile-preview.offers-page .offers-form button{min-height:58px}
