/* calculadora-parrilla.css — Herrería La Roseta
   UI pública del cotizador. Prefijo lr-calc-. SCOPED bajo .lr-calc.
   Sin valores de negocio (costos, coeficientes, etc.).

   Layout inspirado en el mockup aprobado:
   - Columna principal IZQUIERDA (ancha): formulario + resultado.
   - Columna lateral DERECHA (angosta): guía visual interactiva en panel oscuro.
   Paleta nativa al HOME: crema cálido con más contraste, acentos cobre/rose-gold,
   chocolate del header en CTA y panel lateral. Tipografías Playfair + Montserrat. */

.lr-calc {
  /* Acento de marca */
  /* Acentos alineados a la paleta del sitio (css/style.css), con fallback
     para que _test-calc.php funcione aunque no cargue style.css. */
  --lrc-copper: var(--cobre-sombra, #8E5E43);      /* cobre oscuro de marca: texto/acentos (mantiene contraste) */
  --lrc-copper-soft: var(--cobre-base, #B97A57);   /* cobre base de marca: hover / bordes vivos */
  --lrc-gold: var(--cobre-luz, #D9A27C);
  --lrc-gold-lt: var(--cobre-luz, #D9A27C);
  /* Superficies cálidas — SE MANTIENEN (no se enfrían a #F4F1F4) */
  --lrc-paper: #E8DECF;
  --lrc-card: #FFFFFF;
  --lrc-card-2: #F8F3EC;
  --lrc-cream: #F5EBE2;
  /* Grafito del sitio para el CTA principal y el panel oscuro de la guía */
  --lrc-choco: var(--grafito-strong, #1D1D1D);
  --lrc-choco-2: var(--grafito, #2F2F2F);
  /* Tinta */
  --lrc-ink: #262321;
  --lrc-ink-2: #5C564F;
  --lrc-ink-3: #837B72;
  --lrc-on-dark: rgba(246, 240, 232, .86);
  --lrc-on-dark-2: rgba(246, 240, 232, .55);
  /* Bordes / sombras */
  --lrc-line: rgba(64, 59, 54, .14);
  --lrc-line-2: rgba(64, 59, 54, .20);
  --lrc-line-gold: rgba(185, 122, 87, .32);        /* tinte de borde derivado de --cobre-base (#B97A57) */
  --lrc-danger: #B03A2E;
  --lrc-sh-sm: 0 4px 14px rgba(60, 48, 34, .10);
  --lrc-sh-md: 0 14px 34px rgba(60, 48, 34, .16);

  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--lrc-ink);
  background:
    radial-gradient(820px 220px at 14% -12%, rgba(166, 106, 85, .12), transparent 60%),
    linear-gradient(180deg, #EFE6D8, #E2D7C5);
  border: 1px solid var(--lrc-line-gold);
  border-radius: 18px;
  padding: clamp(18px, 3vw, 30px);
  box-shadow: var(--lrc-sh-md);
  max-width: 920px;
  margin: 0 auto;
  box-sizing: border-box;
}
.lr-calc *,
.lr-calc *::before,
.lr-calc *::after { box-sizing: border-box; }

/* ── Encabezado ── */
.lr-calc-head { margin: 0 0 14px; }
.lr-calc-kicker {
  display: inline-block;
  font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--lrc-copper);
  margin: 0 0 9px;
}
.lr-calc-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(22px, 3vw, 31px);
  font-weight: 700; line-height: 1.14; letter-spacing: .005em;
  color: var(--lrc-ink);
  margin: 0 0 7px;
}
.lr-calc-intro { font-size: 13px; line-height: 1.55; color: var(--lrc-ink-2); margin: 0; max-width: 60ch; }

/* ══════════════ LAYOUT: principal (izq) + lateral (der) ══════════════ */
.lr-calc-layout { display: grid; grid-template-columns: 1fr; gap: 18px; }
.lr-calc-main { min-width: 0; display: flex; flex-direction: column; gap: 13px; }
.lr-calc-side { min-width: 0; display: flex; flex-direction: column; gap: 16px; }

/* ── Grupos del formulario: tarjeta clara, contraste contra el fondo ── */
.lr-calc-group {
  position: relative;
  min-width: 0;
  border: 1px solid var(--lrc-line-2);
  background: linear-gradient(180deg, #FFFFFF, #FBF8F2);
  border-radius: 14px;
  margin: 0;
  padding: 22px 22px 20px;
  box-shadow: 0 6px 18px rgba(60, 48, 34, .09);
}
/* Título de sección: <p> normal DENTRO de la card (ya NO es <legend>, sin straddle) */
.lr-calc-legend {
  display: block; width: 100%; float: none; position: static; transform: none;
  font-size: 11px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase;
  color: var(--lrc-copper);
  padding: 0; margin: 0 0 13px;
}
.lr-calc-help { font-size: 11.5px; line-height: 1.5; color: var(--lrc-ink-3); margin: 0 0 11px; }
.lr-calc-note { font-size: 11.5px; line-height: 1.5; color: var(--lrc-copper); margin: 11px 0 0; }

/* ── Medidas ── */
.lr-calc-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lr-calc-field { display: flex; flex-direction: column; gap: 6px; }
.lr-calc-label { font-size: 12px; font-weight: 600; color: var(--lrc-ink-2); }
.lr-calc-inputwrap { position: relative; }
.lr-calc-unit {
  position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
  font-size: 13px; font-weight: 600; color: var(--lrc-ink-3); pointer-events: none;
}
.lr-calc-input {
  font-family: inherit; font-size: 15px; color: var(--lrc-ink);
  background: var(--lrc-card);
  border: 1px solid var(--lrc-line-2);
  border-radius: 10px;
  padding: 11px 13px; width: 100%; min-height: 44px;
  transition: border-color .15s, box-shadow .15s;
}
.lr-calc-inputwrap .lr-calc-input { padding-right: 32px; }
.lr-calc-input::placeholder { color: var(--lrc-ink-3); }
.lr-calc-input:hover { border-color: var(--lrc-line-gold); }
.lr-calc-input:focus-visible {
  outline: none; border-color: var(--lrc-copper-soft);
  box-shadow: 0 0 0 3px rgba(166, 106, 85, .18);
}

/* ── Opciones tipo CARD: grilla pareja (mismo alto y ancho) ── */
.lr-calc-options { display: grid; grid-template-columns: repeat(2, 1fr); gap: 9px; }
.lr-calc-opt { position: relative; display: flex; }
.lr-calc-opt input { position: absolute; opacity: 0; width: 1px; height: 1px; pointer-events: none; }
.lr-calc-opt label {
  flex: 1;
  display: flex; flex-direction: column; justify-content: center; gap: 2px;
  align-items: flex-start; text-align: left;
  min-height: 56px; cursor: pointer;
  font-size: 12.5px; font-weight: 600; line-height: 1.28;
  color: var(--lrc-ink-2);
  background: var(--lrc-card-2);
  border: 1px solid var(--lrc-line-2);
  border-radius: 12px;
  padding: 10px 36px 10px 13px;
  transition: transform .14s, border-color .14s, color .14s, background .14s, box-shadow .14s;
}
.lr-calc-opt-t { font-size: 12.5px; font-weight: 700; color: var(--lrc-ink); line-height: 1.2; }
.lr-calc-opt-s { font-size: 10.5px; font-weight: 600; color: var(--lrc-ink-3); line-height: 1.25; }
.lr-calc-opt label:hover {
  transform: translateY(-1px);
  border-color: var(--lrc-copper-soft);
  box-shadow: var(--lrc-sh-sm);
}
/* Indicador (anillo) */
.lr-calc-opt label::after {
  content: "";
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px; border-radius: 50%;
  border: 1.5px solid var(--lrc-line-2);
  background: var(--lrc-card);
  transition: border-color .14s, background .14s;
}
/* SELECCIONADO: borde cobre + tinte cálido + check */
.lr-calc-opt input:checked + label {
  border-color: var(--lrc-copper);
  background: var(--lrc-cream);
  box-shadow: 0 0 0 1px var(--lrc-copper), 0 8px 20px rgba(143, 89, 72, .16);
}
.lr-calc-opt input:checked + label .lr-calc-opt-s { color: var(--lrc-copper); }
.lr-calc-opt input:checked + label::after {
  border-color: var(--lrc-copper);
  background: var(--lrc-copper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / 10px 10px no-repeat;
}
.lr-calc-opt input:focus-visible + label { outline: 2px solid var(--lrc-copper); outline-offset: 2px; }

/* ── Contadores de cajones ── */
.lr-calc-counters { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lr-calc-counter {
  display: flex; align-items: center;
  background: var(--lrc-card); border: 1px solid var(--lrc-line-2);
  border-radius: 10px; overflow: hidden;
}
.lr-calc-counter .lr-calc-cbtn {
  font-family: inherit; font-size: 18px; line-height: 1;
  width: 42px; height: 44px; flex: 0 0 42px; cursor: pointer;
  color: var(--lrc-copper); background: var(--lrc-card-2);
  border: 0; transition: background .14s, color .14s;
  touch-action: manipulation; -webkit-user-select: none; user-select: none;
}
.lr-calc-counter .lr-calc-input { flex: 1 1 auto; min-width: 0; }
.lr-calc-counter .lr-calc-cbtn:hover { background: var(--lrc-cream); color: var(--lrc-copper-soft); }
.lr-calc-counter .lr-calc-cbtn:focus-visible { outline: 2px solid var(--lrc-copper); outline-offset: -2px; }
.lr-calc-counter .lr-calc-input {
  text-align: center; border: 0; border-radius: 0; background: transparent;
  min-height: 44px; -moz-appearance: textfield;
}
.lr-calc-counter .lr-calc-input:focus-visible { outline: none; box-shadow: none; }

/* ── CTA principal (chocolate + borde cobre) ── */
.lr-calc-actions { margin-top: 4px; }
.lr-calc-submit {
  font-family: inherit; font-size: 14.5px; font-weight: 800; letter-spacing: .02em;
  color: #F6F0E8; cursor: pointer; width: 100%; min-height: 52px;
  padding: 14px 22px; border: 1.5px solid var(--lrc-copper-soft); border-radius: 13px;
  background: linear-gradient(180deg, var(--lrc-choco-2), var(--lrc-choco));
  box-shadow: 0 12px 26px rgba(43, 41, 38, .28), inset 0 1px 0 rgba(255, 255, 255, .06);
  transition: filter .15s, transform .1s, box-shadow .15s, border-color .15s;
}
.lr-calc-submit:hover:not(:disabled) { filter: brightness(1.12); border-color: var(--lrc-copper); }
.lr-calc-submit:active:not(:disabled) { transform: translateY(1px); }
.lr-calc-submit:focus-visible { outline: 2px solid var(--lrc-copper); outline-offset: 3px; }
.lr-calc-submit:disabled { opacity: .7; cursor: progress; filter: saturate(.7); }

/* ── Errores ── */
.lr-calc-errors {
  margin: 0;
  border: 1px solid rgba(176, 58, 46, .5); border-left: 4px solid var(--lrc-danger);
  border-radius: 10px; background: rgba(176, 58, 46, .08);
  padding: 10px 13px; color: var(--lrc-danger); font-size: 12.5px;
}
.lr-calc-errors[hidden] { display: none; }
.lr-calc-errlist { margin: 0; padding-left: 18px; }
.lr-calc-errlist li { margin: 3px 0; }
.lr-calc-errline { margin: 0; }
.lr-calc-errors::before { content: "⚠ "; font-weight: 700; }

/* ══════════════ RESULTADO (debajo del formulario, columna principal) ══════════════ */
.lr-calc-panel {
  background: var(--lrc-card);
  border: 1px solid var(--lrc-line-gold);
  border-radius: 16px;
  padding: clamp(18px, 2.6vw, 24px);
  box-shadow: var(--lrc-sh-md);
}
.lr-calc-empty { text-align: center; padding: 14px 6px; }
.lr-calc-empty[hidden] { display: none; }
.lr-calc-empty-ic {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px; margin-bottom: 12px; border-radius: 14px;
  color: var(--lrc-copper); background: var(--lrc-cream); border: 1px solid var(--lrc-line-gold);
}
.lr-calc-empty-t {
  font-family: 'Playfair Display', Georgia, serif; font-size: 17px; font-weight: 600;
  color: var(--lrc-ink); margin: 0 0 6px;
}
.lr-calc-empty-s { font-size: 12.5px; line-height: 1.55; color: var(--lrc-ink-3); margin: 0 auto; max-width: 36ch; }

.lr-calc-result { background: transparent; border: 0; padding: 0; margin: 0; }
.lr-calc-result[hidden] { display: none; }
.lr-calc-result:focus-visible { outline: none; }

.lr-calc-rhero { text-align: center; padding-bottom: 15px; margin-bottom: 14px; border-bottom: 1px solid var(--lrc-line-gold); }
.lr-calc-rkicker {
  display: block; font-size: 10px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--lrc-copper); margin-bottom: 6px;
}
.lr-calc-rtotal {
  font-family: 'Playfair Display', Georgia, serif; font-weight: 700;
  font-size: clamp(28px, 6vw, 38px); line-height: 1.04; color: var(--lrc-copper); margin: 2px 0 6px;
}
.lr-calc-rsup { font-size: 12px; color: var(--lrc-ink-2); margin: 0; }

.lr-calc-rbreak { margin-bottom: 14px; }

.lr-calc-rsplit { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.lr-calc-rcard {
  display: flex; flex-direction: column; gap: 3px; text-align: center;
  padding: 12px 10px; border: 1px solid var(--lrc-line); border-radius: 11px; background: var(--lrc-card-2);
}
.lr-calc-rcard-l { font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--lrc-ink-3); }
.lr-calc-rcard-v { font-size: 15px; font-weight: 800; color: var(--lrc-copper); }

.lr-calc-rsum { margin-top: 16px; }
.lr-calc-ressub {
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--lrc-copper); margin: 0 0 6px;
}
.lr-calc-resrow {
  display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
  padding: 6px 0; border-bottom: 1px solid var(--lrc-line);
}
.lr-calc-resrow:last-child { border-bottom: none; }
.lr-calc-reslabel { font-size: 12px; color: var(--lrc-ink-2); }
.lr-calc-resval { font-size: 12.5px; font-weight: 700; color: var(--lrc-ink); text-align: right; }
.lr-calc-resrow--total { border-bottom: none; border-top: 1px solid var(--lrc-line-gold); margin-top: 2px; padding-top: 9px; }
.lr-calc-resrow--total .lr-calc-reslabel { font-weight: 700; color: var(--lrc-ink); }
.lr-calc-resrow--total .lr-calc-resval { font-size: 15px; color: var(--lrc-copper); }

.lr-calc-flag {
  margin: 12px 0 0; padding: 9px 12px; border-radius: 10px;
  background: var(--lrc-cream); border: 1px solid var(--lrc-line-gold);
  font-size: 12px; line-height: 1.45; color: var(--lrc-copper);
}
.lr-calc-disclaimer { margin: 14px 0 0; font-size: 11px; line-height: 1.6; color: var(--lrc-ink-3); font-style: italic; }

/* ── Opciones de pago ── */
.lr-calc-pagos { margin-top: 16px; }
.lr-calc-pagos-sub { font-size: 11.5px; line-height: 1.5; color: var(--lrc-ink-3); margin: 0 0 10px; }
.lr-calc-pago {
  border: 1px solid var(--lrc-line-2);
  border-radius: 11px;
  background: var(--lrc-card-2);
  padding: 11px 13px;
  margin-bottom: 8px;
}
.lr-calc-pago:last-child { margin-bottom: 0; }
.lr-calc-pago-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.lr-calc-pago-title { font-size: 12.5px; font-weight: 700; color: var(--lrc-ink); }
.lr-calc-pago-badge {
  font-size: 9.5px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
  color: var(--lrc-copper); background: var(--lrc-cream);
  border: 1px solid var(--lrc-line-gold); border-radius: 999px;
  padding: 2px 8px; white-space: nowrap;
}
.lr-calc-pago-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding: 4px 0 0; }
.lr-calc-pago-l { font-size: 12px; color: var(--lrc-ink-2); }
.lr-calc-pago-v { font-size: 13px; font-weight: 700; color: var(--lrc-ink); text-align: right; }
.lr-calc-pago-note { margin: 4px 0 0; font-size: 12px; color: var(--lrc-copper); font-style: italic; }
/* Destacado: 10% OFF (beneficio claro) */
.lr-calc-pago--off { border-color: var(--lrc-copper); background: var(--lrc-cream); box-shadow: inset 0 0 0 1px var(--lrc-copper); }
.lr-calc-pago--off .lr-calc-pago-v { color: var(--lrc-copper); font-size: 15px; }
.lr-calc-pago--off .lr-calc-pago-badge { color: #fff; background: var(--lrc-copper); border-color: var(--lrc-copper); }
/* Destacado sutil: 70/30 estándar */
.lr-calc-pago--std { border-color: var(--lrc-line-gold); }

/* Selección de opciones de pago (checkbox premium en cobre; sin verde fuerte) */
.lr-calc-pago--pick { display: block; position: relative; cursor: pointer; padding-right: 42px; transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease; }
.lr-calc-pago--pick:hover { border-color: var(--lrc-copper); }
.lr-calc-pago--pick.is-selected { border-color: var(--lrc-copper); box-shadow: inset 0 0 0 1px var(--lrc-copper); }
.lr-calc-pago-check {
  position: absolute; top: 12px; right: 12px; width: 20px; height: 20px; margin: 0;
  cursor: pointer; appearance: none; -webkit-appearance: none;
  border: 1.5px solid var(--lrc-line-gold); border-radius: 6px; background: #fff;
  display: grid; place-content: center; transition: border-color .15s ease, background-color .15s ease;
}
.lr-calc-pago-check::after {
  content: ""; width: 5px; height: 9px; margin-top: -2px;
  border: solid var(--lrc-copper); border-width: 0 2px 2px 0;
  transform: rotate(45deg) scale(0); transition: transform .12s ease;
}
.lr-calc-pago-check:checked { border-color: var(--lrc-copper); }
.lr-calc-pago-check:checked::after { transform: rotate(45deg) scale(1); }
.lr-calc-pago-check:focus-visible { outline: 2px solid var(--lrc-copper); outline-offset: 2px; }
.lr-calc-pago-msg {
  margin: 8px 0 0; padding: 8px 11px; border-radius: 9px; font-size: 11.5px; line-height: 1.45;
  color: var(--lrc-danger); background: rgba(176, 58, 46, .08); border: 1px solid rgba(176, 58, 46, .4);
}
.lr-calc-pago-msg[hidden] { display: none; }

/* ── Cierre comercial (datos del cliente + WhatsApp) ── */
.lr-calc-cierre { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--lrc-line-gold); }
.lr-calc-cierre[hidden] { display: none; }
.lr-calc-cierre-intro { font-size: 12.5px; line-height: 1.5; color: var(--lrc-ink-2); margin: 0 0 12px; }
.lr-calc-cgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.lr-calc-textarea { resize: vertical; min-height: 64px; font-family: inherit; line-height: 1.5; padding: 10px 13px; }
.lr-calc-opt-tag { font-weight: 600; color: var(--lrc-ink-3); text-transform: none; letter-spacing: 0; }
.lr-calc-wa {
  margin-top: 14px; color: #fff; border: 1.5px solid rgba(0, 0, 0, .12);
  background: linear-gradient(180deg, #29b24a, #1f9d3f);
  box-shadow: 0 10px 24px rgba(31, 157, 63, .28), inset 0 1px 0 rgba(255, 255, 255, .18);
}
.lr-calc-wa:hover:not(:disabled) { filter: brightness(1.06); border-color: rgba(0, 0, 0, .2); }
.lr-calc-wa:focus-visible { outline: 2px solid #1f9d3f; outline-offset: 3px; }
.lr-calc-cierre-msg {
  margin: 12px 0 0; padding: 10px 12px; border-radius: 10px;
  background: var(--lrc-cream); border: 1px solid var(--lrc-line-gold);
  font-size: 12px; line-height: 1.5; color: var(--lrc-copper);
}
.lr-calc-cierre-msg[hidden] { display: none; }
.lr-calc-cierre-msg--warn { background: rgba(176, 58, 46, .08); border-color: rgba(176, 58, 46, .4); color: var(--lrc-danger); }
@media (max-width: 520px) { .lr-calc-cgrid { grid-template-columns: 1fr; } }

/* ══════════════ GUÍA VISUAL (gris medio del sitio + bloques con borde cobre) ══════════════ */
.lr-calc-guide {
  background: var(--grafito, #2F2F2F);               /* grafito más oscuro para contraste (real del sitio) */
  border: 1px solid rgba(185, 122, 87, .48);         /* marco/borde cobre más definido (--cobre-base) */
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .06);
}
.lr-calc-glabel {
  display: block;
  font-size: 11px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase;
  color: var(--cobre-luz, #D9A27C); margin: 0 0 14px;
}
/* Dibujo SVG del frente (no cards): marco, bandas, líneas, rieles y cotas */
.lr-calc-gsvg { display: block; width: 100%; max-width: 230px; height: auto; margin: 0 auto 14px; }
.lr-calc-gsvg .g-frame { fill: rgba(255, 255, 255, .04); stroke: var(--cobre-base, #B97A57); stroke-width: 1.4; }   /* marco más definido */
.lr-calc-gsvg .g-mid { fill: rgba(255, 255, 255, .07); stroke: none; }                                             /* frente móvil / bajo: fondo intermedio */
.lr-calc-gsvg .g-band { fill: rgba(185, 122, 87, .14); stroke: var(--cobre-base, #B97A57); stroke-width: 1.5; }    /* Chapón / Faldón: relleno cálido + borde cobre marcado */
.lr-calc-gsvg .g-line { stroke: rgba(185, 122, 87, .55); stroke-width: 1; fill: none; }                            /* cajón / puertas: cobre tenue */
.lr-calc-gsvg .g-mline { stroke: rgba(255, 255, 255, .34); stroke-width: 1; fill: none; }                          /* líneas internas del frente móvil, más claras */
.lr-calc-gsvg .g-rail { stroke: rgba(217, 162, 124, .70); stroke-width: 1; fill: none; }                           /* guías de contrapeso, cobre claro */
.lr-calc-gsvg .g-rail-2 { stroke: rgba(217, 162, 124, .38); stroke-width: 1; fill: none; }
.lr-calc-gsvg .g-arrow { stroke: var(--cobre-luz, #D9A27C); stroke-width: 1.4; fill: none; }                       /* cotas alto/ancho, legibles */
.lr-calc-gsvg .g-arrowlbl { fill: var(--cobre-luz, #D9A27C); font: 700 9px 'Montserrat', sans-serif; letter-spacing: .06em; text-transform: uppercase; }
.lr-calc-gsvg .g-bandlbl { fill: var(--text-inv-1, rgba(244, 241, 244, .96)); font: 700 10px 'Montserrat', sans-serif; letter-spacing: .04em; }  /* etiquetas Chapón / Faldón en crema */
/* Zonas interactivas: overlays TRANSPARENTES (no botones, no cards) */
.lr-calc-zone { fill: transparent; stroke: transparent; cursor: pointer; outline: none; pointer-events: all; }
.lr-calc-zone.lr-zone-info { cursor: help; }   /* zonas solo informativas (frente móvil, bajo parrilla / puertas) */
.lr-calc-zone:hover, .lr-calc-zone:focus-visible, .lr-calc-zone.lr-zone-active { fill: rgba(217, 162, 124, .18); stroke: var(--cobre-luz, #D9A27C); stroke-width: 1.3; }
/* Highlight breve del grupo al navegar desde la guía */
.lr-calc-group.lr-group-flash { box-shadow: 0 0 0 2px var(--lrc-copper-soft), var(--lrc-sh-sm); transition: box-shadow .2s; }
/* Panel de texto explicativo: crema, separado del dibujo, con línea cobre al costado */
.lr-calc-gtip {
  margin: 0; min-height: 3em;
  font-size: 12px; line-height: 1.5; color: var(--text-1, rgba(31, 31, 31, .94));
  background: var(--surface-1, #F4F1F4);
  border: 1px solid rgba(31, 31, 31, .10);
  border-left: 3px solid var(--cobre-base, #B97A57);
  border-radius: 10px; padding: 10px 12px;
  white-space: pre-line;
  pointer-events: none;            /* el panel nunca intercepta el hover de las zonas */
}
.lr-calc-gnote { margin: 11px 0 0; font-size: 10.5px; line-height: 1.5; color: var(--text-inv-2, rgba(244, 241, 244, .82)); font-style: italic; pointer-events: none; }
.lr-calc-gnote[hidden] { display: none; }

/* ══════════════ DESKTOP: 2 columnas (principal ancha | lateral angosta) ══════════════ */
@media (min-width: 880px) {
  .lr-calc-layout { grid-template-columns: minmax(0, 1fr) 288px; gap: 26px; align-items: start; }
  /* Panel lateral sticky SIMPLE: acompaña el scroll, SIN scroll interno propio
     (sin max-height / overflow-y, para que no aparezca barra interna). El top
     contempla el header sticky del sitio (--header-h, 78px en /cotizador/);
     en _test-calc.php no hay style.css → var cae a 0px (top 16px). */
  .lr-calc-side {
    position: sticky;
    top: calc(var(--header-h, 0px) + 16px);
    align-self: start;
  }
}

/* ── Mobile ── */
@media (max-width: 480px) {
  .lr-calc-options { grid-template-columns: 1fr; }
  /* Cajones: apilar a 1 columna en celular para que +/− y el campo sean tocables */
  .lr-calc-counters { grid-template-columns: 1fr; }
}

/* ══════════════ UX MOBILE (chrome) ══════════════ */
/* Por defecto (desktop) el chrome mobile está oculto: no cambia el diseño aprobado */
.lr-calc-mbar { display: none; }
.lr-calc-guide-toggle { display: none; }
.lr-calc-mcta { display: none; }

/* "Nuevo cálculo": botón secundario (visible tras calcular, en el cierre) — desktop + mobile */
.lr-calc-personalizado {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; margin-top: 10px; min-height: 46px; padding: 12px 20px;
  font: 700 13px/1 'Montserrat', system-ui, sans-serif; letter-spacing: .02em;
  color: var(--lrc-copper); cursor: pointer; text-decoration: none;
  background: transparent; border: 1.5px solid var(--lrc-copper); border-radius: 12px;
  transition: background .15s, border-color .15s, color .15s;
}
.lr-calc-personalizado:hover { background: var(--lrc-cream); border-color: var(--lrc-copper); color: var(--lrc-copper); }
.lr-calc-personalizado:focus-visible { outline: 2px solid var(--lrc-copper); outline-offset: 2px; }

@media (max-width: 879px) {
  /* 1) Barra superior compacta sticky (debajo del header del sitio) */
  .lr-calc-mbar {
    display: block;
    position: sticky;
    top: var(--header-h, 0px);
    z-index: 60;
    margin: 0 0 12px;
    padding: 9px 12px;
    font: 700 11.5px/1 'Montserrat', system-ui, sans-serif; letter-spacing: .08em; text-transform: uppercase;
    color: var(--lrc-copper);
    background: linear-gradient(180deg, #FBF7F1, #F3EADD);
    border: 1px solid var(--lrc-line-gold); border-radius: 10px;
    box-shadow: 0 4px 14px rgba(60, 48, 34, .10);
  }

  /* 2) Guía visual colapsable */
  .lr-calc-guide-toggle {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    width: 100%; min-height: 46px; padding: 12px 14px;
    font: 700 12.5px/1.2 'Montserrat', system-ui, sans-serif; color: var(--lrc-ink);
    background: var(--lrc-card); border: 1px solid var(--lrc-line-gold); border-radius: 12px;
    cursor: pointer;
  }
  .lr-calc-guide-toggle::after { content: "▾"; color: var(--lrc-copper); font-size: 14px; transition: transform .15s; }
  .lr-calc-guidewrap.is-open .lr-calc-guide-toggle::after { transform: rotate(180deg); }
  .lr-calc-guidewrap:not(.is-open) .lr-calc-guide { display: none; }
  .lr-calc-guidewrap.is-open .lr-calc-guide { margin-top: 10px; }

  /* 3) Barra inferior sticky con la acción principal */
  .lr-calc-mcta {
    display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(180deg, rgba(246, 242, 236, .92), #F2ECE2);
    border-top: 1px solid var(--lrc-line-gold);
    box-shadow: 0 -8px 24px rgba(60, 48, 34, .16);
    -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  }
  .lr-calc-mcta-btn {
    width: 100%; min-height: 50px; padding: 14px 20px;
    font: 800 14.5px/1 'Montserrat', system-ui, sans-serif; letter-spacing: .02em;
    color: #F6F0E8; cursor: pointer;
    border: 1.5px solid var(--lrc-copper-soft); border-radius: 13px;
    background: linear-gradient(180deg, var(--lrc-choco-2), var(--lrc-choco));
    box-shadow: 0 8px 20px rgba(43, 41, 38, .28);
  }
  .lr-calc-mcta-btn:active { transform: translateY(1px); }

  /* Espacio para que la barra inferior no tape el contenido ni el cierre */
  .lr-calc { padding-bottom: 88px; }
}

/* Solo en /cotizador/ y solo mobile: ocultar el WhatsApp flotante global para que
   no tape la barra inferior de acción (no afecta el resto del sitio). */
@media (max-width: 879px) {
  body.page-cotizador .whatsapp-float { display: none; }
}
