* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; background: #f0fdf4; min-height: 100vh; padding: 1rem; }
.container { max-width: 80rem; margin: 0 auto; }
.card { background: white; border-radius: 1rem; box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1); overflow: hidden; border: 1px solid #bbf7d0; }
.header { background: linear-gradient(to right, #166534, #22c55e); padding: 1.5rem; color: white; }
.header-title { display: flex; align-items: center; gap: .75rem; margin-bottom: .5rem; }
.header-title h1 { font-size: 1.875rem; font-weight: bold; }
.header-subtitle { color: #bbf7d0; }
main { display: block; }
.content { padding: 2rem; }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 2rem; }
.section { display: flex; flex-direction: column; gap: 1.5rem; }
.section-title { font-size: 1.25rem; font-weight: 600; color: #14532d; }
.box { background: #f9fafb; padding: 1.25rem; border-radius: .75rem; border: 1px solid #e5e7eb; }
.label { display: flex; align-items: center; gap: .5rem; font-size: .875rem; font-weight: 500; color: #374151; margin-bottom: .75rem; }
.label-subtitle { margin-top: .75rem; }
.helper-text { font-size: .75rem; color: #6b7280; margin-top: .5rem; }
.muted-caption { font-size: .8rem; color: #6b7280; }
.paragraph-spaced { margin-bottom: .5rem; }
.chip-group { display: flex; gap: .5rem; margin-top: .5rem; flex-wrap: wrap; }
.button-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.btn { padding: .75rem; border-radius: .5rem; font-weight: 500; border: 1px solid #d1d5db; cursor: pointer; transition: all .2s; background: white; color: #166534; }
.btn.active { background: #16a34a; border-color: #15803d; color: white; box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1); }
.btn.active-purple { background: #15803d; border-color: #166534; color: white; box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1); }
.btn:hover { opacity: .93; }
.btn-subtitle { font-size: .75rem; margin-top: .25rem; opacity: .9; }
.select { width: 100%; padding: .6rem .75rem; border-radius: .5rem; border: 1px solid #d1d5db; font-size: .9rem; color: #14532d; background: white; }
.checkbox-box { display: flex; align-items: flex-start; gap: .75rem; padding: 1rem; border-radius: .5rem; cursor: pointer; }
.checkbox-box input { margin-top: .25rem; width: 1.25rem; height: 1.25rem; cursor: pointer; }
.checkbox-box input:disabled { cursor: not-allowed; }
.checkbox-box input:disabled + .checkbox-content { opacity: .6; }
.checkbox-content { flex: 1; }
.checkbox-title { font-weight: 500; color: #14532d; }
.checkbox-desc { font-size: .875rem; color: #374151; margin-top: .25rem; }
.checkbox-price { font-size: .875rem; font-weight: 600; margin-top: .25rem; }
.price-note-blue { color: #0369a1; }
.warning-box { background: #fefce8; border: 1px solid #facc15; padding: 1.25rem; border-radius: .75rem; }
.warning-text { color: #b45309; }
.info-box { background: #ecfdf5; border: 1px solid #6ee7b7; padding: 1.25rem; border-radius: .75rem; }
.extra-moves { background: #ecfdf5; border: 1px solid #86efac; }
.extra-manguera { background: #fef2f2; border: 1px solid #fecaca; }
.extra-ipack { background: #e0f2fe; border: 1px solid #7dd3fc; }
.extras-title { font-weight: 600; color: #14532d; }
.result-box { background: linear-gradient(to bottom right, #14532d, #16a34a); color: white; padding: 1.5rem; border-radius: .75rem; box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1); }
.result-label { font-size: .875rem; opacity: .9; margin-bottom: .5rem; }
.result-price { font-size: 1.75rem; font-weight: bold; margin-bottom: .25rem; min-height: 2rem; }
.result-subtitle { font-size: .875rem; opacity: .9; }
.result-breakdown { margin-top: .75rem; border-top: 1px solid rgba(255, 255, 255, 0.3); padding-top: .5rem; font-size: .85rem; }
.result-row { display: flex; justify-content: space-between; font-size: .9rem; margin-top: .25rem; }
.result-row span:last-child { font-weight: 600; }
.result-total-label, .result-total-value { font-weight: 700; }
.desglose-box { background: #f9fafb; padding: 1.5rem; border-radius: .75rem; border: 1px solid #e5e7eb; }
.desglose-title { font-weight: 600; color: #14532d; margin-bottom: 1rem; }
.desglose-items { display: flex; flex-direction: column; gap: .5rem; }
.desglose-item { display: flex; justify-content: space-between; align-items: flex-start; padding: .5rem .75rem; border-radius: .5rem; background: white; border: 1px solid #e5e7eb; font-size: .875rem; }
.desglose-item.destacado { background: #ecfdf5; border-color: #6ee7b7; }
.desglose-concepto-wrapper { display: flex; align-items: flex-start; gap: .35rem; flex: 1; }
.desglose-concepto { color: #374151; max-width: 70%; }
.desglose-precio { font-weight: 600; font-size: .875rem; white-space: nowrap; margin-left: .5rem; color: #111827; }
.desglose-precio.descuento { color: #16a34a; }
.desglose-precio.negativo { color: #b91c1c; }
.info-btn { border: none; background: #e0f2fe; color: #0369a1; border-radius: 9999px; width: 1.5rem; height: 1.5rem; font-size: .85rem; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; padding: 0; transition: background .15s; }
.info-btn:hover { background: #bae6fd; }
.instalacion-info-panel { margin-top: 1rem; border: 1px solid #bae6fd; background: #eff6ff; border-radius: .75rem; padding: 1rem; font-size: .85rem; color: #0f172a; }
.instalacion-info-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem; gap: .5rem; }
.instalacion-info-title { font-weight: 600; color: #0c4a6e; }
.close-info-btn { border: none; background: none; font-size: 1.25rem; line-height: 1; cursor: pointer; color: #0c4a6e; }
.close-info-btn:hover { color: #1d4ed8; }
.instalacion-info-content ul { margin-left: 1rem; margin-top: .35rem; list-style: disc; }
.instalacion-info-content li { margin-bottom: .15rem; }
.instalacion-info-note { margin-top: .5rem; color: #0c4a6e; font-weight: 500; }
.promo-box { margin-top: 1rem; background: #ecfdf5; border: 1px solid #6ee7b7; padding: .75rem 1rem; border-radius: .75rem; font-size: .8rem; color: #065f46; display: none; }
.cashback-box { margin-top: 1rem; background: #e0f2fe; border: 1px solid #7dd3fc; padding: .75rem 1rem; border-radius: .75rem; font-size: .8rem; color: #0f172a; }
.accordion { margin-top: 1.5rem; padding: 1rem 1.1rem; background: #f9fafb; border-radius: .75rem; border: 1px solid #e5e7eb; }
.accordion-header { display: flex; justify-content: space-between; align-items: center; cursor: pointer; font-size: .9rem; font-weight: 500; color: #14532d; width: 100%; background: none; border: none; text-align: left; padding: 0; }
.accordion-header:focus { outline: 2px solid #16a34a; outline-offset: 2px; }
.accordion-icon { font-size: .8rem; transition: transform .2s; }
.accordion.open .accordion-icon { transform: rotate(90deg); }
.accordion-body { margin-top: .75rem; display: none; }
.ssaa-grid { display: flex; flex-direction: column; gap: .75rem; margin-top: .5rem; }
.ssaa-item { background: #ecfdf5; border: 1px solid #6ee7b7; border-radius: .75rem; padding: .75rem 1rem; font-size: .8rem; }
.ssaa-title { font-weight: 600; color: #14532d; margin-bottom: .15rem; }
.ssaa-tagline { font-size: .78rem; color: #047857; margin-bottom: .25rem; }
.ssaa-list { margin-left: 1rem; list-style: disc; color: #374151; }
.ssaa-list li { margin-bottom: .15rem; }
.charger-info-header { margin-top: 1rem; }
.chip-btn { border-radius: 9999px; border: 1px solid #d1d5db; background: white; font-size: .75rem; padding: .35rem .75rem; cursor: pointer; color: #166534; display: inline-flex; align-items: center; gap: .25rem; transition: all .15s; }
.chip-btn:hover { background: #ecfdf5; }
.chip-btn.active-chip { background: #16a34a; border-color: #15803d; color: white; }
.info-detail-box { margin-top: .5rem; padding: .75rem 1rem; background: #ecfdf5; border-radius: .75rem; border: 1px solid #6ee7b7; font-size: .8rem; color: #064e3b; display: none; }
.info-detail-box ul { margin-top: .35rem; margin-left: 1rem; list-style: disc; }
.info-detail-box li { margin-bottom: .15rem; }
.info-detail-note { margin-top: .35rem; }
.phase-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; margin-top: .5rem; }
.phase-btn { padding: .5rem .75rem; border: 1px solid #d1d5db; border-radius: .5rem; background: white; color: #166534; font-size: .85rem; cursor: pointer; }
.phase-btn.active { background: #16a34a; border-color: #15803d; color: #fff; }
.hidden { display: none; }
.badge-tri { margin-top: .5rem; display: inline-flex; align-items: center; gap: .4rem; padding: .35rem .6rem; font-size: .78rem; border-radius: 9999px; border: 1px solid #f59e0b; background: #fffbeb; color: #92400e; }
.trifasico-note { margin-top: .75rem; background: #fffbeb; border: 1px solid #f59e0b; color: #92400e; padding: .75rem 1rem; border-radius: .75rem; font-size: .85rem; display: none; }
.result-region { position: relative; }
@media (prefers-reduced-motion: reduce) {
  * { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}
