/* ═══════════════════════════════════════════════════════════════
   X-energy — Calculadora Ley 1715 · v1.1.0
   Colores corporativos: Negro · Amarillo #FFD600 · Blanco
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ── Variables de marca X-energy ─────────────────────────────── */
.protergy-calc-wrapper {
  --pc-bg:          #0d0d0d;   /* Negro principal */
  --pc-card:        #161616;   /* Negro tarjetas */
  --pc-card-2:      #1c1c1c;   /* Negro tarjetas secundarias */
  --pc-border:      #2a2a2a;   /* Borde sutil */
  --pc-accent:      #FFD600;   /* Amarillo X-energy */
  --pc-accent-2:    #FFE033;   /* Amarillo hover */
  --pc-yellow:      #FFD600;   /* Botón editar */
  --pc-text:        #ffffff;   /* Blanco texto principal */
  --pc-text-muted:  #888888;   /* Gris texto secundario */
  --pc-text-soft:   #aaaaaa;   /* Gris texto suave */
  --pc-success:     #FFD600;   /* Amarillo para checkmarks */
  --pc-radius:      12px;
  --pc-radius-sm:   8px;
  --pc-shadow:      0 4px 32px rgba(0,0,0,.7);
  --pc-font:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ── Reset suave ─────────────────────────────────────────────── */
.protergy-calc-wrapper *,
.protergy-calc-wrapper *::before,
.protergy-calc-wrapper *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ── Wrapper principal ───────────────────────────────────────── */
.protergy-calc-wrapper {
  font-family:      var(--pc-font);
  background:       var(--pc-bg);
  color:            var(--pc-text);
  border-radius:    16px;
  padding:          28px;
  display:          grid;
  grid-template-columns: 55% 1fr;
  gap:              22px;
  max-width:        1140px;
  margin:           0 auto;
  box-shadow:       var(--pc-shadow);
  /* Borde sutil amarillo */
  border:           1px solid rgba(255,214,0,.12);
}

/* ── Columnas ────────────────────────────────────────────────── */
.pc-col { display: flex; flex-direction: column; gap: 18px; }

/* ── Tarjetas / cards ────────────────────────────────────────── */
.pc-card {
  background:    var(--pc-card);
  border:        1px solid var(--pc-border);
  border-radius: var(--pc-radius);
  padding:       22px;
}

/* ── Título de sección ───────────────────────────────────────── */
.pc-title {
  font-size:     1.15rem;
  font-weight:   700;
  color:         var(--pc-text);
  margin-bottom: 16px;
  letter-spacing: .01em;
}

/* ══════════════════════════════════════════════════════════════
   SECCIÓN 1 — Input de valor
══════════════════════════════════════════════════════════════ */
.pc-input-header {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  margin-bottom:   10px;
  flex-wrap:       wrap;
  gap:             8px;
}

.pc-input-label {
  font-size:      .68rem;
  font-weight:    600;
  color:          var(--pc-text-muted);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pc-edit-btn {
  display:      flex;
  align-items:  center;
  gap:          5px;
  background:   transparent;
  border:       none;
  color:        var(--pc-yellow);
  font-size:    .78rem;
  font-weight:  600;
  cursor:       pointer;
  padding:      4px 8px;
  border-radius: 4px;
  transition:   background .2s;
}
.pc-edit-btn:hover { background: rgba(255,214,0,.1); }
.pc-edit-btn svg   { fill: var(--pc-yellow); }

.pc-input-wrap {
  display:          flex;
  align-items:      center;
  background:       #1c1c1c;
  border:           2px solid var(--pc-border);
  border-radius:    var(--pc-radius-sm);
  padding:          14px 16px;
  gap:              12px;
  transition:       border-color .2s;
}
.pc-input-wrap:focus-within {
  border-color: var(--pc-accent);
  box-shadow:   0 0 0 3px rgba(255,214,0,.1);
}

.pc-car-icon { fill: var(--pc-text-muted); flex-shrink: 0; }

/* ── FIX CRÍTICO: texto del input siempre visible ── */
.protergy-calc-wrapper .pc-vehicle-input,
.protergy-calc-wrapper .pc-vehicle-input:focus,
.protergy-calc-wrapper .pc-vehicle-input:active {
  flex:                    1;
  background:              transparent !important;
  background-color:        transparent !important;
  border:                  none !important;
  outline:                 none !important;
  color:                   #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  font-family:             var(--pc-font);
  font-size:               1.55rem;
  font-weight:             700;
  min-width:               0;
  cursor:                  default;
  box-shadow:              none !important;
  caret-color:             #FFD600;
}
.protergy-calc-wrapper .pc-vehicle-input:not([readonly]) {
  cursor: text !important;
}
.protergy-calc-wrapper .pc-vehicle-input[readonly] {
  user-select: none;
}
/* Autofill del navegador — evita fondo blanco */
.protergy-calc-wrapper .pc-vehicle-input:-webkit-autofill,
.protergy-calc-wrapper .pc-vehicle-input:-webkit-autofill:hover,
.protergy-calc-wrapper .pc-vehicle-input:-webkit-autofill:focus {
  -webkit-text-fill-color: #ffffff !important;
  -webkit-box-shadow:      0 0 0px 1000px #1c1c1c inset !important;
  transition:              background-color 5000s ease-in-out 0s;
}

.pc-currency {
  font-size:   .85rem;
  font-weight: 600;
  color:       var(--pc-text-muted);
  flex-shrink: 0;
}

.pc-hint {
  font-size:  .73rem;
  color:      var(--pc-text-muted);
  margin-top: 8px;
  text-align: center;
}

/* ══════════════════════════════════════════════════════════════
   SECCIÓN 2 — Beneficios
══════════════════════════════════════════════════════════════ */
.pc-benefit-row {
  display:       flex;
  gap:           14px;
  padding:       16px 0;
  border-bottom: 1px solid var(--pc-border);
  position:      relative;
}
.pc-benefit-row:last-of-type { border-bottom: none; }

/* Bullets A / B / C */
.pc-bullet {
  flex-shrink:     0;
  width:           34px;
  height:          34px;
  border-radius:   50%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       .85rem;
  font-weight:     700;
  margin-top:      2px;
}
.pc-bullet--circle  { background: transparent; border: 2px solid var(--pc-text-muted); color: var(--pc-text-muted); }
.pc-bullet--teal    { background: rgba(255,214,0,.12); border: 2px solid var(--pc-accent); color: var(--pc-accent); }
.pc-bullet--outline { background: transparent; border: 2px solid var(--pc-border); color: var(--pc-text-soft); }

.pc-benefit-body  { flex: 1; min-width: 0; position: relative; }

.pc-benefit-label {
  display:        block;
  font-size:      .67rem;
  font-weight:    600;
  letter-spacing: .09em;
  color:          var(--pc-accent);
  text-transform: uppercase;
  margin-bottom:  6px;
}

.pc-benefit-amount {
  font-size:     1.8rem;
  font-weight:   800;
  color:         var(--pc-text);
  line-height:   1.1;
  margin-bottom: 6px;
}
.pc-benefit-amount--large { font-size: 2rem; }

.pc-benefit-desc {
  font-size:  .8rem;
  color:      var(--pc-text-soft);
  line-height: 1.5;
}
.pc-benefit-desc strong { color: var(--pc-text); }

/* Badge 50% */
.pc-pct-badge {
  position:    absolute;
  right:       0;
  top:         0;
  font-size:   2.8rem;
  font-weight: 900;
  color:       rgba(255,255,255,.04);
  line-height: 1;
  user-select: none;
  pointer-events: none;
}

/* ── Slider ── */
.pc-slider-header {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  margin-bottom:   10px;
}
.pc-slider-text  { font-size: .72rem; font-weight: 600; color: var(--pc-text-muted); letter-spacing: .06em; }
.pc-slider-value { font-size: 1rem;   font-weight: 700; color: var(--pc-accent); }

.pc-slider {
  -webkit-appearance: none;
  appearance:         none;
  width:              100%;
  height:             5px;
  border-radius:      4px;
  outline:            none;
  cursor:             pointer;
  margin-bottom:      6px;
  background: linear-gradient(to right, var(--pc-accent) 100%, var(--pc-border) 100%);
}
.pc-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance:   none;
  width:        20px;
  height:       20px;
  border-radius: 50%;
  background:   var(--pc-accent);
  box-shadow:   0 0 0 4px rgba(255,214,0,.2);
  cursor:       pointer;
  transition:   box-shadow .2s;
}
.pc-slider::-webkit-slider-thumb:hover { box-shadow: 0 0 0 6px rgba(255,214,0,.25); }
.pc-slider::-moz-range-thumb {
  width:        20px;
  height:       20px;
  border-radius: 50%;
  background:   var(--pc-accent);
  border:       none;
  cursor:       pointer;
}

.pc-slider-marks {
  display:         flex;
  justify-content: space-between;
  font-size:       .68rem;
  color:           var(--pc-text-muted);
  margin-bottom:   12px;
}

.pc-recovery-box {
  background:    rgba(255,214,0,.06);
  border:        1px solid rgba(255,214,0,.18);
  border-radius: var(--pc-radius-sm);
  padding:       14px 16px;
  position:      relative;
}
.pc-formula {
  font-size:  .75rem;
  color:      var(--pc-text-muted);
  margin-top: 4px;
}
.pc-arrow {
  position:  absolute;
  right:     14px;
  top:       50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  color:     var(--pc-accent);
  opacity:   .6;
}

/* IVA note */
.pc-iva-note {
  display:     flex;
  align-items: flex-start;
  gap:         6px;
  font-size:   .77rem;
  color:       var(--pc-accent);
  margin-top:  8px;
  flex-wrap:   wrap;
}
.pc-iva-note svg { fill: var(--pc-accent); flex-shrink: 0; margin-top: 1px; }
.pc-optional {
  color:     var(--pc-text-muted);
  font-size: .73rem;
  width:     100%;
  padding-left: 20px;
}

/* ── Ahorro Neto ── */
.pc-net-savings {
  background:    linear-gradient(135deg, #1a1500 0%, #1c1c1c 100%);
  border:        1px solid rgba(255,214,0,.22);
  border-radius: var(--pc-radius);
  padding:       20px;
  margin-top:    4px;
}
.pc-net-header {
  display:       flex;
  align-items:   center;
  gap:           10px;
  margin-bottom: 4px;
}
.pc-check-icon {
  width:           24px;
  height:          24px;
  background:      var(--pc-accent);
  border-radius:   50%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       .75rem;
  color:           #000000;
  flex-shrink:     0;
  font-weight:     700;
}
.pc-net-title {
  font-size:      .7rem;
  font-weight:    700;
  letter-spacing: .08em;
  color:          var(--pc-text-muted);
  text-transform: uppercase;
}
.pc-net-formula {
  font-size:     .72rem;
  color:         var(--pc-text-muted);
  margin-bottom: 10px;
}
.pc-net-amount {
  font-size:     2.6rem;
  font-weight:   900;
  color:         var(--pc-accent);
  line-height:   1;
  margin-bottom: 14px;
  letter-spacing: -.01em;
}

/* Garantía */
.pc-guarantee { margin-top: 12px; }
.pc-guarantee-badge {
  display:        inline-block;
  font-size:      .65rem;
  font-weight:    700;
  letter-spacing: .06em;
  color:          var(--pc-accent);
  text-transform: uppercase;
  margin-bottom:  4px;
}
.pc-guarantee-text {
  font-size:  .77rem;
  color:      var(--pc-text-soft);
  line-height: 1.5;
}
.pc-guarantee-text strong { color: var(--pc-text); }

/* ── ROI ── */
.pc-roi-section {
  background:    var(--pc-card-2);
  border:        1px solid var(--pc-border);
  border-radius: var(--pc-radius);
  padding:       18px;
  text-align:    center;
}
.pc-roi-title {
  font-size:      .67rem;
  font-weight:    600;
  letter-spacing: .1em;
  color:          var(--pc-text-muted);
  text-transform: uppercase;
  margin-bottom:  14px;
}
.pc-roi-grid {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             12px;
  margin-bottom:   12px;
}
.pc-roi-block    { flex: 1; text-align: center; }
.pc-roi-label    { display: block; font-size: .65rem; color: var(--pc-text-muted); margin-bottom: 4px; letter-spacing: .06em; }
.pc-roi-val      { font-size: .9rem; font-weight: 700; color: var(--pc-text); }
.pc-roi-multiplier {
  background:    var(--pc-accent);
  color:         #000000;          /* Negro sobre amarillo */
  font-size:     1.6rem;
  font-weight:   900;
  border-radius: var(--pc-radius-sm);
  padding:       10px 18px;
  flex-shrink:   0;
  letter-spacing: -.01em;
}
.pc-roi-desc {
  font-size:  .75rem;
  color:      var(--pc-text-muted);
  line-height: 1.5;
}
.pc-roi-desc strong { color: var(--pc-text); }

/* ══════════════════════════════════════════════════════════════
   SECCIÓN 3 — Costos
══════════════════════════════════════════════════════════════ */
.pc-costs-top   { margin-bottom: 14px; }
.pc-costs-meta  { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.pc-costs-subtitle {
  font-size:      .65rem;
  font-weight:    600;
  letter-spacing: .09em;
  color:          var(--pc-text-muted);
  text-transform: uppercase;
}
.pc-projected-badge {
  font-size:     .65rem;
  font-weight:   600;
  color:         var(--pc-text-muted);
  border:        1px solid var(--pc-border);
  border-radius: 20px;
  padding:       2px 9px;
}

/* Filas de costo */
.pc-cost-line {
  display:         flex;
  justify-content: space-between;
  align-items:     flex-start;
  padding:         12px 0;
  border-bottom:   1px solid var(--pc-border);
  gap:             10px;
}
.pc-cost-name { font-size: .87rem; font-weight: 600; color: var(--pc-text);   margin-bottom: 2px; }
.pc-cost-sub  { font-size: .72rem; color: var(--pc-text-muted); }
.pc-cost-amount {
  font-size:   .95rem;
  font-weight: 700;
  color:       var(--pc-text);
  white-space: nowrap;
}

/* Honorarios */
.pc-cost-line--hon { align-items: flex-start; }
.pc-cost-right     { text-align: right; }
.pc-cost-original {
  display:         block;
  font-size:       .78rem;
  color:           var(--pc-text-muted);
  text-decoration: line-through;
  margin-top:      3px;
}
.pc-discount-badge {
  display:       inline-block;
  background:    rgba(255,214,0,.15);
  color:         var(--pc-accent);
  font-size:     .68rem;
  font-weight:   700;
  border-radius: 4px;
  padding:       2px 7px;
  margin-top:    4px;
}

/* Split de pago */
.pc-payment-split {
  display:       flex;
  flex-direction: column;
  gap:           5px;
  padding:       10px 12px;
  background:    rgba(255,255,255,.02);
  border-radius: var(--pc-radius-sm);
  margin:        8px 0;
}
.pc-payment-item         { font-size: .73rem; color: var(--pc-text-muted); }
.pc-payment-item--accent { color: var(--pc-accent); }

/* Total */
.pc-total-row {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  padding:         14px 0 10px;
  border-top:      1px solid var(--pc-border);
  margin-top:      6px;
}
.pc-total-label  { font-size: .95rem; font-weight: 700; color: var(--pc-text); }
.pc-total-amount { font-size: 1.3rem; font-weight: 800; color: var(--pc-accent); }

.pc-includes-note {
  display:       flex;
  align-items:   center;
  gap:           6px;
  font-size:     .75rem;
  color:         var(--pc-text-muted);
  padding:       8px;
  background:    rgba(255,214,0,.05);
  border-radius: 6px;
  margin-top:    4px;
}
.pc-includes-note svg { fill: var(--pc-accent); flex-shrink: 0; }

/* ── Servicios ── */
.pc-card--services { padding: 18px 22px; }
.pc-services-title {
  display:        flex;
  align-items:    center;
  gap:            8px;
  font-size:      .72rem;
  font-weight:    700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color:          var(--pc-text-muted);
  margin-bottom:  14px;
}
.pc-services-title svg { fill: var(--pc-text-muted); }

.pc-services-list { list-style: none; display: flex; flex-direction: column; gap: 14px; }
.pc-services-list li { display: flex; gap: 10px; align-items: flex-start; }
.pc-svc-check {
  font-size:   .85rem;
  color:       var(--pc-success);
  font-weight: 700;
  flex-shrink: 0;
  margin-top:  1px;
}
.pc-services-list strong {
  font-size:     .85rem;
  font-weight:   600;
  color:         var(--pc-text);
  display:       block;
  margin-bottom: 2px;
}
.pc-services-list p {
  font-size:  .77rem;
  color:      var(--pc-text-muted);
  line-height: 1.4;
}

/* ── Botones ── */
.pc-actions { display: flex; flex-direction: column; gap: 10px; }

.pc-btn {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             8px;
  width:           100%;
  padding:         15px 20px;
  border-radius:   var(--pc-radius-sm);
  font-family:     var(--pc-font);
  font-size:       .88rem;
  font-weight:     700;
  letter-spacing:  .07em;
  cursor:          pointer;
  text-align:      center;
  transition:      all .2s ease;
  text-decoration: none;
  border:          none;
}

/* Botón primario: amarillo X-energy con texto negro */
.pc-btn--primary {
  background: var(--pc-accent);
  color:      #000000 !important;
  box-shadow: 0 4px 20px rgba(255,214,0,.25);
}
.pc-btn--primary:hover {
  background:      var(--pc-accent-2);
  box-shadow:      0 6px 24px rgba(255,214,0,.35);
  transform:       translateY(-1px);
  color:           #000000 !important;
  text-decoration: none;
}
.pc-btn--primary:active { transform: translateY(0); }

/* Botón secundario: transparente con borde */
.pc-btn--secondary {
  background: transparent;
  color:      var(--pc-text);
  border:     1px solid var(--pc-border);
}
.pc-btn--secondary:hover {
  border-color: var(--pc-accent);
  color:        var(--pc-accent);
  background:   rgba(255,214,0,.05);
}
.pc-btn--secondary svg { fill: currentColor; }

/* ── Nota legal ── */
.pc-legal-note {
  display:       flex;
  align-items:   flex-start;
  gap:           6px;
  font-size:     .72rem;
  color:         var(--pc-text-muted);
  line-height:   1.5;
  padding:       10px;
  background:    rgba(255,255,255,.02);
  border-radius: var(--pc-radius-sm);
}
.pc-legal-note svg { fill: var(--pc-text-muted); flex-shrink: 0; margin-top: 2px; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .protergy-calc-wrapper {
    grid-template-columns: 1fr;
    padding: 20px;
    gap: 16px;
  }
}

@media (max-width: 480px) {
  .protergy-calc-wrapper     { padding: 14px; border-radius: 10px; }
  .pc-vehicle-input          { font-size: 1.2rem !important; }
  .pc-benefit-amount         { font-size: 1.4rem; }
  .pc-benefit-amount--large  { font-size: 1.6rem; }
  .pc-net-amount             { font-size: 2rem; }
  .pc-roi-multiplier         { font-size: 1.3rem; padding: 8px 14px; }
  .pc-btn                    { font-size: .8rem; padding: 13px 16px; }

  .pc-roi-grid        { flex-direction: column; gap: 8px; }
  .pc-roi-block       { width: 100%; }
  .pc-roi-multiplier  { width: 100%; }

  .pc-input-header    { flex-direction: column; align-items: flex-start; }
  .pc-cost-line       { flex-direction: column; }
}
