/* ==========================================================================
   Archivo: mto_base.css
   Fecha: 2026-01-31 (actualizado 2026-02-05)
   Template asociado: tienda.html
   Objetivo: tokens, reset moderno, tipografía base, focus-visible, fondo consistente
   Validación realizada: sin !important, selectores simples, mobile-first
   Estándares: HTML5, CSS moderno 2026+, accesible
   ========================================================================== */

/* =========================================================
   TIPOGRAFÍA GLOBAL (OBLIGATORIA)
   Ubicación: statics/css/fonts/
   ========================================================= */

@font-face{
  font-family: "Montserrat Tiendalo";
  src: url("fonts/Montserrat-Regular_tiendalo.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face{
  font-family: "Montserrat Tiendalo";
  src: url("fonts/Montserrat-Bold_tiendalo.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root{
  /* Marca */
  --mto_color_marca: #5af139;

  /* Neutros */
  --mto_color_texto: #0b0b0b;
  --mto_color_fondo: #ffffff;
  --mto_color_superficie: #ffffff;
  --mto_color_borde: rgba(15, 15, 15, 0.12);
  --mto_color_sombra: rgba(0, 0, 0, 0.14);

  /* Focus */
  --mto_color_focus: #111111;

  /* Radios */
  --mto_radio_xl: 22px;
  --mto_radio_md: 14px;
  --mto_radio_sm: 10px;

  /* Espaciado */
  --mto_esp_1: 4px;
  --mto_esp_2: 8px;
  --mto_esp_3: 12px;
  --mto_esp_4: 16px;
  --mto_esp_5: 20px;
  --mto_esp_6: 24px;
  --mto_esp_7: 32px;

  /* Tipografía (✅ Montserrat SIEMPRE) */
  --mto_fuente_sistema: "Montserrat Tiendalo", system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  --mto_tamano_base: clamp(15px, 1.1vw, 16px);
  --mto_altura_linea: 1.45;
}

*,
*::before,
*::after{
  box-sizing: border-box;
}

html{
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body{
  margin: 0;
  font-family: var(--mto_fuente_sistema);
  font-size: var(--mto_tamano_base);
  line-height: var(--mto_altura_linea);
  color: var(--mto_color_texto);
  background: var(--mto_color_fondo);
  overflow-x: hidden;
}

img,
svg,
video{
  max-width: 100%;
  height: auto;
  display: block;
}

a{
  color: inherit;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

a:hover{
  text-decoration: none;
}

:focus-visible{
  outline: 2px solid var(--mto_color_focus);
  outline-offset: 3px;
  border-radius: 10px;
}

/* Accesibilidad: oculto visual pero accesible */
.mto_oculto_visualmente{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* =========================================================
   FIX TEMPORAL — Páginas aisladas (login / registro / reset)
   Oculta NAV y FOOTER MTO sin tocar HTML ni JS
   ========================================================= */

/* Login */
body.login-isolated .mto_encabezado,
body.login-isolated footer{
  display: none;
}

/* Reset password */
body.resetpass-isolated .mto_encabezado,
body.resetpass-isolated footer{
  display: none;
}

/* Validar email */
body.validar-isolated .mto_encabezado,
body.validar-isolated footer{
  display: none;
}

/* Reactivar cuenta (si no tiene clase propia aún) */
body.reactivate-isolated .mto_encabezado,
body.reactivate-isolated footer{
  display: none;
}

/* Seguridad extra: si algún template no tiene class pero usa layout aislado */
body[class*="isolated"] .mto_encabezado,
body[class*="isolated"] footer{
  display: none;
}
