:root{
  --bg:#0f1113;          /* grafito profundo */
  --fg:#f4f2ee;          /* blanco cálido */
  --muted:#a6a6a6;
  --accent:#1f7a6d;      /* verde Pixkuy */
}

*{ box-sizing:border-box; }
html,body{
  margin:0;
  padding:0;
  background:var(--bg);
  color:var(--fg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* ✅ MEJORA UX: scroll suave en anclas */
  scroll-behavior:smooth;
}

.lang{
  position:fixed;
  top:clamp(12px, 2vw, 16px);
  right:clamp(12px, 2vw, 16px);
  z-index:20;

  display:inline-flex;
  align-items:center;
  gap:6px;

  padding:8px 10px;
  border-radius:999px;

  background:rgba(15,17,19,.55);
  border:1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

.lang button{
  background:transparent;
  border:0;
  color:var(--muted);
  cursor:pointer;

  padding:6px 10px;
  border-radius:999px;

  font-size:14px;
  line-height:1;
  white-space:nowrap;

  transition:
    color .15s ease,
    background-color .15s ease,
    opacity .15s ease,
    transform .15s ease,
    box-shadow .15s ease,
    border-color .15s ease;
}

/* ✅ Estado activo del idioma (CSS-driven, accesible) */
.lang button[aria-pressed="true"]{
  border:1px solid rgba(244, 242, 238, 0.35);
  background:rgba(244, 242, 238, 0.12);
  color:var(--fg);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  transform: translateY(-1px);
}

.lang button:hover{
  color:var(--fg);
  background:rgba(255,255,255,.06);
}

.lang button:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:2px;
  color:var(--fg);
  background:rgba(31,122,109,.12);
}

.lang button:active{
  opacity:.85;
}

/* -------------------------------------------------
   LANGUAGE SELECTOR — PRO (trigger + dropdown/sheet)
   Compatible con:
   - Trigger: .lang-trigger / #lang-trigger
   - Current: .lang-current
   - Menu: .lang-menu (ul) + buttons con [data-lang]
   Nota: NO rompe el modo legacy (3 botones) porque no toca .lang button salvo en el ámbito .lang-menu.
   ------------------------------------------------- */

.lang-trigger{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  min-width:44px;
  height:36px;
  padding:0 14px;

  border-radius:999px;
  background:transparent;
  border:0;

  color:var(--fg);
  cursor:pointer;
  font-size:14px;
  line-height:1;
  white-space:nowrap;

  transition:
    background-color .15s ease,
    box-shadow .15s ease,
    transform .15s ease;
}

.lang-trigger:hover{
  background:rgba(255,255,255,.06);
}

.lang-trigger:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:2px;
  background:rgba(31,122,109,.12);
}

.lang-trigger[aria-expanded="true"]{
  border:1px solid rgba(244, 242, 238, 0.35);
  background:rgba(244, 242, 238, 0.12);
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  transform: translateY(-1px);
}

.lang-current{
  font-weight:500;
  letter-spacing:.02em;
}

/* Dropdown menu (desktop) */
.lang-menu{
  position:absolute;
  top:calc(100% + 10px);
  right:0;

  min-width:180px;
  padding:6px;

  background:#111315;
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;

  box-shadow: 0 20px 50px rgba(0,0,0,.45);
}

.lang-menu[hidden]{
  display:none;
}

.lang-menu li{
  list-style:none;
}

/* Estilo de items dentro del menú (no afecta a .lang button legacy) */
.lang-menu button{
  width:100%;
  text-align:left;

  background:transparent;
  border:0;
  border-radius:8px;

  padding:10px 12px;
  font-size:14px;
  color:var(--fg);
  cursor:pointer;

  transition:
    background-color .12s ease,
    color .12s ease;
}

.lang-menu button:hover{
  background:rgba(255,255,255,.06);
}

.lang-menu button:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:2px;
  background:rgba(31,122,109,.12);
}

.lang-menu button[aria-checked="true"]{
  background:rgba(31,122,109,.18);
  color:var(--fg);
}

/* Mobile sheet */
@media (max-width:720px){
  .lang{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    overflow:visible;
  }

  .lang-menu{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    top:auto;
    margin:0;

    border-radius:16px 16px 0 0;
    padding:16px;

    background:#0f1113;
    box-shadow: 0 -20px 50px rgba(0,0,0,.6);
  }

  .lang-menu button{
    font-size:16px;
    padding:14px 12px;
  }
}

.screen{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8vh 6vw;
}

.content{ max-width:920px; }



h1{
  font-size:clamp(40px,6vw,72px);
  line-height:1.05;
  margin:0 0 24px 0;
}
h2{
  font-size:clamp(28px,4vw,44px);
  margin:0 0 16px 0;
}
.subtitle{
  font-size:18px;
  color:var(--muted);
  margin-bottom:32px;
}

p{
  color:var(--muted);
  font-size:18px;
  line-height:1.5;
}

ul{
  list-style:none;
  padding:0;
  margin:24px 0 0 0;
}


/* CTA */
.cta{
  display:inline-block;
  margin-top:24px;
  padding:14px 26px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  border:0;
  cursor:pointer;

  /* ✅ contrast guard: mantiene legibilidad sobre fondos variables */
  border:1px solid rgba(255,255,255,.10);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.22),
    0 0 0 rgba(0,0,0,0);

  transition:
    transform .12s ease,
    box-shadow .12s ease,
    filter .12s ease,
    background-color .12s ease;
}

.cta:hover{
  transform: translateY(-1px);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.28),
    0 10px 24px rgba(0,0,0,.28);
  filter: brightness(1.05);
}

.cta:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:3px;
  box-shadow: 0 0 0 4px rgba(31,122,109,.25);
}

.cta:active{
  transform: translateY(0);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,.28),
    0 6px 16px rgba(0,0,0,.25);
}

.form{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:24px;
}
.form input,
.form textarea{
  width:100%;
  box-sizing:border-box;
  display:block;
  background:#14181b;
  border:1px solid #222;
  color:var(--fg);
  padding:12px 14px;
  border-radius:8px;
  font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size:15px;
  font-weight:400;
  line-height:1.2;
  letter-spacing:0;
}

.form-grid{
  display:grid;
  gap:14px;
}

.form-field{
  position:relative;
  min-width:0;
}

.form-field--place{
  position:relative;
}

.place-autocomplete{
  position:relative;
  min-width:0;
}

.place-autocomplete__mount{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
}

.place-autocomplete.is-ready .place-autocomplete__mount,
.place-autocomplete.is-open .place-autocomplete__mount{
  pointer-events:auto;
}

.place-autocomplete input[data-place-input]{
  position:relative;
  z-index:1;
  padding-right:46px;
}

.place-autocomplete__clear{
  position:absolute;
  top:50%;
  right:10px;
  transform:translateY(-50%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  padding:0;
  border:0;
  border-radius:999px;
  background:transparent;
  color:rgba(244,242,238,.72);
  cursor:pointer;
  z-index:3;
  -webkit-appearance:none;
  appearance:none;
  touch-action:manipulation;
}

.place-autocomplete__clear:hover{
  background:rgba(255,255,255,.06);
  color:var(--fg);
}

.place-autocomplete__clear:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:2px;
  background:rgba(31,122,109,.10);
  color:var(--fg);
}

.place-autocomplete__clear span{
  display:block;
  line-height:1;
  font-size:20px;
  transform:translateY(-1px);
}

.place-autocomplete__clear[hidden]{
  display:none !important;
}

.place-autocomplete.is-open input[data-place-input]{
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}

.form-field.is-invalid input,
.form-field.is-invalid textarea{
  border-color:#d46a6a;
  box-shadow:0 0 0 1px rgba(212,106,106,.18);
}

.form-field.is-invalid .form-field-icon{
  color:#f0b4b4;
  opacity:1;
}

.form-error{
  position:relative;
  z-index:1;
  margin:8px 0 0;
  font-size:13px;
  line-height:1.45;
  color:#f0b4b4;
}

.form-error[hidden]{
  display:none !important;
}

.form-error--global{
  margin:0 0 16px;
  padding:12px 14px;
  border:1px solid rgba(212,106,106,.32);
  border-radius:10px;
  background:rgba(212,106,106,.08);
  color:#ffd0d0;
}

.form-row{
  display:grid;
  gap:14px;
}

.form-row--two{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.form-actions{
  display:flex;
  align-items:center;
  margin-top:8px;
}

.place-autocomplete__panel{
  position:absolute;
  top:calc(100% - 1px);
  left:0;
  right:0;
  z-index:12;
  overflow:hidden;
  border:1px solid #222;
  border-top:0;
  border-bottom-left-radius:8px;
  border-bottom-right-radius:8px;
  background:#14181b;
  box-shadow:0 18px 32px rgba(0,0,0,.28);
}

.place-autocomplete__panel[hidden]{
  display:none !important;
}

.place-autocomplete__panel.is-visible{
  display:block;
}

.place-autocomplete__status{
  display:block;
  padding:14px 16px;
  font-size:14px;
  line-height:1.45;
  color:var(--muted);
}

.place-autocomplete__status.is-loading{
  color:var(--muted);
}

.place-autocomplete__status.is-empty{
  color:var(--muted);
}

.place-autocomplete__status.is-error{
  color:#f0b4b4;
}

.place-autocomplete__item{
  display:block;
  border-top:1px solid rgba(255,255,255,.06);
}

.place-autocomplete__item:first-child{
  border-top:0;
}

.place-autocomplete__item-button{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
  padding:14px 16px;
  background:transparent;
  border:0;
  color:var(--fg);
  text-align:left;
  cursor:pointer;
  font:inherit;
}

.place-autocomplete__item-button:hover{
  background:rgba(255,255,255,.04);
}

@media (min-width: 721px){
  .place-autocomplete__item-button.is-active{
    background:rgba(31,122,109,.10);
    outline:2px solid rgba(31,122,109,.95);
    outline-offset:-2px;
  }
}

.place-autocomplete__item-button:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:-2px;
  background:rgba(31,122,109,.10);
}

.place-autocomplete__item-title{
  display:block;
  font-size:15px;
  line-height:1.35;
  color:var(--fg);
}

.place-autocomplete__item-subtitle,
.place-autocomplete__item-meta{
  display:block;
  font-size:13px;
  line-height:1.4;
  color:var(--muted);
}

@media (max-width: 720px){
  .place-autocomplete__mount{
    inset:auto 0 auto 0;
    top:100%;
    bottom:auto;
    z-index:12;
    pointer-events:none;
  }

  .place-autocomplete.is-ready .place-autocomplete__mount{
    pointer-events:none;
  }

  .place-autocomplete.is-open .place-autocomplete__mount{
    pointer-events:auto;
  }

  .place-autocomplete__panel{
    position:relative;
    top:auto;
    left:auto;
    right:auto;
    z-index:auto;
    margin-top:6px;
    border-top:1px solid #222;
    border-top-left-radius:8px;
    border-top-right-radius:8px;
    box-shadow:0 18px 32px rgba(0,0,0,.28);
  }

  .place-autocomplete__item-button{
    padding:15px 16px;
  }

  .place-autocomplete input[data-place-input]{
    padding-right:52px;
  }

  .place-autocomplete__clear{
    right:8px;
    width:36px;
    height:36px;
  }
}

.form-actions .cta{
  width:100%;
}

.contact-service-panel[hidden],
.contact-panel-summary[hidden],
.contact-panel-fare[hidden]{
  display:none !important;
}

.contact-service-switcher{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:2px;
}

.contact-service-switcher__button{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  color:var(--fg);
  border-radius:999px;
  padding:10px 14px;
  font:inherit;
  font-size:14px;
  line-height:1.2;
  cursor:pointer;
  transition:
    background-color .15s ease,
    border-color .15s ease,
    color .15s ease,
    transform .15s ease,
    box-shadow .15s ease;
}

.contact-service-switcher__button:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.22);
}

.contact-service-switcher__button:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:3px;
}

.contact-service-switcher__button[data-service-active="true"]{
  background:rgba(31,122,109,.16);
  border-color:rgba(31,122,109,.6);
  color:var(--fg);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.contact-service-panel{
  display:grid;
  gap:12px;
}

.contact-airport-hotel-editor{
  display:grid;
  gap:14px;
  padding:16px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:rgba(255,255,255,.02);
}

.contact-airport-hotel-editor__header{
  display:grid;
  gap:6px;
}

.contact-airport-hotel-editor__header .muted.small{
  margin:0;
}

.contact-airport-hotel-editor__grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 56px minmax(0, 1fr);
  gap:12px;
  align-items:end;
}

.contact-airport-hotel-editor__field{
  display:grid;
  gap:8px;
  min-width:0;
}

.contact-airport-hotel-editor__airport-shell{
  width:100%;
  min-width:0;
}

.contact-airport-hotel-editor__airport-shell .services-expand__control{
  width:100%;
}

.contact-airport-hotel-editor__swap{
  display:flex;
  align-items:center;
  justify-content:center;
  padding-bottom:2px;
}

.contact-airport-hotel-editor__passengers{
  display:grid;
  gap:12px;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-root]{
  position:relative;
  min-width:0;
  z-index:1;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-root].is-open{
  z-index:40;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-input]{
  width:100%;
  min-height:56px;
  padding:0 48px 0 16px;
  border-radius:16px;
  border:1px solid rgba(236,220,189,.30);
  background:rgba(22,18,17,.62);
  color:rgba(255,249,238,.98);
  box-shadow:inset 0 1px 0 rgba(255,248,236,.08);
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-input]::placeholder{
  color:rgba(255,249,238,.64);
  opacity:1;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-mount]{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-root].is-open [data-contact-airport-hotel-hotel-mount]{
  z-index:41;
}

.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-root].is-ready [data-contact-airport-hotel-hotel-mount],
.contact-airport-hotel-editor [data-contact-airport-hotel-hotel-root].is-open [data-contact-airport-hotel-hotel-mount]{
  pointer-events:auto;
}

@media (max-width: 720px){
  .contact-airport-hotel-editor{
    padding:14px;
    border-radius:16px;
  }

  .contact-airport-hotel-editor__grid{
    grid-template-columns:1fr;
    gap:12px;
  }

  .contact-airport-hotel-editor__swap{
    justify-content:center;
    padding-bottom:0;
  }
}

.contact-panel-summary{
  margin-top:10px;
  padding:10px 0 0;
}

.contact-panel-summary__eyebrow{
  margin:0 0 6px;
  font-size:11px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(184,229,214,.98);
}

.contact-panel-summary__text{
  margin:0;
  display:flex;
  align-items:baseline;
  gap:6px;
  flex-wrap:wrap;
  font-size:14px;
  line-height:1.5;
  color:rgba(244,242,238,.84);
}

.contact-panel-summary__zone-label{
  color:rgba(244,242,238,.64);
}

.contact-panel-summary__zone-value{
  color:var(--fg);
  font-weight:700;
}

.contact-panel-fare{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:2px;
  margin-bottom:2px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(247,226,170,.52);
  background:linear-gradient(180deg, rgba(255,242,214,.18) 0%, rgba(255,226,178,.12) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,248,236,.16),
    0 10px 22px rgba(0,0,0,.12);
}

.contact-panel-fare__label{
  margin:0;
  font-size:12px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,245,228,.72);
}

.contact-panel-fare__value{
  display:block;
  margin:0;
  font-size:clamp(24px, 2.8vw, 34px);
  line-height:1.05;
  letter-spacing:-0.03em;
  color:rgba(255,224,140,.98);
}

@media (max-width: 720px){
  .contact-panel-summary{
    margin-top:8px;
    padding-top:8px;
  }

  .contact-panel-summary__eyebrow{
    margin-bottom:5px;
    font-size:10px;
  }

  .contact-panel-summary__text{
    gap:4px;
    font-size:13px;
    line-height:1.45;
  }

  .contact-panel-fare{
    margin-top:0;
    padding:12px 14px;
    border-radius:14px;
  }

  .contact-panel-fare__value{
    font-size:26px;
  }
}

.form-field--date input,
.form-field--time input{
  padding-right:44px;
}

.form input::placeholder,
.form textarea::placeholder{
  color:rgba(244,242,238,.64);
  font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size:15px;
  font-weight:400;
  line-height:1.2;
  letter-spacing:0;
}

.form-field-icon{
  position:absolute;
  top:50%;
  right:14px;
  transform:translateY(-50%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  color:var(--fg);
  opacity:.82;
  pointer-events:none;
  z-index:2;
}

.form-field--date input,
.form-field--time input{
  color-scheme:dark;
  position:relative;
  z-index:2;
  background:transparent;
}

.form-field--date input::-webkit-inner-spin-button,
.form-field--date input::-webkit-clear-button,
.form-field--time input::-webkit-inner-spin-button,
.form-field--time input::-webkit-clear-button{
  display:none;
}

.form-field-overlay{
  display:none;
}

@media (max-width: 720px){
  .form-field-overlay{
    position:absolute;
    left:14px;
    right:44px;
    top:1px;
    bottom:1px;
    display:flex;
    align-items:center;
    color:rgba(244,242,238,.64);
    font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size:15px;
    font-weight:400;
    line-height:1.2;
    letter-spacing:0;
    pointer-events:none;
    user-select:none;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    z-index:1;
    opacity:1;
    transition:opacity .15s ease;
  }

  .form-field--date input,
  .form-field--time input{
    -webkit-appearance:none;
    appearance:none;
  }

  .form-field--date input:focus + .form-field-overlay,
  .form-field--time input:focus + .form-field-overlay,
  .form-field--date input:valid + .form-field-overlay,
  .form-field--time input:valid + .form-field-overlay,
  .form-field.is-invalid .form-field-overlay{
    opacity:0;
  }

  .contact-airport-hotel-editor__date input:valid + .form-field-overlay--date{
    opacity:1;
  }

  .contact-airport-hotel-editor__date input[data-has-value="true"] + .form-field-overlay--date,
  .contact-airport-hotel-editor__date input:focus + .form-field-overlay--date,
  .contact-airport-hotel-editor__date.is-invalid .form-field-overlay--date{
    opacity:0;
  }

  .form-field--date input::-webkit-calendar-picker-indicator,
  .form-field--time input::-webkit-calendar-picker-indicator{
    opacity:0;
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    cursor:pointer;
  }
  
  .form-field--date.is-invalid .form-field-icon{
    transform:translateY(calc(-50% - 24px));
  }

  .form-field--time.is-invalid .form-field-icon{
    transform:translateY(calc(-50% - 12px));
  }
}

@media (min-width: 721px){
  .form-field--date .form-field-icon,
  .form-field--time .form-field-icon{
    display:none;
  }

  .form-field--date input,
  .form-field--time input{
    padding-right:14px;
    -webkit-appearance:auto;
    appearance:auto;
  }

  .form-field--date input:invalid::-webkit-datetime-edit,
  .form-field--time input:invalid::-webkit-datetime-edit{
    color:rgba(244,242,238,.64);
    font-family:Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-size:15px;
    font-weight:400;
    line-height:1.2;
  }

  .form-field--date input:valid::-webkit-datetime-edit,
  .form-field--time input:valid::-webkit-datetime-edit{
    color:var(--fg);
    font-family:Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-size:15px;
    font-weight:400;
    line-height:1.2;
  }

  .form-field--date input::-webkit-calendar-picker-indicator,
  .form-field--time input::-webkit-calendar-picker-indicator{
    opacity:1;
    cursor:pointer;
  }
}

@media (max-width: 720px){
  .form-row--two{
    grid-template-columns:1fr;
  }

  .contact-handoff{
    padding:14px 14px;
    gap:10px;
  }

  .contact-handoff__note{
    max-width:none;
    font-size:13px;
    line-height:1.55;
  }

  .contact-handoff__link{
    width:100%;
    justify-content:center;
    padding:12px 14px;
  }
}

.muted{ color:var(--muted); }
.small{
  font-size:14px;
  margin-top:16px;
  line-height:1.6;
}

.contact-handoff{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  margin-top:14px;
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:rgba(255,255,255,.02);
}

.contact-handoff__note{
  margin:0;
  max-width:760px;
  font-size:14px;
  line-height:1.6;
}

.contact-handoff__link{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0;
  color:var(--fg);
  text-decoration:none;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
  white-space:nowrap;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  transition:
    background-color .15s ease,
    border-color .15s ease,
    transform .15s ease,
    box-shadow .15s ease,
    color .15s ease;
}

.contact-handoff__icon{
  width:18px;
  height:18px;
  display:block;
  object-fit:contain;
  opacity:.92;
  flex:0 0 auto;
}

.contact-handoff__link::after{
  content:"→";
  font-size:14px;
  line-height:1;
  opacity:.9;
}

.contact-handoff__link:hover{
  color:var(--fg);
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.22);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}

.contact-handoff__link:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:3px;
  box-shadow:0 0 0 4px rgba(31,122,109,.18);
}

.contact-handoff__link:active{
  transform:translateY(0);
  box-shadow:none;
}





/* -------------------------------------------------
   FRANJA 6 — CIERRE LEGAL Y FIRMA
   ------------------------------------------------- */

.legal{
  min-height:auto;              /* no pantalla completa */
  padding:10vh 6vw 8vh;
  text-align:center;

  /* fondo editorial oscuro (sin imagen) */
  background-color:#0e0f11;
  background-image:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.015),
      rgba(255,255,255,0.015) 1px,
      transparent 1px,
      transparent 2px
    ),
    linear-gradient(
      180deg,
      rgba(255,255,255,0.04) 0%,
      rgba(255,255,255,0.015) 35%,
      rgba(0,0,0,0.25) 100%
    );
  background-blend-mode:overlay;
}

.legal .content{
  max-width:720px;               /* más estrecho: sensación de cierre */
}

.legal-logo{
  display:block;
  margin:0 auto 32px;
  max-width:220px;               /* firma, no hero */
  width:100%;
  height:auto;
}

.legal address{
  font-style:normal;             /* evitar cursiva por defecto */
  margin:24px 0;
  line-height:1.6;
}

/* ✅ MEJORA: navegación legal con gap real y separadores discretos */
.legal-links{
  margin-top:22px;
  font-size:14px;

  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}

.legal-links span[aria-hidden="true"]{
  color:rgba(244,242,238,.32);
  padding:0 2px;
  transform: translateY(-1px);
}

/* ✅ enlaces legales con look premium + accesibilidad + tap-area */
.legal-links a{
  color:var(--fg);
  text-decoration: underline;
  text-decoration-color: rgba(244,242,238,.55);
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  padding:6px 8px;              /* mejora tap-area sin romper layout */
  border-radius:8px;
}

.legal-links a:hover{
  color:var(--fg);
  text-decoration-color: rgba(31,122,109,.9);
}

.legal-links a:focus-visible{
  outline:2px solid rgba(31,122,109,.95);
  outline-offset:3px;
  text-decoration-color: rgba(31,122,109,.95);
}

.legal-links a:active{
  opacity:.85;
}

/* ✅ Accesibilidad: respetar preferencias de reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  html,body{
    scroll-behavior:auto;
  }
  .cta{
    transition:none;
  }
}
