: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; }

/* backgrounds */
.hero{
  background:
    radial-gradient(60% 60% at 50% 40%, rgba(26,29,32,.45), rgba(15,17,19,.92)),
    url("../img/hero-night-cdmx.webp") center/cover no-repeat;
}

/* ✅ FIX responsive-safe: evitar que el selector de idioma fijo pise el hero */
.screen.hero{
  padding-top: calc(8vh + clamp(44px, 6vw, 64px));
}

.local{
  background:
    linear-gradient(180deg, rgba(15,17,19,.65), rgba(20,24,27,.92)),
    url("../img/cdmx-angel-night.webp") center/cover no-repeat;
}

/* FRANJA 3 — mantener EXACTO el asset que ya funciona */
.standard{
  background:
    linear-gradient(180deg, rgba(15,17,19,.35), rgba(15,17,19,.72)),
    url("../img/standard-silence.webp") center/cover no-repeat;
}

/* FRANJA 4 — CDMX blur editorial (nuevo fondo) */
.services{
  background:
    linear-gradient(180deg, rgba(15,17,19,.82), rgba(15,17,19,.92)),
    url("../img/cdmx-city-blur-night.webp") center/cover no-repeat;
}

.contact{ background:#0f1113; }

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;
}
.services ul{
  margin-bottom:18px;
}

/* ✅ MEJORA: layout consistente para servicios (responsive-safe) */
.services li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:20px;
  margin:10px 0;
}

.services li svg{
  flex:0 0 auto;
  margin:0 !important;           /* neutraliza márgenes inline */
  vertical-align:baseline !important;
  opacity:.75;
  color:var(--fg);
}

.services li span{
  display:block;
  min-width: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:auto;
  }

  .place-autocomplete__panel{
    position:relative;
    top:auto;
    left:auto;
    right:auto;
    z-index:auto;
    margin-top:0;
    border-top:1px solid #222;
    border-top-left-radius:0;
    border-top-right-radius:0;
    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%;
}

.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;
  }

  .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;
}

/* ✅ breakpoint suave para densidad/legibilidad */
@media (max-width:900px){
  .services ul{ margin-top:18px; }
  .services li{
    font-size:18px;
    margin:8px 0;
    gap:10px;
  }
}

/* -------------------------------------------------
   SERVICES CARDS — desktop 2+3 / mobile stacked
   ------------------------------------------------- */

.services .content{
  max-width:1120px;
}

.services-cards{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:18px;
  margin-top:28px;
}

.service-card{
  grid-column:span 2;
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding:24px 22px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow:0 18px 36px rgba(0,0,0,.18);
}

.service-card--featured{
  grid-column:span 3;
  padding:28px 26px 24px;
}

.service-card__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  margin-bottom:18px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:var(--fg);
  opacity:.92;
}

.service-card__icon svg{
  display:block;
}

.service-card__title{
  margin:0 0 12px;
  font-size:24px;
  line-height:1.15;
  letter-spacing:-0.02em;
}

.service-card__text{
  margin:0 0 18px;
  font-size:16px;
  line-height:1.55;
  color:var(--muted);
}

.service-card__bullets{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.service-card__bullets li{
  position:relative;
  padding-left:16px;
  margin:0;
  font-size:15px;
  line-height:1.5;
  color:var(--fg);
}

.service-card__bullets li::before{
  content:"";
  position:absolute;
  left:0;
  top:.58em;
  width:6px;
  height:6px;
  border-radius:999px;
  background:rgba(244,242,238,.72);
}

.service-card__price{
  margin-top:auto;
  padding-top:20px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.service-card__price-label{
  font-size:12px;
  line-height:1.2;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(244,242,238,.64);
}

.service-card__price-value{
  font-size:22px;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--fg);
}

/* Tablet / compact desktop */
@media (max-width: 1024px){
  .services-cards{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:16px;
  }

  .service-card,
  .service-card--featured{
    grid-column:span 1;
  }

  .service-card--featured{
    padding:26px 24px 22px;
  }
}

/* Mobile */
@media (max-width: 720px){
  .services .content{
    max-width:none;
  }

  .services-cards{
    grid-template-columns:1fr;
    gap:14px;
    margin-top:22px;
  }

  .service-card,
  .service-card--featured{
    grid-column:auto;
    padding:20px 18px 18px;
    border-radius:18px;
  }

  .service-card--featured{
    padding:22px 18px 20px;
  }

  .service-card__icon{
    width:38px;
    height:38px;
    margin-bottom:14px;
  }

  .service-card__title{
    margin-bottom:10px;
    font-size:22px;
  }

  .service-card__text{
    margin-bottom:14px;
    font-size:15px;
    line-height:1.5;
  }

  .service-card__bullets{
    gap:7px;
  }

  .service-card__bullets li{
    font-size:14px;
    line-height:1.45;
  }

  .service-card__price{
    padding-top:16px;
  }

  .service-card__price-value{
    font-size:20px;
  }
}

/* -------------------------------------------------
   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;
  }
}
