/* styles.css - Guardar Momentos Quinceañeras */
/* Mobile-first CSS con variables y reset base */
/* Breakpoint base: 390px, Desktop: 1024px */

/* ==========================================================================
   RESET CSS Y ESTILOS BASE
   ========================================================================== */

/* Reset básico */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--fuente-principal);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-texto);
  background-color: var(--color-fondo);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Normalización de elementos comunes */
h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: var(--espacio-sm);
}

p {
  margin-bottom: var(--espacio-sm);
}

a {
  color: var(--color-primario);
  text-decoration: none;
  transition: color 0.3s ease;
}

a:hover {
  color: var(--color-secundario);
}

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

button,
input,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

/* Elementos interactivos - área de toque mínima 44x44px */
button,
a[role="button"],
input[type="submit"],
input[type="button"] {
  min-height: var(--altura-boton);
  min-width: var(--ancho-minimo-boton);
  padding: var(--espacio-xs) var(--espacio-sm);
}

/* ==========================================================================
   VARIABLES CSS EN :root
   ========================================================================== */

:root {
  /* Colores principales - paleta para fotografía de quinceañeras */
  --color-primario: #8B5A2B;        /* Marrón cálido - principal */
  --color-secundario: #D4A76A;      /* Dorado suave - secundario */
  --color-acento: #E8C39E;          /* Beige claro - acento */
  --color-fondo: #FFF9F0;           /* Fondo crema muy claro */
  --color-texto: #333333;           /* Texto oscuro para contraste */
  --color-texto-claro: #666666;     /* Texto secundario */
  --color-borde: #E0D6C9;           /* Borde suave */
  --color-exito: #4CAF50;           /* Verde para confirmaciones */
  --color-error: #F44336;           /* Rojo para errores */
  --color-advertencia: #FF9800;     /* Naranja para advertencias */
  --color-info: #2196F3;            /* Azul para información */

  /* Tipografía */
  --fuente-principal: 'Helvetica Neue', Arial, sans-serif;
  --fuente-secundaria: Georgia, 'Times New Roman', serif;
  --fuente-titulos: 'Playfair Display', Georgia, serif;

  /* Tamaños de fuente - escala modular */
  --tamano-fuente-xs: 0.75rem;      /* 12px */
  --tamano-fuente-sm: 0.875rem;     /* 14px */
  --tamano-fuente-base: 1rem;       /* 16px */
  --tamano-fuente-md: 1.125rem;     /* 18px */
  --tamano-fuente-lg: 1.25rem;      /* 20px */
  --tamano-fuente-xl: 1.5rem;       /* 24px */
  --tamano-fuente-2xl: 2rem;        /* 32px */
  --tamano-fuente-3xl: 2.5rem;      /* 40px */

  /* Espaciado - escala 8px */
  --espacio-xs: 0.5rem;             /* 8px */
  --espacio-sm: 1rem;               /* 16px */
  --espacio-md: 1.5rem;             /* 24px */
  --espacio-lg: 2rem;               /* 32px */
  --espacio-xl: 3rem;               /* 48px */
  --espacio-2xl: 4rem;              /* 64px */

  /* Breakpoints */
  --breakpoint-mobile: 390px;
  --breakpoint-tablet: 768px;
  --breakpoint-desktop: 1024px;
  --breakpoint-wide: 1280px;

  /* Tamaños de elementos interactivos */
  --altura-boton: 44px;
  --ancho-minimo-boton: 44px;
  --radio-borde: 8px;
  --radio-borde-pequeno: 4px;

  /* Sombras */
  --sombra-suave: 0 2px 8px rgba(0, 0, 0, 0.1);
  --sombra-media: 0 4px 12px rgba(0, 0, 0, 0.15);
  --sombra-fuerte: 0 8px 24px rgba(0, 0, 0, 0.2);

  /* Transiciones */
  --transicion-rapida: 0.2s ease;
  --transicion-media: 0.3s ease;
  --transicion-lenta: 0.5s ease;
}

/* ==========================================================================
   ESTILOS MOBILE-FIRST (390px BASE)
   ========================================================================== */

/* Contenedores principales */
.contenedor {
  width: 100%;
  max-width: 100%;
  padding-left: var(--espacio-sm);
  padding-right: var(--espacio-sm);
  margin-left: auto;
  margin-right: auto;
}

/* Utilidades de tipografía */
.texto-centrado {
  text-align: center;
}

.texto-izquierda {
  text-align: left;
}

.texto-derecha {
  text-align: right;
}

.texto-justificado {
  text-align: justify;
}

/* Utilidades de espaciado */
.mt-xs { margin-top: var(--espacio-xs); }
.mt-sm { margin-top: var(--espacio-sm); }
.mt-md { margin-top: var(--espacio-md); }
.mt-lg { margin-top: var(--espacio-lg); }
.mt-xl { margin-top: var(--espacio-xl); }

.mb-xs { margin-bottom: var(--espacio-xs); }
.mb-sm { margin-bottom: var(--espacio-sm); }
.mb-md { margin-bottom: var(--espacio-md); }
.mb-lg { margin-bottom: var(--espacio-lg); }
.mb-xl { margin-bottom: var(--espacio-xl); }

.p-xs { padding: var(--espacio-xs); }
.p-sm { padding: var(--espacio-sm); }
.p-md { padding: var(--espacio-md); }
.p-lg { padding: var(--espacio-lg); }
.p-xl { padding: var(--espacio-xl); }

/* Utilidades de texto */
.texto-claro {
  color: var(--color-texto-claro);
}

.tamano-fuente-sm {
  font-size: var(--tamano-fuente-sm);
}

.tamano-fuente-md {
  font-size: var(--tamano-fuente-md);
}

.tamano-fuente-lg {
  font-size: var(--tamano-fuente-lg);
}

/* Grid básico para móvil */
.grid {
  display: grid;
  gap: var(--espacio-sm);
}

/* Flexbox básico */
.flex {
  display: flex;
}

.flex-columna {
  flex-direction: column;
}

.flex-centrado {
  justify-content: center;
  align-items: center;
}

/* Botones base */
.boton {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--altura-boton);
  min-width: var(--ancho-minimo-boton);
  padding: var(--espacio-xs) var(--espacio-md);
  background-color: var(--color-primario);
  color: white;
  border-radius: var(--radio-borde);
  font-weight: 600;
  transition: all var(--transicion-media);
  text-align: center;
}

.boton:hover {
  background-color: var(--color-secundario);
  transform: translateY(-2px);
  box-shadow: var(--sombra-media);
}

.boton:active {
  transform: translateY(0);
}

.boton-secundario {
  background-color: var(--color-secundario);
}

.boton-secundario:hover {
  background-color: var(--color-acento);
}

/* Formularios base */
.campo-formulario {
  margin-bottom: var(--espacio-md);
}

.campo-formulario label {
  display: block;
  margin-bottom: var(--espacio-xs);
  font-weight: 600;
  color: var(--color-texto);
}

.campo-formulario input,
.campo-formulario select,
.campo-formulario textarea {
  width: 100%;
  padding: var(--espacio-sm);
  border: 2px solid var(--color-borde);
  border-radius: var(--radio-borde-pequeno);
  font-size: var(--tamano-fuente-base);
  transition: border-color var(--transicion-media);
}

.campo-formulario input:focus,
.campo-formulario select:focus,
.campo-formulario textarea:focus {
  outline: none;
  border-color: var(--color-primario);
}

/* Tarjetas */
.tarjeta {
  background: white;
  border-radius: var(--radio-borde);
  padding: var(--espacio-md);
  box-shadow: var(--sombra-suave);
  transition: transform var(--transicion-media), box-shadow var(--transicion-media);
}

.tarjeta:hover {
  transform: translateY(-4px);
  box-shadow: var(--sombra-media);
}

/* ==========================================================================
   MEDIA QUERIES PARA DESKTOP (1024px)
   ========================================================================== */

@media (min-width: 1024px) {
  /* Contenedores más amplios en desktop */
  .contenedor {
    max-width: 1200px;
    padding-left: var(--espacio-lg);
    padding-right: var(--espacio-lg);
  }

  /* Ajustes de tipografía para desktop */
  h1 {
    font-size: var(--tamano-fuente-3xl);
  }

  h2 {
    font-size: var(--tamano-fuente-2xl);
  }

  h3 {
    font-size: var(--tamano-fuente-xl);
  }

  /* Grid de 2 columnas en desktop */
  .grid-2-columnas {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid-3-columnas {
    grid-template-columns: repeat(3, 1fr);
  }

  .grid-4-columnas {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Flexbox para desktop */
  .flex-desktop-fila {
    flex-direction: row;
  }

  .flex-desktop-columna {
    flex-direction: column;
  }

  /* Espaciado aumentado para desktop */
  .mt-lg-desktop { margin-top: var(--espacio-xl); }
  .mb-lg-desktop { margin-bottom: var(--espacio-xl); }
  
  .p-lg-desktop { padding: var(--espacio-xl); }

  /* Botones más grandes en desktop */
  .boton-grande {
    padding: var(--espacio-sm) var(--espacio-lg);
    font-size: var(--tamano-fuente-md);
  }

  /* Formularios optimizados para desktop */
  .formulario-desktop {
    max-width: 600px;
    margin: 0 auto;
  }

  /* Layout específico para el cotizador */
  .cotizador-contenedor {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: var(--espacio-lg);
  }

  .cotizador-panel-precio {
    position: sticky;
    top: var(--espacio-lg);
    align-self: start;
  }
}

/* ==========================================================================
   MEDIA QUERY PARA TABLET (768px) - Opcional
   ========================================================================== */

@media (min-width: 768px) and (max-width: 1023px) {
  .contenedor {
    max-width: 720px;
    padding-left: var(--espacio-md);
    padding-right: var(--espacio-md);
  }

  .grid-tablet-2-columnas {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ==========================================================================
   UTILIDADES DE VISIBILIDAD
   ========================================================================== */

.oculto-movil {
  display: none;
}

.oculto-desktop {
  display: block;
}

@media (min-width: 1024px) {
  .oculto-movil {
    display: block;
  }
  
  .oculto-desktop {
    display: none;
  }
}

/* ==========================================================================
   ESTILOS ESPECÍFICOS PARA ACCESIBILIDAD
   ========================================================================== */

/* Enfoque visible para navegación con teclado */
:focus-visible {
  outline: 3px solid var(--color-primario);
  outline-offset: 2px;
}

/* Contraste para texto */
.texto-alto-contraste {
  color: var(--color-texto);
  font-weight: 600;
}

/* Texto para screen readers */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ==========================================================================
   ANIMACIONES SUAVES
   ========================================================================== */

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animacion-entrada {
  animation: fadeIn 0.5s ease forwards;
}

.animacion-retraso-1 {
  animation-delay: 0.1s;
}

.animacion-retraso-2 {
  animation-delay: 0.2s;
}

.animacion-retraso-3 {
  animation-delay: 0.3s;
}

/* ==========================================================================
   ESTILOS DEL COTIZADOR INTERACTIVO
   ========================================================================== */

/* Contenedor principal del cotizador */
.cotizador-contenedor {
  margin: var(--espacio-xl) 0;
  background: white;
  border-radius: var(--radio-borde);
  box-shadow: var(--sombra-media);
  overflow: hidden;
}

/* Pantallas del cotizador */
.cotizador-pantallas {
  padding: var(--espacio-lg);
}

.cotizador-pantalla {
  animation: fadeIn 0.3s ease forwards;
}

.cotizador-contenido {
  max-width: 800px;
  margin: 0 auto;
}

.cotizador-titulo {
  font-family: var(--fuente-titulos);
  color: var(--color-primario);
  margin-bottom: var(--espacio-lg);
  text-align: center;
  font-size: var(--tamano-fuente-xl);
}

.cotizador-intro {
  background-color: var(--color-fondo);
  padding: var(--espacio-md);
  border-radius: var(--radio-borde-pequeno);
  margin-bottom: var(--espacio-lg);
  border-left: 4px solid var(--color-secundario);
}

/* Opciones del cotizador */
.cotizador-opciones {
  display: flex;
  flex-direction: column;
  gap: var(--espacio-sm);
}

.cotizador-opcion {
  position: relative;
}

.cotizador-radio {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.cotizador-opcion-label {
  display: block;
  padding: var(--espacio-md);
  background-color: var(--color-fondo);
  border: 2px solid var(--color-borde);
  border-radius: var(--radio-borde);
  cursor: pointer;
  transition: all var(--transicion-media);
}

.cotizador-opcion-label:hover {
  border-color: var(--color-secundario);
  background-color: rgba(212, 167, 106, 0.1);
}

.cotizador-radio:checked + .cotizador-opcion-label {
  border-color: var(--color-primario);
  background-color: rgba(139, 90, 43, 0.1);
  box-shadow: 0 0 0 1px var(--color-primario);
}

.cotizador-opcion-texto {
  display: block;
  font-weight: 600;
  color: var(--color-texto);
  margin-bottom: var(--espacio-xs);
  font-size: var(--tamano-fuente-md);
}

.cotizador-opcion-descripcion {
  display: block;
  color: var(--color-texto-claro);
  font-size: var(--tamano-fuente-sm);
}

/* Placeholder para pantallas no implementadas */
.cotizador-placeholder {
  background-color: var(--color-fondo);
  padding: var(--espacio-xl);
  border-radius: var(--radio-borde);
  text-align: center;
  border: 2px dashed var(--color-borde);
}

/* Navegación del cotizador */
.cotizador-navegacion {
  background-color: var(--color-fondo);
  padding: var(--espacio-md);
  border-top: 2px solid var(--color-borde);
  position: sticky;
  bottom: 0;
  z-index: 10;
}

.cotizador-precio-container {
  margin-bottom: var(--espacio-md);
}

.cotizador-precio {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: white;
  padding: var(--espacio-md);
  border-radius: var(--radio-borde);
  box-shadow: var(--sombra-suave);
}

.cotizador-precio-label {
  font-weight: 600;
  color: var(--color-texto);
  font-size: var(--tamano-fuente-md);
}

.cotizador-precio-valor {
  font-family: var(--fuente-titulos);
  font-size: var(--tamano-fuente-xl);
  font-weight: 700;
  color: var(--color-primario);
}

.cotizador-botones {
  display: flex;
  justify-content: space-between;
  gap: var(--espacio-sm);
}

/* Botón deshabilitado */
.boton-deshabilitado {
  opacity: 0.5;
  cursor: not-allowed;
}

.boton-deshabilitado:hover {
  transform: none;
  background-color: var(--color-primario);
}

/* Error del cotizador */
.cotizador-error {
  margin: var(--espacio-lg) 0;
  animation: fadeIn 0.5s ease forwards;
}

/* Subtítulo del cotizador */
.cotizador-subtitulo {
  font-family: var(--fuente-titulos);
  color: var(--color-primario);
  margin-bottom: var(--espacio-md);
  font-size: var(--tamano-fuente-lg);
}

/* Precio en opciones del cotizador */
.cotizador-opcion-precio {
  display: block;
  font-weight: 700;
  color: var(--color-primario);
  font-size: var(--tamano-fuente-md);
  margin-top: var(--espacio-xs);
}

/* Input numérico del cotizador */
.cotizador-input-numerico {
  width: 100px;
  text-align: center;
  padding: var(--espacio-sm);
  border: 2px solid var(--color-borde);
  border-radius: var(--radio-borde-pequeno);
  font-size: var(--tamano-fuente-base);
  transition: border-color var(--transicion-media);
}

.cotizador-input-numerico:focus {
  outline: none;
  border-color: var(--color-primario);
}

/* Input de texto del cotizador */
.cotizador-input-texto {
  width: 100%;
  padding: var(--espacio-sm);
  border: 2px solid var(--color-borde);
  border-radius: var(--radio-borde-pequeno);
  font-size: var(--tamano-fuente-base);
  transition: border-color var(--transicion-media);
}

.cotizador-input-texto:focus {
  outline: none;
  border-color: var(--color-primario);
}

/* Input de archivo del cotizador */
.cotizador-input-archivo {
  width: 100%;
  padding: var(--espacio-sm);
  border: 2px solid var(--color-borde);
  border-radius: var(--radio-borde-pequeno);
  font-size: var(--tamano-fuente-base);
  background-color: white;
  cursor: pointer;
  transition: border-color var(--transicion-media);
}

.cotizador-input-archivo:hover {
  border-color: var(--color-secundario);
}

.cotizador-input-archivo:focus {
  outline: none;
  border-color: var(--color-primario);
}

/* Nombre de archivo seleccionado */
.nombre-archivo {
  font-weight: 600;
  color: var(--color-primario);
}

/* Utilidades de margen */
.ml-sm { margin-left: var(--espacio-sm); }
.mr-sm { margin-right: var(--espacio-sm); }
.ml-md { margin-left: var(--espacio-md); }
.mr-md { margin-right: var(--espacio-md); }

/* Media queries para desktop */
@media (min-width: 1024px) {
  .cotizador-contenedor {
    margin: var(--espacio-2xl) 0;
  }
  
  .cotizador-pantallas {
    padding: var(--espacio-xl);
  }
  
  .cotizador-titulo {
    font-size: var(--tamano-fuente-2xl);
  }
  
  .cotizador-opciones {
    gap: var(--espacio-md);
  }
  
  .cotizador-opcion-label {
    padding: var(--espacio-lg);
  }
  
  .cotizador-opcion-texto {
    font-size: var(--tamano-fuente-lg);
  }
  
  .cotizador-precio {
    padding: var(--espacio-lg);
  }
  
  .cotizador-precio-label {
    font-size: var(--tamano-fuente-lg);
  }
  
  .cotizador-precio-valor {
    font-size: var(--tamano-fuente-2xl);
  }
  
  .cotizador-botones {
    gap: var(--espacio-md);
  }
  
  .cotizador-navegacion {
    padding: var(--espacio-lg);
  }
  
  .cotizador-subtitulo {
    font-size: var(--tamano-fuente-xl);
  }
  
  .cotizador-opcion-precio {
    font-size: var(--tamano-fuente-lg);
  }
}