:root{
  --sbc-green:#06FD62;
  --sbc-ink:#0f172a;
  --sbc-muted:rgba(15,23,42,.65);
  --sbc-line:rgba(15,23,42,.12);
  --sbc-soft:rgba(6,253,98,.12);
  --sbc-radius:16px;
  --sbc-shadow-soft:0 8px 18px rgba(15,23,42,.06);
  --sbc-shadow-premium:0 24px 55px rgba(15,23,42,.14);
  --sbc-font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

/* =========================================================
   WRAPPER
========================================================= */
.sbc-wrap{
  font-family: var(--sbc-font);
  color: var(--sbc-ink);
  background:#fff;
  padding:14px 0 34px;
}

/* =========================================================
   NEW TOP LAYOUT: FORM + RIGHT BANNER
========================================================= */
.sbc-shell{
  max-width:1180px;
  margin:0 auto;
  padding:0 14px;
}

.sbc-hero-title{
  font-size:34px;
  font-weight:1000;
  letter-spacing:-.6px;
  text-align:center;
  margin:10px 0 18px;
}

@media (max-width:768px){
  .sbc-hero-title{ font-size:24px; }
}

.sbc-top{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:18px;
  align-items:stretch;
}

@media (max-width:1024px){
  .sbc-top{
    grid-template-columns:1fr;
  }
}

/* left: form container */
.sbc-form-card{
  background:#fff;
  border:1px solid var(--sbc-line);
  border-radius:22px;
  box-shadow: var(--sbc-shadow-soft);
  padding:18px;
  overflow:hidden;
}

/* right: big banner */
.sbc-right-banner{
  background: #fff;
  border:1px solid var(--sbc-line);
  border-radius:22px;
  box-shadow: var(--sbc-shadow-soft);
  overflow:hidden;
  min-height: 520px;
  display:flex;
}

.sbc-right-banner img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

@media (max-width:1024px){
  .sbc-right-banner{
    display: none;
  }
}

/* =========================================================
   FORM INNER SPLIT: left banner + fields
========================================================= */
.sbc-form-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:18px;
  align-items:start;
}

@media (max-width:900px){
  .sbc-form-grid{
    grid-template-columns:1fr;
  }
}

.sbc-left-banner{
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(6,253,98,.06);
  min-height: 520px;
  display:flex;
}

.sbc-left-banner img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

@media (max-width:900px){
  .sbc-left-banner{
    min-height: 180px;
  }
}

/* =========================================================
   FORM COMPONENTS
========================================================= */
.sbc-card__title{
  font-size:18px;
  margin:0 0 12px;
  letter-spacing:-.2px;
}
h2.sbc-card__title {
  font-size: 22px;
  font-weight: 900;
  line-height: 1.2;
  margin:0 0 12px;
  
}

.sbc-hint{
  color:var(--sbc-muted);
  font-size:13px;
}

.sbc-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.sbc-row{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.sbc-row--2{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
@media (min-width:700px){
  .sbc-row--2{ grid-template-columns:1fr 1fr; }
}

.sbc-row--3{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
@media (min-width:900px){
  .sbc-row--3{ grid-template-columns:1fr 1fr 1fr; }
}

.sbc-label{
  font-weight:900;
  font-size:13px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.sbc-label--sm{
  font-weight:900;
  font-size:12px;
  color:var(--sbc-muted);
}

.sbc-input{
  width:100%;
  height:42px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--sbc-line);
  outline:none;
  background:#fff;
  color:var(--sbc-ink);
  font-size:14px;
  transition: box-shadow .15s ease, border-color .15s ease;
}

.sbc-input:focus{
  border-color: rgba(6,253,98,.65);
  box-shadow:0 0 0 4px rgba(6,253,98,.18);
}

.sbc-range__meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
  color:var(--sbc-muted);
}

.sbc-range__meta strong{
  color:var(--sbc-ink);
  background:var(--sbc-soft);
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(6,253,98,.18);
}

.sbc-mini{
  border:1px dashed var(--sbc-line);
  border-radius:14px;
  padding:12px;
  background:rgba(15,23,42,.02);
}

.sbc-mini__title{
  font-weight:1000;
  font-size:13px;
  margin:0 0 10px;
}

.sbc-mini__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

@media (min-width:900px){
  .sbc-mini__grid{ grid-template-columns:repeat(4,1fr); }
}

/* =========================================================
   PREMIUM TOGGLE (Sí/No)
========================================================= */
.sbc-toggle-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border:1px solid var(--sbc-line);
  border-radius:14px;
  background: rgba(15,23,42,.02);
}

.sbc-toggle-label{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:900;
  font-size:13px;
  flex-wrap:wrap;
}

.sbc-toggle{
  position:relative;
  width:118px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  padding:4px;
  box-shadow:0 10px 18px rgba(15,23,42,.06);
}

.sbc-toggle input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}

.sbc-toggle__pill{
  position:absolute;
  top:4px;
  left:4px;
  width:54px;
  height:30px;
  border-radius:999px;
  background:rgba(15,23,42,.08);
  transition: transform .18s ease, background .18s ease;
  box-shadow:0 10px 18px rgba(15,23,42,.08);
}

.sbc-toggle__opt{
  position:relative;
  z-index:2;
  width:50%;
  text-align:center;
  font-weight:1000;
  font-size:12px;
  color:rgba(15,23,42,.60);
  user-select:none;
}

.sbc-toggle.is-yes .sbc-toggle__pill{
  background:rgba(6,253,98,.90);
  transform:translateX(56px);
}

.sbc-toggle.is-yes .sbc-toggle__opt--yes{
  color:#00140a;
}

.sbc-toggle:not(.is-yes) .sbc-toggle__opt--no{
  color:#00140a;
}

/* =========================================================
   BUTTONS
========================================================= */
.sbc-btn{
  height:46px;
  border-radius:14px;
  border:1px solid var(--sbc-line);
  padding:0 16px;
  font-weight:1000;
  font-size:14px;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  user-select:none;
}

.sbc-btn--primary{
  background:var(--sbc-green);
  border-color:rgba(6,253,98,.6);
  color:#00140a;
  box-shadow:0 10px 22px rgba(6,253,98,.22);
}

.sbc-btn--ghost{
  background:#fff;
  color:var(--sbc-ink);
}

.sbc-btn.is-loading{
  opacity:.75;
  cursor:wait;
}

/* =========================================================
   RESULTS BELOW FULL WIDTH
========================================================= */
.sbc-results-wrap{
  max-width:1180px;
  margin:18px auto 0;
  padding:0 14px;
}

.sbc-results-card{
  background:#fff;
  border:1px solid var(--sbc-line);
  border-radius:22px;
  box-shadow: var(--sbc-shadow-soft);
  padding:18px;
}

/* Results summary grid */
.sbc-summary{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:10px;
}

@media (min-width:886px){
  .sbc-summary{ grid-template-columns:1fr; }
}
@media (min-width:1100px){
  .sbc-summary{ grid-template-columns:1fr 1fr; }
}

.sbc-summary__item{
  border:1px solid var(--sbc-line);
  border-radius:14px;
  padding:50px;
  background:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.04);
}

.sbc-summary__label{
  font-size:22px;
  color:rgb(0 0 0);
  margin-bottom:6px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.sbc-summary__value{
  font-size:18px;
  font-weight:1000;
  letter-spacing:-.2px;
  border-left:6px solid var(--sbc-green);
  padding-left:10px;
}

/* Charts */
.sbc-charts{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:14px;
}

@media (min-width:900px){
  .sbc-charts{ grid-template-columns:1fr; }
}

/* ✅ FIX + premium chart container */
.sbc-chart-card{
  border:1px solid var(--sbc-line);
  border-radius:14px;
  padding:12px;
  background:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.04);
  overflow:hidden;

  display:flex;
  flex-direction:column;
  height:260px;
}

.sbc-chart-title{
  font-weight:1000;
  font-size:13px;
  margin-bottom:10px;
  flex:0 0 auto;
}

.sbc-chart-card canvas{
  flex:1 1 auto;
  width:100% !important;
  height:100% !important;
  display:block;
}

/* Actions */
.sbc-actions{
  display: grid;
  grid-template-columns: repeat(4,1fr);
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
  padding: 12px;
}

@media (max-width:700px){
  .sbc-actions{
    grid-template-columns:1fr;
  }
}

/* CF7 panel */
.sbc-form-panel{
  margin-top:14px;
  border:1px solid var(--sbc-line);
  border-radius:14px;
  padding:12px;
  background:rgba(15,23,42,.02);
}

.sbc-empty{
  font-size:14px;
  color:var(--sbc-muted);
  padding:8px 0;
}

.sbc-alert{
  border-radius:14px;
  padding:10px 12px;
  font-size:13px;
}

.sbc-alert--error{
  border:1px solid rgba(220,38,38,.25);
  background:rgba(220,38,38,.06);
  color:rgba(153,27,27,1);
}

/* =========================================================
   REPORT PDF hidden but capturable
========================================================= */
.sbc-report{
  position:absolute;
  left:-99999px;
  top:0;
  width:794px;
  max-width:794px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  overflow:hidden;
}

/* =========================================================
   TOOLTIP ULTRA (keep)
========================================================= */
.sbc-info{
  display:inline-flex;
  align-items:center;
  position:relative;
  vertical-align:middle;
  outline:none;
  line-height:1;
}

.sbc-info__icon{
  width:18px;
  height:18px;
  min-width:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(6,253,98,.38);
  background:rgba(6,253,98,.10);
  color:rgba(15,23,42,.88);
  cursor:pointer;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease, background .14s ease;
  box-shadow:0 6px 14px rgba(15,23,42,.06);
}

.sbc-info__svg{
  width:16px;
  height:16px;
  display:block;
}

.sbc-info:hover .sbc-info__icon,
.sbc-info:focus .sbc-info__icon{
  transform: translateY(-1px);
  border-color: rgba(6,253,98,.65);
  background:rgba(6,253,98,.16);
  box-shadow:0 0 0 4px rgba(6,253,98,.18), 0 16px 28px rgba(15,23,42,.10);
}

.sbc-info__tooltip{
  position:absolute;
  bottom:135%;
  width:min(440px, 82vw);
  max-width:440px;

  background:rgba(255,255,255,.94);
  color:rgba(15,23,42,.92);
  border:1px solid rgba(6,253,98,.34);
  box-shadow: var(--sbc-shadow-premium);
  border-radius:16px;
  padding:12px;

  font-size:12px;
  line-height:1.35;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition: opacity .14s ease, transform .14s ease, visibility .14s ease;
  z-index:80;

  left:50%;
  transform: translateX(-50%) translateY(8px);
}

.sbc-info__badge{
  display:inline-flex;
  width:max-content;
  align-items:center;
  gap:6px;
  font-size:11px;
  font-weight:1000;
  letter-spacing:.2px;
  color:#00140a;
  background:rgba(6,253,98,.22);
  border:1px solid rgba(6,253,98,.32);
  padding:3px 8px;
  border-radius:999px;
  margin-bottom:8px;
}

.sbc-info__text{
  display:block;
  color:rgba(15,23,42,.92);
}

.sbc-info__tooltip::after{
  content:"";
  position:absolute;
  top:100%;
  width:10px;
  height:10px;
  background:rgba(255,255,255,.94);
  border-right:1px solid rgba(6,253,98,.34);
  border-bottom:1px solid rgba(6,253,98,.34);
  transform: rotate(45deg);
}

.sbc-info:hover .sbc-info__tooltip,
.sbc-info:focus .sbc-info__tooltip{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform: translateX(-50%) translateY(0);
}

@media (max-width: 640px){
  .sbc-info__tooltip{ display:none; }
}

/* Mobile overlay */
.sbc-tip-overlay{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.38);
  z-index:9999;
  display:none;
  align-items:flex-end;
  justify-content:center;
  padding:14px;
}
.sbc-tip-overlay.is-open{ display:flex; }
.sbc-tip-panel{
  width:min(620px, 100%);
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(6,253,98,.30);
  box-shadow: 0 30px 70px rgba(15,23,42,.22);
  overflow:hidden;
  transform: translateY(12px);
  opacity:0;
  transition: transform .16s ease, opacity .16s ease;
}
.sbc-tip-overlay.is-open .sbc-tip-panel{
  transform: translateY(0);
  opacity:1;
}
.sbc-tip-panel__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  background:linear-gradient(0deg, rgba(6,253,98,.10), rgba(6,253,98,.18));
  border-bottom:1px solid rgba(15,23,42,.10);
}
.sbc-tip-panel__title{
  font-weight:1000;
  font-size:13px;
  color:#00140a;
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.sbc-tip-panel__titleText{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sbc-tip-panel__close{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition: transform .12s ease, box-shadow .12s ease;
}
.sbc-tip-panel__close:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(15,23,42,.10);
}
.sbc-tip-panel__body{
  padding:14px;
  font-size:13px;
  line-height:1.45;
  color:rgba(15,23,42,.92);
  max-height: 52vh;
  overflow:auto;
}
/* =========================================================
   Versión 2.1 - PREMIUM UPGRADES (Animaciones + Highlights)
========================================================= */

/* Entrada animada de resultados (sin saltos) */
.sbc-results-card{
  opacity: 1;
  transform: none;
}

.sbc-results-card.sbc-animate-in{
  animation: sbcFadeSlide .42s cubic-bezier(.22,.95,.3,1) both;
}

@keyframes sbcFadeSlide{
  from{
    opacity: 0;
    transform: translateY(10px);
    filter: blur(2px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

/* Highlights: primeras 3 tarjetas (Batería / Precio / Ahorro) */
.sbc-summary__item:nth-child(1),
.sbc-summary__item:nth-child(2),
.sbc-summary__item:nth-child(3){
  border-color: rgba(6,253,98,.25);
  box-shadow: 0 18px 42px rgba(15,23,42,.08);
}

.sbc-summary__item:nth-child(1) .sbc-summary__value,
.sbc-summary__item:nth-child(2) .sbc-summary__value,
.sbc-summary__item:nth-child(3) .sbc-summary__value{
  font-size: 35px;
  letter-spacing: -.35px;
}

/* Pequeña “chip” estética en labels para dar sensación SaaS */
.sbc-summary__label{
  gap: 10px;
}

.sbc-summary__label::after{
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(6,253,98,.65);
  opacity: .25;
  margin-left: auto;
}

/* Botones un pelín más premium */
.sbc-btn{
  position: relative;
  overflow: hidden;
}

.sbc-btn--primary::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.35), transparent 55%);
  opacity:.55;
  pointer-events:none;
}

.sbc-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(15,23,42,.12);
}

.sbc-btn:active{
  transform: translateY(0px);
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
}

/* Micro-interacción en tarjetas */
.sbc-summary__item{
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.sbc-summary__item:hover{
  transform: translateY(-2px);
  border-color: rgba(6,253,98,.32);
  box-shadow: 0 22px 52px rgba(15,23,42,.10);
}

/* Charts: un poco más "dashboard" */
.sbc-chart-card{
  transition: transform .16s ease, box-shadow .16s ease;
}
.sbc-chart-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 52px rgba(15,23,42,.10);
}

/* Despliegue suave del panel CF7 */
.sbc-form-panel{
  animation: sbcPanelIn .28s ease both;
}

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

/* =========================================================
   Upgrade 2.1 - HERO (KPI + CTA)
========================================================= */

.sbc-kpi-hero{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap: 18px;
  margin: 14px 0 18px;
}

.sbc-kpi-main{
  border: 1px solid rgba(6,253,98,.22);
  background:
    radial-gradient(1200px 420px at 20% 20%, rgba(6,253,98,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,1));
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 24px 60px rgba(15,23,42,.08);
  position: relative;
  overflow:hidden;
}

.sbc-kpi-main::after{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.55), transparent 55%);
  opacity:.55;
  pointer-events:none;
}

.sbc-kpi-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.sbc-kpi-badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(6,253,98,.12);
  border: 1px solid rgba(6,253,98,.25);
  color: rgba(15,23,42,.78);
  font-weight: 850;
  font-size: 12px;
}

.sbc-kpi-badge .dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(6,253,98,.95);
  box-shadow: 0 0 0 4px rgba(6,253,98,.18);
}

.sbc-kpi-note{
  font-size: 12px;
  color: rgba(15,23,42,.55);
  font-weight: 700;
}

.sbc-kpi-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.sbc-kpi-card{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.90);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 14px 34px rgba(15,23,42,.06);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.sbc-kpi-card:hover{
  transform: translateY(-2px);
  border-color: rgba(6,253,98,.28);
  box-shadow: 0 22px 54px rgba(15,23,42,.09);
}

.sbc-kpi-label{
  display:flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  font-weight: 850;
  color: rgba(15,23,42,.62);
  margin-bottom: 8px;
}

.sbc-kpi-label .pill{
  display:inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(15,23,42,.04);
  border: 1px solid rgba(15,23,42,.08);
  font-weight: 850;
  color: rgba(15,23,42,.65);
}

.sbc-kpi-value{
  font-size: 34px;
  font-weight: 980;
  letter-spacing: -0.6px;
  color: rgba(15,23,42,.92);
  line-height: 1.05;
}

.sbc-kpi-value .unit{
  font-size: 14px;
  font-weight: 900;
  color: rgba(15,23,42,.55);
  margin-left: 6px;
}

.sbc-kpi-sub{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(15,23,42,.58);
  font-weight: 700;
}

/* Right panel */
.sbc-kpi-side{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.92);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 18px 46px rgba(15,23,42,.08);
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.sbc-kpi-side__title{
  font-size: 13px;
  font-weight: 950;
  color: rgba(15,23,42,.85);
  letter-spacing: -.2px;
}

.sbc-kpi-mini{
  display:grid;
  gap: 8px;
}

.sbc-kpi-mini__row{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(15,23,42,.02);
}

.sbc-kpi-mini__row strong{
  color: rgba(15,23,42,.78);
  font-weight: 900;
  font-size: 12px;
}

.sbc-kpi-mini__row span{
  color: rgba(15,23,42,.92);
  font-weight: 950;
  font-size: 12px;
}

.sbc-kpi-cta{
  margin-top: auto;
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.sbc-kpi-cta .sbc-btn{
  width:100%;
}

.sbc-kpi-cta .sbc-hint{
  margin: 0;
  font-size: 12px;
  color: rgba(15,23,42,.55);
}

/* Mobile */
@media (max-width: 900px){
  .sbc-kpi-hero{
    grid-template-columns: 1fr;
  }
  .sbc-kpi-grid{
    grid-template-columns: 1fr;
  }
  .sbc-kpi-value{
    font-size: 30px;
  }
}
/* =========================================================
   REMODEL RESULTADOS HERO (sin datos repetidos)
========================================================= */

.sbc-results-hero{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(142, 252, 188, 0.052);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 22px 54px rgba(15,23,42,.08);
  margin: 12px 0 18px;
}

.sbc-results-hero__title{
  font-size: 24px;
  font-weight: 980;
  letter-spacing: -0.6px;
  color: rgba(15,23,42,.92);
  margin: 0 0 10px;
}

.sbc-results-hero__copy{
  display: grid;
  gap: 10px;
  margin: 0 0 16px;
}

.sbc-results-hero__copy p{
  margin: 0;
  color: rgba(15,23,42,.72);
  font-weight: 400;
  line-height: 1.45;
}

.sbc-results-hero__copy p strong{
  color: rgba(15,23,42,.86);
  font-weight: 900;
}

.sbc-results-hero__actions{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}

@media (max-width: 900px){
  .sbc-results-hero__actions{
    grid-template-columns: 1fr;
  }
}

/*encabezado botones contactar*/
.sbc-results-bottom-contact{
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(142, 252, 188, 0.052);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 22px 54px rgba(15,23,42,.08);
  margin: 12px 0 18px;
}
h3.sbc-results-bottom-contact{
  font-size: 22px;
  font-weight: 900;
  line-height: 1.2;
  text-align: center;
  margin:0 0 12px;
  
}
p.sbc-results-bottom-contact{
  font-weight: 400;
  line-height: 1.45;
  text-align: center;
  margin:0 0 16px;
}


@media (max-width: 900px){
  .ssbc-results-bottom-contacto{
    grid-template-columns: 1fr;
  }
}

/* Botón WhatsApp con look premium */
.sbc-btn--whatsapp{
  background: rgba(6,253,98,.14);
  border: 1px solid rgba(6,253,98,.35);
  color: rgba(15,23,42,.92);
}

.sbc-btn--whatsapp:hover{
  border-color: rgba(6,253,98,.55);
  background: rgba(6,253,98,.20);
}

/* =========================================================
   RESULTADOS - COMPARADOR TIPO TABLA (Sin batería vs Con batería)
   - Mantiene KPI row superior
   - Comparativa visual clara
========================================================= */

.sbc-compare{
  margin-top: 14px;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 16px 30px rgba(15,23,42,.05);
  overflow: visible !important;
}

.sbc-compare__head{
  display: grid;
  grid-template-columns: 1.55fr 1fr 1fr;
  gap: 0;
  padding: 12px 14px;
  background: rgba(15,23,42,.02);
  border-bottom: 1px solid rgba(15,23,42,.10);
}

.sbc-compare__hmetric{
  font-size: 12px;
  font-weight: 1000;
  color: rgba(15,23,42,.65);
  letter-spacing: .2px;
}

.sbc-compare__hcol{
  font-size: 12px;
  font-weight: 1000;
  color: rgba(15,23,42,.55);
  text-align: center;
}

.sbc-compare__hcol.is-green{
  color: #00140a;
}

.sbc-compare__row{
  display: grid;
  grid-template-columns: 1.55fr 1fr 1fr;
  align-items: center;
  gap: 0;
  padding: 14px;
  border-top: 1px solid rgba(15,23,42,.08);
  background: #fff;
}

.sbc-compare__row:nth-child(even){
  background: rgba(15,23,42,.012);
}

.sbc-compare__label{
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 13px;
  font-weight: 1000;
  color: rgba(15,23,42,.92);
}

.sbc-compare__val{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 1000;
  color: rgba(15,23,42,.90);
  text-align: right;
}

.sbc-compare__val.is-green{
  color: #00140a;
}

.sbc-compare__main{
  white-space: nowrap;
}

.sbc-compare__badge{
  font-size: 11px;
  font-weight: 1000;
  padding: 4px 8px;
  border-radius: 999px;
  white-space: nowrap;
  border: 1px solid rgba(6,253,98,.28);
  background: rgba(6,253,98,.16);
  color: #00140a;
  box-shadow: 0 10px 18px rgba(6,253,98,.10);
}

/* Enfatiza la columna Con batería */
.sbc-compare__val.is-green{
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(6,253,98,.08);
  border: 1px solid rgba(6,253,98,.16);
}

/* ---------------------------------------------------------
   Total ahorro (centrado + badge % mejora)
--------------------------------------------------------- */
.sbc-total--center{
  margin-top: 14px;
  text-align: center;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 8px;
  padding: 18px 16px;
}

.sbc-total--center .sbc-total__label{
  font-size: 13px;
  font-weight: 1000;
  color: rgba(15,23,42,.65);
}

.sbc-total--center .sbc-total__value{
  font-size: 28px;
  font-weight: 1200;
  letter-spacing: -.55px;
  background: rgba(6,253,98,.35);
  padding: 10px 16px;
  border-radius: 999px;
  box-shadow: 0 16px 26px rgba(6,253,98,.14);
}

.sbc-total__pct{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 1100;
  color: rgba(15,23,42,.80);
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.03);
}

.sbc-total--sim{
  margin-top: 14px;
  text-align: center;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 8px;
  padding: 18px 16px;
}
/* ---------------------------------------------------------
   Responsive: mantiene formato comparador sin perder claridad
--------------------------------------------------------- */
@media (max-width: 680px){
  .sbc-compare__head{
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "metric metric"
      "con sin";
    row-gap: 8px;
  }

  .sbc-compare__hmetric{ grid-area: metric; }
  .sbc-compare__hcol:nth-child(3){ grid-area: sin; text-align:center; }
  .sbc-compare__hcol:nth-child(2){ grid-area: con; text-align:center; }

  .sbc-compare__row{
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "label label"
      "con sin";
    row-gap: 10px;
  }

  .sbc-compare__label{ grid-area: label; }
  .sbc-compare__row .sbc-compare__val:nth-of-type(1){
    grid-area: sin;
    justify-content: flex-start;
    text-align: left;
  }
  .sbc-compare__row .sbc-compare__val:nth-of-type(2){
    grid-area: con;
    justify-content: flex-end;
    text-align: right;
  }

  .sbc-compare__val.is-green{
    justify-content: flex-end;
  }
}
/* =========================================================
   FIX: ICONOS KPI (Batería / Precio / Ahorro) - CONSOLIDADO
   - Iconos en ::before (60x60) desde /icon
   - Glow premium sigue en ::after
   - Tooltips NO se recortan (overflow visible)
========================================================= */

.sbc-summary__item:nth-child(1),
.sbc-summary__item:nth-child(2),
.sbc-summary__item:nth-child(3){
  position: relative;
  overflow: visible !important; /* tooltips OK */
}

/* Iconos: SIEMPRE activos */
.sbc-summary__item:nth-child(1)::before,
.sbc-summary__item:nth-child(2)::before,
.sbc-summary__item:nth-child(3)::before{
  content: "" !important;
  position: absolute;
  top: 14px;
  right: 14px;
  width: 60px;
  height: 60px;

  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;

  opacity: .92;
  filter: drop-shadow(0 10px 18px rgba(15,23,42,.10));
  pointer-events: none;

  z-index: 6; /* por encima del glow y del contenido */
}

/* 1) Batería recomendada */
.sbc-summary__item:nth-child(1)::before{
  background-image: url("../icon/ico-bateria-recomendada.svg") !important;
}

/* 2) Precio estimado */
.sbc-summary__item:nth-child(2)::before{
  background-image: url("../icon/ico-precio-instala.svg") !important;
}

/* 3) Ahorro real anual */
.sbc-summary__item:nth-child(3)::before{
  background-image: url("../icon/ico-ahorro-a.svg") !important;
}

/* Mantener contenido por encima del glow */
.sbc-summary__item:nth-child(1) > *,
.sbc-summary__item:nth-child(2) > *,
.sbc-summary__item:nth-child(3) > *{
  position: relative;
  z-index: 4;
}

/* Ajuste móvil: icono algo más pequeño y aire en el valor */
@media (max-width: 520px){
  .sbc-summary__item:nth-child(1)::before,
  .sbc-summary__item:nth-child(2)::before,
  .sbc-summary__item:nth-child(3)::before{
    width: 48px;
    height: 48px;
    top: 12px;
    right: 12px;
    opacity: .88;
  }

  .sbc-summary__item:nth-child(1) .sbc-summary__value,
  .sbc-summary__item:nth-child(2) .sbc-summary__value,
  .sbc-summary__item:nth-child(3) .sbc-summary__value{
    padding-right: 54px;
  }
}
/* =========================================================
   AJUSTE COMPARADOR: quitar highlight de "Con batería"
   y destacar MÁS el ahorro total
========================================================= */

/* 1) Quitamos cualquier fondo/estilo especial en las celdas "Con batería"
   (suele estar marcado con .is-green o columna 3) */
.sbc-compare__val.is-green{
  background: transparent !important;
  border: 1px solid rgba(15,23,42,.10) !important;
  color: var(--sbc-ink) !important;
  padding: 8px 10px !important;
  border-radius: 12px !important;
}

/* Si existe un highlight por columna completa (según versión del CSS),
   lo anulamos también */
.sbc-compare__head .is-green,
.sbc-compare__hcol.is-green{
  color: var(--sbc-muted) !important;
}

/* 2) Solo el ahorro total mantiene el highlight */
.sbc-total{
  border: 1px solid rgba(6,253,98,.45) !important;
  background: linear-gradient(120deg, rgba(6,253,98,.18), rgba(6,253,98,0) 70%) !important;
}

/* 3) Ahorro total: MÁS GRANDE y MÁS GRUESO 
COMENTADO
.sbc-total__value{
  font-size: 30px !important;
  font-weight: 1300 !important;
  letter-spacing: -0.6px !important;
  padding: 10px 16px !important;
  box-shadow: 0 18px 34px rgba(6,253,98,.12) !important;
}
  */



/* Mejora el texto del label también para que acompañe 
.sbc-total__label{
  font-size: 14px !important;
  font-weight: 1000 !important;
  color: rgba(15,23,42,.70) !important;
}


*/

/* Responsive para que no sea demasiado grande en móvil */
@media (max-width: 520px){
  .sbc-total__value{
    font-size: 24px !important;
    padding: 8px 14px !important;
  }
}
/* =========================================================
   COMPARADOR: "Con batería" SIN borde ni fondo
========================================================= */

.sbc-compare__val.is-green{
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
/* =========================================================
   AHORRO TOTAL: estilo KPI premium (sin degradado)
   Similar a “Ahorro real anual” pero más grande
========================================================= */

.sbc-total{
  background: #fff !important;                /* sin degradado */
  border: 1px solid rgba(15,23,42,.12) !important;
  border-radius: 18px !important;
  box-shadow: 0 26px 58px rgba(15,23,42,.10) !important;
  padding: 16px 16px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
}

/* Quitamos cualquier pseudo elemento viejo que meta degradados */
.sbc-total::before,
.sbc-total::after{
  content: none !important;
}

/* Label del ahorro total */
.sbc-total__label{
  font-size: 18px !important;
  font-weight: 1100 !important;
  color: rgb(0, 0, 0) !important;
  letter-spacing: .2px !important;
}

/* Valor GRANDE y más “KPI” */
.sbc-total__value{
  font-size: 50px !important;
  font-weight: 900 !important;
  letter-spacing: -0.8px !important;
  line-height: 1.05 !important;

  /* mismo estilo “KPI” que arriba: acento verde */
  border-left: 8px solid var(--sbc-green) !important;
  padding: 6px 0 6px 14px !important;

  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;

  color: #00140a !important;
}

/* Responsive */
@media (max-width: 520px){
  .sbc-total{
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .sbc-total__value{
    font-size: 28px !important;
    padding-left: 12px !important;
    border-left-width: 7px !important;
  }
}
/* =========================================================
   CTA texto antes de botones (v2.5.6 visual)
========================================================= */
.sbc-actions-cta{
  margin: 30px 0 30px;
  font-size: 18px;
  line-height: 1.35;
  color: rgba(15,23,42,.70);
}
/* =========================================================
   PDF (Informe) – Maquetación
========================================================= */
.sbc-report{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  color:#0f172a;
  background:#fff;
  width:794px;
  max-width:794px;
  border-radius:18px;
  overflow:hidden;
}

.sbc-report__header{
  padding:22px 24px 16px;
  border-bottom:1px solid rgba(15,23,42,.10);
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}

.sbc-report__title{
  font-size:22px;
  font-weight:1200;
  letter-spacing:-.4px;
}

.sbc-report__meta{
  text-align:right;
  font-size:11px;
  color:rgba(15,23,42,.65);
  line-height:1.3;
}

.sbc-report__section{
  padding:18px 24px;
}

.sbc-report__sectionTitle{
  font-size:12px;
  font-weight:1100;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:rgba(15,23,42,.70);
  margin-bottom:10px;
}

.sbc-report__inputs{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 16px;
  font-size:12px;
  color:rgba(15,23,42,.78);
}

.sbc-report__inputs strong{
  color:rgba(15,23,42,.90);
}

.sbc-report__summary{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.sbc-report__kpis{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px;
}

.sbc-report__kpi{
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  padding:12px 12px 10px;
  background:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.04);
}

.sbc-report__kpiLabel{
  font-size:11px;
  color:rgba(15,23,42,.62);
  font-weight:1000;
  margin-bottom:6px;
}

.sbc-report__kpiValue{
  font-size:18px;
  font-weight:1200;
  letter-spacing:-.2px;
  padding-left:10px;
  border-left:6px solid #06FD62;
  display:flex;
  align-items:baseline;
  gap:6px;
}

.sbc-report__kpiValue span{
  font-size:11px;
  color:rgba(15,23,42,.55);
  font-weight:900;
}

.sbc-report__compare{
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
}

.sbc-report__compareHead{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  gap:10px;
  padding:10px 12px;
  background:rgba(15,23,42,.03);
  border-bottom:1px solid rgba(15,23,42,.08);
  font-size:11px;
  font-weight:1100;
  color:rgba(15,23,42,.72);
}

.sbc-report__compareRow{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid rgba(15,23,42,.06);
  align-items:center;
}

.sbc-report__compareRow:last-child{ border-bottom:0; }

.sbc-report__compareLabel{
  font-size:12px;
  font-weight:1000;
  color:rgba(15,23,42,.90);
}

.sbc-report__compareVal{
  font-size:12px;
  font-weight:1100;
  text-align:right;
  color:rgba(15,23,42,.80);
}

.sbc-report__total{
  border:1px solid rgba(6,253,98,.45);
  border-radius:18px;
  padding:12px 14px;
  background:#fff;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
}

.sbc-report__totalLabel{
  font-size:12px;
  font-weight:1100;
  color:rgba(15,23,42,.68);
}

.sbc-report__totalValue{
  font-size:26px;
  font-weight:1300;
  letter-spacing:-.4px;
  color:#06210f;
}

.sbc-report__totalPct{
  font-size:11px;
  font-weight:1200;
  padding:3px 10px;
  border-radius:999px;
  background:rgba(6,253,98,.18);
  color:rgba(6,120,50,1);
  white-space:nowrap;
}

.sbc-report__mini{
  display:flex;
  justify-content:space-between;
  gap:16px;
  font-size:11px;
  color:rgba(15,23,42,.70);
}

.sbc-report__charts{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}

.sbc-report__chartBox{
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  padding:10px;
  background:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.04);
  overflow:hidden;
}

.sbc-report__chartTitle{
  font-size:11px;
  font-weight:1100;
  color:rgba(15,23,42,.72);
  margin-bottom:8px;
}

.sbc-report__chartBox img{
  width:100%;
  height:220px;
  object-fit:contain;
  display:block;
  border-radius:12px;
  background:#fff;
}

.sbc-report__banner{
  padding:10px 24px 22px;
}

.sbc-report__bannerBox{
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.04);
}

.sbc-report__bannerBox img{
  width:100%;
  height:140px;
  object-fit:cover;
  display:block;
}

.sbc-report__footer{
  padding:12px 24px 18px;
  font-size:10px;
  color:rgba(15,23,42,.55);
  border-top:1px solid rgba(15,23,42,.08);
}
/* =========================================================
   FIX PDF: evitar iconos pseudo-element en sbc-report
   (en PDF los iconos se pintan como <img>)
========================================================= */
.sbc-report .sbc-summary__item::before{
  content: none !important;
  display: none !important;
  background-image: none !important;
}
/* =========================================================
   FIX PDF: iconos reales en KPIs del informe
========================================================= */
.sbc-report .sbc-pdf-kpi{
  position: relative;
  padding-right: 86px; /* hueco para el icono a la derecha */
}

.sbc-report .sbc-pdf-kpi-ico{
  position: absolute;
  top: 14px;
  right: 14px;
  width: 60px;
  height: 60px;
  display: block;
  opacity: .92;
  pointer-events: none;
}
/* =========================================================
   PDF FIX: render seguro de iconos (SVG INLINE)
========================================================= */
.sbc-report .sbc-pdf-inline-ico{
  width:60px;
  height:60px;
  display:block;
  flex:0 0 60px;
}

.sbc-report .sbc-pdf-inline-ico svg{
  width:60px !important;
  height:60px !important;
  display:block !important;
}
/* =========================================================
   PDF - Bloque de gráficas
========================================================= */
.sbc-report__chartsGrid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.sbc-report__chartCard{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 14px;
  background:#fff;
}

.sbc-report__chartTitle{
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 10px;
  color: #0f172a;
}

.sbc-report__chartCard img{
  width: 100%;
  height: auto;
  display:block;
}
/* =========================================================
   PDF - Gráficas en 2 columnas (lado a lado)
========================================================= */
.sbc-report__chartsGrid{
  display: grid;
  grid-template-columns: 1fr; /* antes dos: 1fr */
  gap: 14px;
  align-items: stretch;
}

.sbc-report__chartCard{
  height: 100%;
}

/* Por seguridad: si el ancho es pequeño, que vuelvan a 1 columna */
@media (max-width: 720px){
  .sbc-report__chartsGrid{
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   PDF - Gráficas ocupando TODO el ancho del A4
========================================================= */

/* La sección de gráficas no debe ser "título izquierda + contenido derecha" */
.sbc-report .sbc-report__section.sbc-report__charts{
  display: block !important;
  width: 100% !important;
}

/* El título ocupa el ancho completo y va arriba */
.sbc-report .sbc-report__charts .sbc-report__sectionTitle{
  display: block !important;
  width: 100% !important;
  margin-bottom: 12px !important;
}

/* Grid a ancho completo en 2 columnas */
.sbc-report .sbc-report__chartsGrid{
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  align-items: stretch !important;
}

/* Las cards ocupan todo el ancho de su columna */
.sbc-report .sbc-report__chartCard{
  width: 100% !important;
}

/* Imágenes de gráficas siempre grandes */
.sbc-report .sbc-report__chartCard img{
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* Fallback si el ancho se reduce */
@media (max-width: 720px){
  .sbc-report .sbc-report__chartsGrid{
    grid-template-columns: 1fr !important;
  }
}
/* =========================================================
   v2.6 - Simulador de tamaño de batería (frontend)
========================================================= */
.sbc-sim{
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(15,23,42,.10);
}

.sbc-sim__head{
  margin-bottom: 10px;
}

.sbc-sim__title{
  margin: 40px 0 20px;
  font-size: 40px;
  font-weight: 900;
  text-align: center;
  line-height: 1.15;
  color: #0F172A;
}

.sbc-sim__desc{
  margin: 0;
  font-size: 15px;
  text-align: center;
  line-height: 1.45;
  color: rgba(15,23,42,.72);
}

.sbc-sim__controls{
  display: flex;
  gap: 16px;
  align-items: flex-end;
  flex-wrap: wrap;
  margin: 18px 0 18px;
}

.sbc-sim__control{
  flex: 1 1 360px;
}

.sbc-sim__control--num{
  flex: 0 0 150px;
}

.sbc-range{
  width: 100%;
}

.sbc-input--num{
  text-align: center;
}
/* =========================================================
   v2.6.x - Simulador: override de precio
========================================================= */
.sbc-sim__control--price{
  flex: 1 1 360px;
}

.sbc-sim__control--priceNum{
  flex: 0 0 170px;
}

.sbc-sim__tog{
  display:flex;
  align-items:center;
  gap:10px;
  margin: 6px 0 10px;
  font-size: 13px;
  color: rgba(15,23,42,.72);
}
.sbc-sim__tog input[type="checkbox"]{
  transform: translateY(1px);
}
/* FIX v5.0 - Iconos KPIs sin depender del nth-child */
.sbc-summary__item[data-sbc-kpi="battery"]::before{
  background-image: url("../icon/ico-bateria-recomendada.svg") !important;
}
.sbc-summary__item[data-sbc-kpi="savings"]::before{
  background-image: url("../icon/ico-ahorro-a.svg") !important;
}

/* Opcional: anular el icono del nth-child(2) */
.sbc-summary__item:nth-child(2)::before{
  background-image: none !important;
}
/* =========================================================
   FIX tooltips: evitar recorte por overflow del contenedor
========================================================= */
.sbc-form-card{
  overflow: visible !important;
  position: relative; /* asegura contexto y z-index consistente */
  z-index: 1;
}

/* Asegura que el tooltip quede por encima de otros elementos */
.sbc-info__tooltip{
  z-index: 9999 !important;
}

/* =========================================================
   FIX tooltips de RESULTADOS para que no se recorten 
========================================================= */

/* 1) Evita recorte por overflow en el bloque de resultados */
.sbc-results-wrap,
.sbc-results-card,
.sbc-compare,
.sbc-compare__head,
.sbc-compare__row{
  overflow: visible !important;
}

/* 2) Evita recorte por 'contain: paint' (muy traicionero) */
.sbc-results-wrap,
.sbc-results-card,
.sbc-compare{
  contain: none !important;
}

/* 3) Asegura stacking por encima del resto */
.sbc-results-wrap{ position: relative; z-index: 1; }
.sbc-compare{ position: relative; z-index: 2; }
.sbc-info{ position: relative; z-index: 10; }
.sbc-info:hover,
.sbc-info:focus-within{ z-index: 999; }
.sbc-info__tooltip{ z-index: 9999 !important; }

/* =========================================================
   MOBILE OVERRIDE (FORZADO) – Comparativa legible
   Afecta a resultados iniciales y simulación (misma estructura)
========================================================= */
@media (max-width: 680px){

  /* Más especificidad para ganar al theme y a reglas previas */
  body .sbc-wrap .sbc-compare__head,
  body .sbc-shell .sbc-compare__head,
  body .sbc-results-card .sbc-compare__head{
    display: none !important;
  }

  body .sbc-wrap .sbc-compare__row,
  body .sbc-shell .sbc-compare__row,
  body .sbc-results-card .sbc-compare__row{
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas:
      "label label"
      "sin con" !important;
    row-gap: 10px !important;
    column-gap: 10px !important;
    padding: 12px !important;
  }

  body .sbc-wrap .sbc-compare__label,
  body .sbc-shell .sbc-compare__label,
  body .sbc-results-card .sbc-compare__label{
    grid-area: label !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  /* Celdas como mini-cards */
  body .sbc-wrap .sbc-compare__val,
  body .sbc-shell .sbc-compare__val,
  body .sbc-results-card .sbc-compare__val{
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    text-align: left !important;
    gap: 6px !important;

    padding: 10px 10px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(15,23,42,.10) !important;
    background: rgba(15,23,42,.02) !important;
    min-width: 0 !important;
  }

  /* Orden típico: 1º sin, 2º con */
  body .sbc-wrap .sbc-compare__row .sbc-compare__val:nth-of-type(1),
  body .sbc-shell .sbc-compare__row .sbc-compare__val:nth-of-type(1){
    grid-area: sin !important;
  }
  body .sbc-wrap .sbc-compare__row .sbc-compare__val:nth-of-type(2),
  body .sbc-shell .sbc-compare__row .sbc-compare__val:nth-of-type(2){
    grid-area: con !important;
  }

  /* Etiquetas dentro de cada celda */
  body .sbc-wrap .sbc-compare__row .sbc-compare__val:nth-of-type(1)::before,
  body .sbc-shell .sbc-compare__row .sbc-compare__val:nth-of-type(1)::before{
    content: "Sin batería";
    font-size: 11px;
    font-weight: 900;
    color: rgba(15,23,42,.55);
    letter-spacing: .2px;
  }

  body .sbc-wrap .sbc-compare__row .sbc-compare__val:nth-of-type(2)::before,
  body .sbc-shell .sbc-compare__row .sbc-compare__val:nth-of-type(2)::before{
    content: "anteriormente sin batería";
    font-size: 11px;
    font-weight: 900;
    color: rgba(0,20,10,.80);
    letter-spacing: .2px;
  }

  /* CLAVE anti-apelotonado: permitir saltos de línea */
  body .sbc-wrap .sbc-compare__main,
  body .sbc-shell .sbc-compare__main,
  body .sbc-results-card .sbc-compare__main{
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    line-height: 1.12 !important;
  }

  body .sbc-wrap .sbc-compare__badge,
  body .sbc-shell .sbc-compare__badge,
  body .sbc-results-card .sbc-compare__badge{
    white-space: normal !important;
    line-height: 1.15 !important;
    margin: 0 !important;
  }
}