/* cotizador.css — modal 50/50 con reseña + gráfico + formulario moderno */

.modal.modal--wide .modal__panel--split{
  max-width: 980px;
  width: 94%;
  padding: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 30px 80px rgba(10,32,56,.35);
}
.modal.is-open .modal__panel--split{ animation: modalIn .35s cubic-bezier(.2,.9,.3,1.2); }

.modal__close--floating{
  position:absolute; top:14px; right:14px; z-index:5;
  width:38px; height:38px; border-radius:50%;
  background: rgba(255,255,255,.92); border:0;
  display:inline-flex; align-items:center; justify-content:center;
  color: var(--color-navy); cursor:pointer;
  box-shadow: 0 6px 18px rgba(10,32,56,.2);
  transition: transform .2s ease, background .2s ease;
}
.modal__close--floating:hover{ background:#fff; transform: rotate(90deg); }

/* ---- Lado info (izquierda) ---- */
.modal__info{
  padding: 34px 32px;
  color:#fff;
  background: linear-gradient(135deg, var(--color-navy-dark) 0%, var(--color-navy) 65%, #143a66 100%);
  position:relative;
  overflow:hidden;
}
.modal__info::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(circle at 20% 10%, rgba(245,130,32,.25), transparent 45%);
  pointer-events:none;
}
.modal__info > *{ position:relative; z-index:1; }
.modal__info--hogar{           background: linear-gradient(135deg,#0a2038,#154a7a 70%,#1d6aa8); }
.modal__info--vehiculo{        background: linear-gradient(135deg,#0a2038,#1a3d5e 70%,#2c5f8d); }
.modal__info--salud{           background: linear-gradient(135deg,#0a2038,#18467a 70%,#d13a5a); }
.modal__info--viajes{          background: linear-gradient(135deg,#0a2038,#0f3a62 60%,#1aa0a8); }
.modal__info--accidentes{      background: linear-gradient(135deg,#0a2038,#163d6a 70%,#c85a1a); }
.modal__info--responsabilidad{ background: linear-gradient(135deg,#0a2038,#1a3a5e 70%,#6a4ea0); }
.modal__info--pasajeros{       background: linear-gradient(135deg,#0a2038,#143a66 70%,#1a8a6a); }
.modal__info--equipos{         background: linear-gradient(135deg,#0a2038,#163c6a 70%,#3a6aa0); }

.modal__info-head{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.modal__info-ic{
  width:52px; height:52px; border-radius:12px;
  display:inline-flex; align-items:center; justify-content:center;
  background: var(--color-primary); color:#fff;
  box-shadow: 0 10px 24px rgba(245,130,32,.4);
}
.modal__info-kicker{
  display:block; font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  opacity:.7; font-weight:700;
}
.modal__info-title{ margin:2px 0 0; font-size:26px; font-weight:800; letter-spacing:-.01em; }
.modal__info-about{ font-size:14px; line-height:1.55; opacity:.92; margin:0 0 18px; }

/* Gráfico de barras */
.modal__chart{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  padding: 16px 16px 14px;
  margin-bottom: 18px;
  backdrop-filter: blur(6px);
}
.modal__chart-head{
  display:flex; justify-content:space-between; align-items:baseline;
  margin-bottom:12px;
}
.modal__chart-head strong{ font-size:13px; font-weight:700; letter-spacing:.02em; }
.modal__chart-head span{ font-size:11px; opacity:.65; }

.bar-chart{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.bar-chart__item{
  display:grid;
  grid-template-columns: 110px 1fr 74px;
  align-items:center; gap:10px;
  font-size:12.5px;
}
.bar-chart__label{ opacity:.9; }
.bar-chart__track{
  height:8px; border-radius:999px;
  background: rgba(255,255,255,.12); overflow:hidden;
  position:relative;
}
.bar-chart__fill{
  display:block; height:100%;
  width:0;
  background: linear-gradient(90deg, var(--color-primary), #ffb36a);
  border-radius:999px;
  box-shadow: 0 0 10px rgba(245,130,32,.5);
  transition: width 1.1s cubic-bezier(.2,.9,.3,1);
}
.modal.is-open .bar-chart__fill{ width: var(--v, 0%); }
.bar-chart__value{
  text-align:right; font-weight:700; font-size:13px; line-height:1.1;
}
.bar-chart__value small{
  display:block; font-weight:500; font-size:10px; opacity:.6;
  text-transform:uppercase; letter-spacing:.06em; margin-top:1px;
}

.modal__benefits{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:8px;
  font-size:13px;
}
.modal__benefits li{ display:flex; align-items:flex-start; gap:8px; opacity:.95; }
.modal__benefit-ic{
  width:22px; height:22px; border-radius:50%;
  background: rgba(245,130,32,.2); color: var(--color-primary);
  display:inline-flex; align-items:center; justify-content:center;
  flex:none; margin-top:1px;
}

/* ---- Lado formulario (derecha) ---- */
.modal__formside{
  padding: 34px 32px;
  background:#fff;
  display:flex; flex-direction:column; justify-content:center;
}
.modal__formside-head{ margin-bottom: 18px; }
.modal__formside-head h4{
  margin:0 0 4px; font-size:22px; color: var(--color-navy); font-weight:800; letter-spacing:-.01em;
}
.modal__formside-head p{ margin:0; color:#6b7a8f; font-size:13.5px; }

.modal-form{ display:flex; flex-direction:column; gap:14px; }
.mf-row{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }

.mf{ position:relative; }
.mf input, .mf textarea{
  width:100%;
  padding: 18px 14px 10px;
  border: 1.5px solid #e1e7ef;
  border-radius: 8px;
  font: inherit;
  color: var(--color-navy);
  background: #fff;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.mf textarea{ resize:vertical; min-height:90px; padding-top: 22px; }
.mf label{
  position:absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color:#94a1b5; font-size:14px;
  pointer-events:none;
  background: transparent;
  padding: 0 4px;
  transition: transform .18s ease, font-size .18s ease, color .18s ease, top .18s ease;
}
.mf--area label{ top: 18px; transform:none; }
.mf input:focus, .mf textarea:focus{
  outline:none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(245,130,32,.15);
  background:#fffdfa;
}
.mf input:focus + label,
.mf input:not(:placeholder-shown) + label,
.mf textarea:focus + label,
.mf textarea:not(:placeholder-shown) + label{
  top: 0;
  transform: translateY(-50%);
  font-size: 11px;
  font-weight: 700;
  color: var(--color-primary);
  background: #fff;
  letter-spacing:.04em;
  text-transform: uppercase;
}

.modal-form__submit{
  margin-top: 6px;
  padding: 14px 18px;
  font-size: 15px;
  font-weight: 700;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.modal-form__arrow{ transition: transform .25s ease; display:inline-block; }
.modal-form__submit:hover .modal-form__arrow{ transform: translateX(4px); }

.modal-form__small{
  margin: 4px 0 0; font-size: 11.5px; color:#8a95a7; text-align:center;
}

/* ---- Responsive ---- */
@media (max-width: 860px){
  .modal.modal--wide .modal__panel--split{
    grid-template-columns: 1fr;
    max-height: 92vh;
    overflow-y: auto;
  }
  .modal__info{ padding: 26px 22px; }
  .modal__formside{ padding: 26px 22px; }
  .bar-chart__item{ grid-template-columns: 95px 1fr 66px; }
}
