/* =========================
   Velora Massa – estilos base (actualizado)
   Archivo: assets/css/velora.css
   ========================= */

/* Tipografías */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Text:ital@0;1&family=Open+Sans:wght@400;600&display=swap');

/* Paleta y tokens */
:root {
  --vm-color-primary: #473B72;
  --vm-color-secondary: #F8D8B7;
  --vm-color-bg: #FFFDF9;
  --vm-color-text: #1C1B1F;
  --vm-color-border: #E4E1EC;

  --vm-radius: 14px;
  --vm-shadow: 0 8px 18px rgba(0,0,0,0.06), 0 2px 6px rgba(0,0,0,0.04);
  --vm-gap: 14px;
}

/* Reset suave */
#vm-app, #vm-app * {
  box-sizing: border-box;
}

/* Contenedor */
.vm-container {
  max-width: 720px;
  margin: 32px auto 120px;
  padding: 0 18px;
  color: var(--vm-color-text);
  background: transparent;
  line-height: 1.35;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Header */
.vm-header {
  text-align: center;
  margin-bottom: 18px;
  padding: 18px 12px;
  background: var(--vm-color-bg);
  border-radius: var(--vm-radius);
}

.vm-title {
  font-family: "DM Serif Text", Georgia, serif;
  font-size: 38px;
  color: var(--vm-color-primary);
  margin: 0 0 8px;
}

.vm-subtitle {
  margin: 0;
  color: #5c5b61;
  font-size: 16px;
}

/* Cards */
.vm-card {
  background: #fff;
  border: 1px solid var(--vm-color-border);
  border-radius: var(--vm-radius);
  box-shadow: var(--vm-shadow);
  padding: 18px;
  margin: 16px 0;
}

.vm-card-title {
  font-family: "DM Serif Text", Georgia, serif;
  color: var(--vm-color-primary);
  font-size: 20px;
  margin: 0 0 12px;
}

.vm-card-title .vm-subnote {
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  display: block;          /* fuerza salto de línea */
  margin-top: 4px;
  font-size: 12px;       
  font-weight: 400;
  color: var(--vm-color-primary);
}

/* Opciones */
.vm-options {
  display: grid;
  gap: 12px;
}

.vm-option {
  display: grid;
  grid-template-columns: 24px 1fr;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--vm-color-border);
  border-radius: 12px;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
  cursor: pointer;
}

.vm-option:hover {
  border-color: #d6d2e3;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.vm-option input[type="radio"],
.vm-option input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--vm-color-primary);
  cursor: pointer;
}

.vm-option span {
  font-weight: 600;
  color: var(--vm-color-text);
}

.vm-option .vm-note {
  grid-column: 2 / -1;
  font-size: 12px;
  color: #6b6a70;
  margin-top: 4px;
}

/* Grids */
.vm-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr; /* 2 columnas en pantallas grandes */
  gap: var(--vm-gap);
}

.vm-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 columnas en desktop */
  gap: var(--vm-gap);
}

/* Responsive */
@media (max-width: 560px) {
  .vm-grid-2 {
    grid-template-columns: 1fr; /* Rellenos → 1 columna en móvil */
  }
}

@media (max-width: 900px) {
  .vm-grid-3 {
    grid-template-columns: 1fr; /* Decoración → 1 columna en móvil */
  }
}

/* Footer del cotizador: sticky dentro del contenedor */
#vm-app .vm-footer {
  position: sticky;     /* clave: deja de ser fixed global */
  bottom: 0;            /* se pega al borde inferior de la ventana */
  z-index: 5;           /* suficiente para sobresalir del contenido del cotizador */
  background: var(--vm-color-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 14px 16px;
  box-shadow: 0 -8px 18px rgba(0,0,0,0.10);
  border-radius: 12px;  /* opcional, se ve “flotado” dentro del área */
  margin: 8px 0;        /* separa un poco del borde del viewport */
}

/* Reserva espacio al final del cotizador para que el sticky no tape el último contenido */
#vm-app .vm-container,
#vm-app {
  padding-bottom: 90px; /* aprox. la altura del footer dentro del widget */
}

/* (opcional) en pantallas grandes, limítalo al ancho del contenido */
@media (min-width: 768px) {
  #vm-app .vm-footer {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Impresión: sigue ocultándose */
@media print {
  #vm-app .vm-footer { display: none !important; }
}

.vm-total {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 16px;
}

#vm-total-amount {
  font-size: 18px;
  font-weight: 700;
}

.vm-btn {
  border: 0;
  padding: 10px 16px;
  border-radius: 999px;
  background: var(--vm-color-secondary);
  color: var(--vm-color-primary);
  font-weight: 700;
  cursor: pointer;
  transition: transform .05s ease, box-shadow .1s ease, background .15s ease;
  box-shadow: 0 6px 14px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.06);
}
.vm-btn:hover { transform: translateY(-1px); }
.vm-btn:active { transform: translateY(0); }

/* Accesibilidad */
.vm-option:has(input:focus-visible),
.vm-btn:focus-visible {
  outline: 2px solid #b7a9df;
  outline-offset: 2px;
}

/* Print */
@media print {
  .vm-footer { display: none !important; }
  .vm-container { margin: 0; max-width: 100%; }
  .vm-card { box-shadow: none; border-color: #ddd; }
}

/* ===== Overlay / Resumen en la misma página ===== */
.vm-overlay[hidden] { display: none !important; }
.vm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 20px;
}

.vm-summary {
  width: min(680px, 100%);
  background: #fff;
  border: 1px solid var(--vm-color-border);
  border-radius: var(--vm-radius);
  box-shadow: var(--vm-shadow);
  padding: 20px;
}

.vm-summary-title {
  margin: 0 0 8px;
  font-family: "DM Serif Text", Georgia, serif;
  color: var(--vm-color-primary);
}

.vm-summary-body p { margin: 6px 0; }
.vm-summary-body ul { margin: 6px 0 0; padding-left: 18px; }
.vm-summary-total { margin-top: 12px; font-weight: 700; color: var(--vm-color-primary); }

.vm-actions {
  display: flex; gap: 10px; justify-content: flex-end; margin-top: 16px;
}
.vm-btn-secondary {
  background: #eee; color: #333; box-shadow: none;
}

/* Imprimir: mostrar sólo el resumen, ocultar resto */
@media print {
  #vm-app > *:not(.vm-overlay) { display: none !important; }
  .vm-overlay {
    position: static; background: none; padding: 0;
  }
  .vm-summary {
    border: none; box-shadow: none; padding: 0;
  }
  .vm-actions { display: none !important; }
  .vm-footer { display: none !important; }
}

