/* ─────────────────────────────────────────────────────────────
   Contratos Operador v4.0 — Resumen oferta
   Wrapper: .co_resume
   IDs #sentim_resume / #sentim_resume_out son de Gravity Forms,
   no se pueden renombrar — se mantienen como selectores alternativos.
   ───────────────────────────────────────────────────────────── */

.co_resume,
#sentim_resume,
#sentim_resume_out {
  --sr-accent:    #FF4502;
  --sr-ink:       #2C1A03;
  --sr-muted:     rgba(44,26,3,.62);
  --sr-border:    rgba(44,26,3,.12);
  --sr-bg:        #FFFFFF;
  --sr-surface:   rgba(255,69,2,.05);
  --sr-surface-2: rgba(44,26,3,.035);
  --sr-radius:    14px;
  color: var(--sr-ink);
  font-size: 14px;
  line-height: 1.45;
}

/* Utilidad */
.co-hidden { display: none; }

/* Separadores */
.co_resume .co-resume__sep,
#sentim_resume .co-resume__sep,
#sentim_resume_out .co-resume__sep {
  border: 0; height: 1px;
  background: var(--sr-border);
  margin: 14px 0;
}

/* Bloques */
.co_resume .co-resume__block,
#sentim_resume .co-resume__block,
#sentim_resume_out .co-resume__block {
  background: var(--sr-bg);
  border: 1px solid var(--sr-border);
  border-radius: var(--sr-radius);
  padding: 14px 16px;
}

/* PLAN con banda naranja */
.co_resume .co-resume__plan,
#sentim_resume .co-resume__plan,
#sentim_resume_out .co-resume__plan {
  border-left: 5px solid var(--sr-accent);
  padding-left: 14px;
}

/* Títulos */
.co_resume .co-resume__title,
#sentim_resume .co-resume__title,
#sentim_resume_out .co-resume__title {
  display: flex; align-items: baseline; gap: 10px;
  font-weight: 900; font-size: 15px; margin: 0 0 10px 0;
}

.co_resume .co-resume__meta,
#sentim_resume .co-resume__meta,
#sentim_resume_out .co-resume__meta {
  font-weight: 700; color: var(--sr-muted);
}

/* Filas */
.co_resume .co-resume__row,
#sentim_resume .co-resume__row,
#sentim_resume_out .co-resume__row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 12px; align-items: baseline; padding: 6px 0;
}

.co_resume .co-resume__label,
#sentim_resume .co-resume__label,
#sentim_resume_out .co-resume__label {
  color: var(--sr-muted); font-weight: 700;
}

.co_resume .co-resume__value,
#sentim_resume .co-resume__value,
#sentim_resume_out .co-resume__value {
  font-weight: 950; font-size: 17px; white-space: nowrap; color: var(--sr-ink);
}

/* Sub-bloques */
.co_resume .co-resume__subblock,
#sentim_resume .co-resume__subblock,
#sentim_resume_out .co-resume__subblock {
  margin-top: 12px; padding: 12px; border-radius: 12px;
  background: var(--sr-surface-2); border: 1px solid rgba(44,26,3,.08);
}

.co_resume .co-resume__subtitle,
#sentim_resume .co-resume__subtitle,
#sentim_resume_out .co-resume__subtitle {
  font-weight: 900; margin: 0 0 8px 0; color: rgba(44,26,3,.85);
}

/* Lista items */
.co_resume .co-resume__list,
#sentim_resume .co-resume__list,
#sentim_resume_out .co-resume__list {
  display: flex; flex-direction: column; gap: 0;
}

.co_resume .co-resume__item,
#sentim_resume .co-resume__item,
#sentim_resume_out .co-resume__item {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  grid-template-areas: "qty name total" "qty unit total";
  column-gap: 10px; row-gap: 2px; padding: 10px 0;
  border-bottom: 1px dashed rgba(44,26,3,.18);
}

.co_resume .co-resume__item:last-child,
#sentim_resume .co-resume__item:last-child,
#sentim_resume_out .co-resume__item:last-child { border-bottom: 0; }

.co_resume .co-resume__qty,
#sentim_resume .co-resume__qty,
#sentim_resume_out .co-resume__qty {
  grid-area: qty; font-weight: 950; color: rgba(44,26,3,.72);
}

.co_resume .co-resume__item-name,
#sentim_resume .co-resume__item-name,
#sentim_resume_out .co-resume__item-name {
  grid-area: name; font-weight: 800;
}

.co_resume .co-resume__unit,
#sentim_resume .co-resume__unit,
#sentim_resume_out .co-resume__unit {
  grid-area: unit; color: var(--sr-muted); font-size: 12.5px;
}

.co_resume .co-resume__eq,
#sentim_resume .co-resume__eq,
#sentim_resume_out .co-resume__eq { display: none; }

.co_resume .co-resume__item-total,
#sentim_resume .co-resume__item-total,
#sentim_resume_out .co-resume__item-total {
  grid-area: total; font-weight: 950; white-space: nowrap; color: rgba(44,26,3,.92);
}

/* Extras */
.co_resume .co-resume__extras-list,
#sentim_resume .co-resume__extras-list,
#sentim_resume_out .co-resume__extras-list {
  margin-top: 8px; color: rgba(44,26,3,.78);
}

/* Comentarios de sección */
.co_resume .co-resume__section-note,
#sentim_resume .co-resume__section-note,
#sentim_resume_out .co-resume__section-note {
  font-size: 12px; color: var(--sr-muted); margin-top: 6px; font-style: italic;
}

/* Notas permanencia/condiciones */
.co_resume .co-resume__note,
#sentim_resume .co-resume__note,
#sentim_resume_out .co-resume__note {
  font-size: 12px; color: var(--sr-muted); margin-top: 4px;
}

/* TOTAL mensual */
.co_resume .co-resume__total,
#sentim_resume .co-resume__total,
#sentim_resume_out .co-resume__total {
  border-color: rgba(255,69,2,.32);
  background: linear-gradient(180deg, rgba(255,69,2,.14), rgba(255,69,2,.06));
}

.co_resume .co-resume__row--total,
#sentim_resume .co-resume__row--total,
#sentim_resume_out .co-resume__row--total { padding: 8px 0 0 0; }

.co_resume .co-resume__label--total,
#sentim_resume .co-resume__label--total,
#sentim_resume_out .co-resume__label--total {
  font-weight: 950; font-size: 16px; color: rgba(44,26,3,.90);
}

.co_resume .co-resume__value--total,
#sentim_resume .co-resume__value--total,
#sentim_resume_out .co-resume__value--total {
  font-weight: 1000; font-size: 24px; letter-spacing: .2px; color: var(--sr-ink);
}

/* ── Sidebar scroll (resumen flotante lateral) ─────────────── */
.sidebar-scroll {
  position: fixed;
  top: 90px; right: 24px;
  width: 360px;
  height: calc(100vh - 90px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 999;
}

@media (max-width: 980px) {
  .sidebar-scroll {
    position: static;
    width: auto; height: auto;
    overflow: visible;
    right: auto; top: auto; z-index: auto;
  }
}

@media (max-width: 600px) {
  .co_resume .co-resume__block,
  #sentim_resume .co-resume__block,
  #sentim_resume_out .co-resume__block { padding: 12px; }

  .co_resume .co-resume__value,
  #sentim_resume .co-resume__value,
  #sentim_resume_out .co-resume__value { font-size: 16px; }

  .co_resume .co-resume__value--total,
  #sentim_resume .co-resume__value--total,
  #sentim_resume_out .co-resume__value--total { font-size: 22px; }

  .co_resume .co-resume__item,
  #sentim_resume .co-resume__item,
  #sentim_resume_out .co-resume__item {
    grid-template-columns: 34px 1fr;
    grid-template-areas: "qty name" "qty unit" "qty total";
  }

  .co_resume .co-resume__item-total,
  #sentim_resume .co-resume__item-total,
  #sentim_resume_out .co-resume__item-total { justify-self: end; margin-top: 4px; }
}

/* Contenedor de campos de línea: nunca desborda */
.sl-fields {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
}

/* ── Scanner ICCID ────────────────────────────────────────────────────── */
.sl-iccid-wrap {
  display: grid;
  grid-template-columns: 1fr 40px;
  gap: 6px;
  width: 100%;
  box-sizing: border-box;
}
.sl-iccid-wrap .sl-iccid {
  width: 100% !important;
  min-width: 0;
  box-sizing: border-box;
}
.sl-scan-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #f9f9f9;
  color: #555;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.sl-scan-btn:hover {
  background: #1a2540;
  border-color: #1a2540;
  color: #fff;
}
.sl-scan-btn svg {
  width: 18px;
  height: 18px;
  pointer-events: none;
}

/* Modal scanner */
#co-scan-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999999;
  background: rgba(0,0,0,.82);
  align-items: center;
  justify-content: center;
  padding: 16px;
}
#co-scan-inner {
  background: #fff;
  border-radius: 12px;
  padding: 20px 16px 16px;
  max-width: 420px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
#co-scan-label {
  font-size: 14px;
  font-weight: 600;
  color: #1a2540;
  margin: 0;
  text-align: center;
}
#co-scan-viewport {
  position: relative;
  width: 100%;
  border-radius: 8px;
  overflow: hidden;
  background: #000;
  aspect-ratio: 16/9;
}
#co-scan-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#co-scan-line {
  position: absolute;
  left: 10%;
  right: 10%;
  top: 50%;
  height: 2px;
  background: rgba(255, 69, 2, .85);
  box-shadow: 0 0 6px rgba(255,69,2,.7);
  animation: co-scan-sweep 2s ease-in-out infinite;
}
@keyframes co-scan-sweep {
  0%, 100% { top: 30%; }
  50%       { top: 70%; }
}
#co-scan-status {
  font-size: 13px;
  color: #c0392b;
  margin: 0;
  text-align: center;
  min-height: 18px;
}
#co-scan-close {
  padding: 8px 24px;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #f0f0f0;
  color: #333;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
#co-scan-close:hover {
  background: #e0e0e0;
}

/* ── Secciones secundarias del resumen (v5.0) ─────────────────────────── */
.co-resume__sec--secondary {
  border-left-color: var(--co-accent-20, rgba(255,69,2,.20));
  background: transparent;
}
.co-resume__sec--secondary .co-resume__title {
  /* Título de sección: prominente, es el nombre de la categoría */
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
  color: var(--sr-ink, rgba(44,26,3,.92));
  margin-bottom: 8px;
}
.co-resume__sec--secondary .co-resume__item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 12.5px;
  padding: 4px 0;
  border-bottom: 1px solid rgba(0,0,0,.05);
}
/* Items dentro de sección secundaria: menos peso que el título */
.co-resume__sec--secondary .co-resume__item-name {
  font-weight: 500;
  color: var(--sr-muted, rgba(44,26,3,.70));
}
.co-resume__sec--secondary .co-resume__item-total {
  font-weight: 700;
  font-size: 13px;
}
.co-resume__sec--secondary .co-resume__item:last-child { border-bottom: none; }
.co-resume__row--subtotal {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
  padding-top: 5px;
  border-top: 1px solid rgba(0,0,0,.1);
  font-size: 12px;
  font-weight: 700;
}

/* ── Tag "Incluido en la tarifa" junto al título de sección (v5.0.6) ───── */
.co-resume__plan-tag {
  display: inline-block;
  margin-left: 8px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--co-muted, rgba(44,26,3,.62));
  vertical-align: middle;
}
.co-resume__item--bono {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid rgba(0,0,0,.08);
  font-size: 12.5px;
}

/* ── Título de sección secundaria con precio inline (v5.0.7) ────────────── */
.co-resume__title--row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.co-resume__title-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--co-dark, #1a2540);
  white-space: nowrap;
  margin-left: 8px;
}

/* ── Bloque líneas móviles en resumen (v5.1.6) ──────────────────────────── */
.co-resume__item-total--included {
  font-size: 11px;
  font-weight: 600;
  color: var(--sr-muted, rgba(44,26,3,.55));
  letter-spacing: .02em;
}
.co-resume__item--extra-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0 2px;
  border-top: 1px solid rgba(0,0,0,.07);
  margin-top: 4px;
}
.co-resume__item--extra-header:first-of-type {
  border-top: none;
  margin-top: 0;
}
.co-resume__line-detail {
  font-size: 11.5px;
  color: var(--sr-muted, rgba(44,26,3,.60));
  padding: 1px 0 1px 10px;
}
.co-resume__line-meta {
  font-size: 11px;
  color: var(--sr-muted, rgba(44,26,3,.50));
  padding: 0 0 4px 10px;
}
