
/* ==============================
   AVIAJAR - CLIENTE ULTRA (APP)
   ============================== */
.avp-app{ padding:18px 0; }
.avp-app-shell{
  max-width:1180px;
  margin:0 auto;
  padding:0 18px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#111;
}

/* =========================================
   Pax draft meta (cliente)
   ========================================= */
.avp-pax-meta{
  background:#f6f7fb;
  border:1px solid rgba(15,15,20,.10);
  border-radius:14px;
  padding:12px 14px;
}
.avp-input--upper{ text-transform:uppercase; }
.avp-input--lower{ text-transform:lowercase; }


/* =============================
   PAX (CLIENTE) - Premium tipo Asesor
   (Para enlaces de diligenciamiento de pasajeros)
   ============================= */

.avp-app-shell .avp-card{
  background:#fff;
  border-radius:22px;
  box-shadow:0 22px 70px rgba(0,0,0,.10);
  border:1px solid rgba(15,15,20,.06);
}

.avp-app-shell .avp-card--sub{
  background: linear-gradient(180deg, #ffffff, #fbfcff);
  box-shadow: 0 14px 40px rgba(0,0,0,.08);
  border-radius: 18px;
  border: 1px solid rgba(15,15,20,.06);
}

.avp-app-shell .avp-section-title{
  font-weight: 900;
  letter-spacing: .8px;
  text-transform: uppercase;
  color: rgba(17,17,17,.62);
  font-size: 12px;
}

.avp-app-shell .avp-form label{
  display:block;
  font-size:12px;
  font-weight:900;
  letter-spacing:.7px;
  text-transform:uppercase;
  color: rgba(17,17,17,.62);
  margin: 0 0 6px 0;
}

.avp-app-shell .avp-form input,
.avp-app-shell .avp-form select,
.avp-app-shell .avp-form textarea{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  border-radius:16px;
  padding:11px 12px;
  border:1px solid rgba(15,15,20,.14);
  background:#fff;
  outline:none;
  transition: box-shadow .15s ease, border-color .15s ease;
  font-size:14px;
  font-weight:800;
  color:#111;
}

.avp-app-shell .avp-form input:focus,
.avp-app-shell .avp-form select:focus,
.avp-app-shell .avp-form textarea:focus{
  border-color: rgba(255,179,0,.85);
  box-shadow: 0 0 0 4px rgba(255,179,0,.18);
}

.avp-app-shell .avp-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:14px;
}

.avp-app-shell .avp-grid > div{ min-width:0; }

/* Visual: muestra nombres/documentos en MAYÚSCULAS */
.avp-app-shell .avp-pax-draft-form input[name^="pax_first_"],
.avp-app-shell .avp-pax-draft-form input[name^="pax_last_"],
.avp-app-shell .avp-pax-draft-form input[name^="pax_doc_"],
.avp-app-shell .avp-pax-wrap input[name^="traveler_first_"],
.avp-app-shell .avp-pax-wrap input[name^="traveler_last_"],
.avp-app-shell .avp-pax-wrap input[name^="traveler_doc_"]{
  text-transform: uppercase;
}

@media (max-width: 980px){
  .avp-app-shell .avp-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 520px){
  .avp-app-shell .avp-grid{ grid-template-columns: 1fr; }
}


/* HERO */
.avp-hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:26px 26px;
  border-radius:26px;
  background:
    radial-gradient(1200px 280px at 20% 20%, rgba(255,179,0,.18), transparent 60%),
    linear-gradient(120deg, #0f0f14, #1c1c24);
  color:#fff;
  box-shadow:0 30px 90px rgba(0,0,0,.18);
  position:relative;
  overflow:hidden;
}
.avp-hero:after{
  content:"";
  position:absolute;
  right:-120px;
  top:-120px;
  width:420px;
  height:420px;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(255,179,0,.55), transparent 60%);
  filter: blur(2px);
  opacity:.35;
}
.avp-hero-kicker{
  letter-spacing:3px;
  font-size:12px;
  opacity:.85;
}
.avp-hero-title{
  font-size:34px;
  font-weight:900;
  letter-spacing:1px;
  margin-top:6px;
}
.avp-hero-sub{ opacity:.85; margin-top:6px; font-size:14px; }
.avp-hero-actions{ display:flex; gap:10px; z-index:1; flex-wrap:wrap; }

/* Buttons */
.avp-btn{
  border:none;
  border-radius:999px;
  padding:12px 16px;
  font-weight:900;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  user-select:none;
  line-height:1;
}
.avp-btn:active{ transform: translateY(1px); }
.avp-btn--brand{
  background:#ffb300;
  color:#111;
  box-shadow:0 18px 40px rgba(255,179,0,.30);
}
.avp-btn--brand:hover{ background:#e0a000; }
.avp-btn--outline{
  background:#fff;
  border:2px solid rgba(255,179,0,.9);
  color:#111;
}
.avp-btn--ghost{
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
}
.avp-btn--ghost:hover{ background:rgba(255,255,255,.16); }

/* Orders accordion */
.avp-order{
  margin-top:18px;
  border-radius:26px;
  background:#fff;
  box-shadow:0 26px 90px rgba(0,0,0,.10);
  border:1px solid rgba(15,15,20,.06);
  overflow:hidden;
}
.avp-order-summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 20px;
  cursor:pointer;
  background:linear-gradient(180deg, #ffffff, #fbfcff);
}
.avp-order summary::-webkit-details-marker{ display:none; }
.avp-order-code{ font-weight:950; font-size:14px; opacity:.9; }
.avp-order-product{ font-weight:900; font-size:18px; margin-top:2px; }
.avp-order-sum-right{ display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; }

.avp-pill{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:10px 12px;
  font-size:12px;
  font-weight:950;
  letter-spacing:.6px;
  background:#eef1f6;
  color:#111;
}
.avp-pill--brand{ background:#ffb300; }

/* Metrics */
.avp-metrics{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:16px;
  padding:18px 20px 0;
}
.avp-metric{
  border-radius:22px;
  padding:18px 18px;
  background:linear-gradient(180deg, #f5f7fb, #ffffff);
  border:1px solid rgba(15,15,20,.06);
}
.avp-metric--green{ background:linear-gradient(180deg, #eafff3, #ffffff); }
.avp-metric--gold{ background:linear-gradient(180deg, #fff4d6, #ffffff); }
.avp-metric-label{ font-size:13px; opacity:.75; font-weight:900; letter-spacing:.4px; }
.avp-metric-value{ font-size:30px; font-weight:1000; margin-top:6px; }
.avp-metric-sub{ font-size:13px; opacity:.75; margin-top:6px; }

/* Progress & timeline */
.avp-progress-wrap{ padding:18px 20px; }
.avp-progress{
  height:14px;
  background:#eef1f6;
  border-radius:999px;
  overflow:hidden;
  position:relative;
}
.avp-progress span{
  display:block;
  height:100%;
  background:linear-gradient(90deg, #11c47f, #00b26b);
  border-radius:999px;
}
.avp-progress-meta{ margin-top:10px; font-size:13px; opacity:.85; }

.avp-timeline{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  align-items:center;
}
.avp-step{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:center;
  padding:10px 10px;
  border-radius:16px;
  background:#f6f7fb;
  border:1px solid rgba(15,15,20,.06);
  color:#667085;
  font-weight:950;
  font-size:12px;
}
.avp-step .dot{
  width:10px; height:10px; border-radius:999px;
  background: #ef4444;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.7);
}
.avp-step.is-on{ color:#111; }
.avp-step.is-on .dot{ background: #22c55e; box-shadow:0 0 0 6px rgba(255,179,0,.18); }

/* Grid cards */
.avp-grid2{
  padding:0 20px 18px;
  display:grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap:16px;
}
.avp-cardx{
  border-radius:22px;
  padding:18px 18px;
  background:#fff;
  border:1px solid rgba(15,15,20,.06);
  box-shadow:0 18px 55px rgba(0,0,0,.06);
}
.avp-cardx-title{
  font-weight:1000;
  letter-spacing:.6px;
  text-transform:uppercase;
  font-size:12px;
  opacity:.75;
  margin-bottom:12px;
}
.avp-kv{ display:flex; justify-content:space-between; gap:14px; padding:10px 0; border-bottom:1px solid rgba(15,15,20,.06); }
.avp-kv:last-child{ border-bottom:none; }
.avp-kv span{ opacity:.75; font-weight:800; font-size:13px; }
.avp-kv strong{ font-weight:1000; font-size:13px; text-align:right; }

.avp-actions{ display:flex; flex-direction:column; gap:12px; }
.avp-pay-icons{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.chip{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:#0f0f14;
  color:#fff;
  font-weight:900;
  font-size:12px;
  letter-spacing:.5px;
  opacity:.92;
}
.avp-secure{ margin-top:12px; font-size:13px; opacity:.75; }

/* Table */
.avp-table-card{
  margin:0 20px 18px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(15,15,20,.06);
  box-shadow:0 18px 55px rgba(0,0,0,.06);
  overflow:hidden;
}
.avp-table-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  background:linear-gradient(180deg, #fbfcff, #ffffff);
}
.avp-table-title{ font-weight:1000; font-size:18px; }
.avp-table-wrap{ overflow:auto; }
.avp-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
}
.avp-table thead th{
  text-align:left;
  font-size:12px;
  letter-spacing:1px;
  text-transform:uppercase;
  opacity:.75;
  padding:12px 14px;
  border-bottom:1px solid rgba(15,15,20,.06);
}
.avp-table tbody td{
  padding:14px;
  border-bottom:1px solid rgba(15,15,20,.06);
  font-weight:700;
  font-size:14px;
}
.avp-table tbody tr:hover{ background:#fbfcff; }
.avp-table .muted{ opacity:.7; font-weight:700; }
.pos{ color:#0a8f4f; }

.tag{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  font-weight:950;
  font-size:12px;
}
.tag--ok{ background:#e9fff3; color:#0a8f4f; }

/* Passengers */
.avp-passengers{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.avp-passengers li{
  display:flex; gap:12px; align-items:flex-start;
  padding:12px 0; border-bottom:1px solid rgba(15,15,20,.06);
}
.avp-passengers li:last-child{ border-bottom:none; }
.bullet{
  width:10px; height:10px; border-radius:999px; margin-top:6px;
  background:#ffb300;
  box-shadow:0 0 0 6px rgba(255,179,0,.18);
}
.muted{ opacity:.7; font-weight:700; font-size:13px; }

/* Support */
.avp-support{
  position:relative;
  overflow:hidden;
  margin:16px 20px 24px;
  border-radius:24px;
  padding:20px 18px;
  background:linear-gradient(135deg, rgba(255,179,0,.18), rgba(255,255,255,.96));
  border:1px solid rgba(255,179,0,.28);
  box-shadow:0 14px 34px rgba(15,15,20,.10);
}
.avp-support:before{
  content:"";
  position:absolute;
  width:180px; height:180px;
  top:-90px; right:-90px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,179,0,.35), rgba(255,179,0,0));
}
.avp-support-title{ font-weight:1000; font-size:16px; margin-bottom:6px; position:relative; z-index:1; }
.avp-support .muted{ position:relative; z-index:1; color:#334155; font-weight:750; line-height:1.45; }

@media (max-width: 700px){
  .avp-support{ margin:14px 12px 20px; padding:16px 14px; border-radius:22px; }
}

/* Alerts (fallback) */
.avp-alert{ padding:14px 16px; border-radius:18px; border:1px solid rgba(15,15,20,.08); background:#eef1f6; font-weight:900; }
.avp-alert--danger{ background:#ffe8e8; color:#8a1111; }
.avp-alert--neutral{ background:#eef3f8; }

/* Responsive */
@media (max-width: 980px){
  .avp-metrics{ grid-template-columns:1fr; }
  .avp-grid2{ grid-template-columns:1fr; }
  .avp-hero{ flex-direction:column; align-items:flex-start; }
  .avp-hero-title{ font-size:28px; }
  .avp-timeline{ grid-template-columns:1fr 1fr; }
}

/* =============================
   RESPONSIVE FIXES
   ============================= */

@media (max-width: 1024px){
  .avp-ultra-hero{
    flex-direction:column;
    align-items:flex-start;
    gap:20px;
  }
  .avp-ultra-status{
    align-self:flex-start;
  }
}

@media (max-width: 768px){
  .avp-ultra-card{
    padding:20px;
  }
  .avp-ultra-metrics{
    grid-template-columns:1fr;
  }
  .avp-ultra-actions{
    flex-direction:column;
  }
  .btn-outline,
  .btn-gold{
    width:100%;
    text-align:center;
  }
  .avp-ultra-timeline{
    flex-direction:column;
    gap:10px;
  }
  .avp-ultra-timeline .step{
    border-bottom:none;
    border-left:4px solid #ddd;
    text-align:left;
    padding-left:10px;
  }
  .avp-ultra-timeline .step.active{
    border-color:#ffb300;
  }
}

@media (max-width: 480px){
  .avp-ultra-hero h2{
    font-size:22px;
  }
  .metric strong{
    font-size:20px;
  }
  .avp-ultra-progress{
    height:12px;
  }
}


/* Download buttons (cliente) */
.avp-btn--dl .avp-ic{
  display:inline-block;
  margin-right:10px;
  font-weight:900;
  transform: translateY(-1px);
}

/* Safety: evita scroll horizontal en móvil */
.avp-app, .avp-app-shell { overflow-x:hidden; }
.avp-app-shell, .avp-app-shell * { box-sizing:border-box; }


/* Override colores de timeline sin cambiar el diseño */
.avp-step .dot{ background:#ef4444 !important; box-shadow:0 0 0 3px rgba(239,68,68,.18) !important; }
.avp-step.is-on .dot{ background:#22c55e !important; box-shadow:0 0 0 3px rgba(34,197,94,.20) !important; }


/* ===== Progress responsive + colores por avance ===== */
.avp-progress{
  position:relative;
  width:100%;
  overflow:hidden;
}
.avp-progress span{
  transition: width .35s ease;
}
.avp-progress--red span{ background:#ef4444 !important; }
.avp-progress--orange span{ background:#f59e0b !important; }
.avp-progress--green span{ background:#22c55e !important; }

/* etiqueta centrada dentro de la barra */
.avp-progress-label{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:12px;
  letter-spacing:1px;
  color:#111;
  text-transform:uppercase;
  pointer-events:none;
  mix-blend-mode:normal;
}

/* en fondos oscuros, mejora lectura */
.avp-progress--red .avp-progress-label,
.avp-progress--orange .avp-progress-label,
.avp-progress--green .avp-progress-label{
  text-shadow: 0 1px 0 rgba(255,255,255,.45);
}

.avp-progress-meta{display:none !important;}


/* =============================
   KPI Saldos - Gradientes (Cliente)
   Orden actual: (1) Total a pagar (2) Saldo abonado (3) Saldo pendiente
   Ajuste de degradados según solicitud.
   ============================= */

/* Safety responsive */
.avp-app-shell, .avp-app-shell * { box-sizing:border-box; }
.avp-app, .avp-app-shell { overflow-x:hidden; }

/* Gradientes por tarjeta (sin cambiar layout) */
.avp-kpi.is-total, .avp-stat.is-total{ background: linear-gradient(135deg, rgba(34,197,94,.20), rgba(34,197,94,.06)) !important; }
.avp-kpi.is-paid, .avp-stat.is-paid{ background: linear-gradient(135deg, rgba(245,158,11,.22), rgba(245,158,11,.06)) !important; }
.avp-kpi.is-balance, .avp-stat.is-balance{ background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(239,68,68,.06)) !important; }
.avp-kpi, .avp-stat{
  border:1px solid rgba(15,15,20,.08) !important;
}


/* ===== Metrics: orden y centrado ===== */
.avp-metrics{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
  margin-top:12px;
}
@media (max-width: 768px){
  .avp-metrics{ grid-template-columns: 1fr; }
}
.avp-metric{
  border-radius:16px;
  padding:14px 14px;
  border:1px solid rgba(15,15,20,.08);
  text-align:center;
}
.avp-metric-label{
  font-weight:900;
  font-size:12px;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:#111;
  opacity:.9;
}
.avp-metric-value{
  margin-top:8px;
  font-weight:1000;
  font-size:22px;
  line-height:1.1;
  color:#111;
}
.avp-metric-sub{ display:none !important; }

/* Gradientes */
.avp-metric--red{
  background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(239,68,68,.06)) !important;
}
.avp-metric--orange{
  background: linear-gradient(135deg, rgba(245,158,11,.22), rgba(245,158,11,.06)) !important;
}
.avp-metric--green{
  background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(34,197,94,.06)) !important;
}


/* ===== Badges de estado (cliente) ===== */
.avp-row-badges{ display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; margin-top:8px; }
@media (max-width: 520px){
  .avp-row-badges{ justify-content:flex-start; }
}

.avp-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
  letter-spacing:.8px;
  text-transform:uppercase;
  font-size:12px;
  line-height:1;
  border:1px solid rgba(15,15,20,.10);
  white-space:nowrap;
}

.avp-badge--red{
  background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(239,68,68,.10));
  color:#7f1d1d;
  border-color: rgba(239,68,68,.25);
}
.avp-badge--orange{
  background: linear-gradient(135deg, rgba(245,158,11,.22), rgba(245,158,11,.10));
  color:#7c2d12;
  border-color: rgba(245,158,11,.25);
}
.avp-badge--green{
  background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(34,197,94,.10));
  color:#14532d;
  border-color: rgba(34,197,94,.25);
}
.avp-badge--soft{
  background:#f6f7fb;
  color:#111;
}


/* Override forzar colores de badges (cliente) */
.avp-badge--red{ background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(239,68,68,.10)) !important; color:#7f1d1d !important; border-color: rgba(239,68,68,.25) !important; }
.avp-badge--orange{ background: linear-gradient(135deg, rgba(245,158,11,.22), rgba(245,158,11,.10)) !important; color:#7c2d12 !important; border-color: rgba(245,158,11,.25) !important; }
.avp-badge--green{ background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(34,197,94,.10)) !important; color:#14532d !important; border-color: rgba(34,197,94,.25) !important; }


/* ===== Pills de estado (cliente) - colores dinámicos ===== */
.avp-pill{ display:inline-flex; align-items:center; justify-content:center; padding:10px 14px; border-radius:999px; font-weight:900; letter-spacing:.8px; text-transform:uppercase; font-size:12px; line-height:1; border:1px solid rgba(15,15,20,.10); white-space:nowrap; }
.avp-pill--red{ background: linear-gradient(135deg, rgba(239,68,68,.22), rgba(239,68,68,.10)) !important; color:#7f1d1d !important; border-color: rgba(239,68,68,.25) !important; }
.avp-pill--orange{ background: linear-gradient(135deg, rgba(245,158,11,.22), rgba(245,158,11,.10)) !important; color:#7c2d12 !important; border-color: rgba(245,158,11,.25) !important; }
.avp-pill--green{ background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(34,197,94,.10)) !important; color:#14532d !important; border-color: rgba(34,197,94,.25) !important; }
.avp-pill--soft{ background:#f6f7fb !important; color:#111 !important; }


/* ===== Client panels responsive safety ===== */
@media (max-width: 520px){
  .avp-grid2{ padding:0 12px 14px; gap:12px; }
  .avp-cardx{ padding:16px 14px; border-radius:18px; }
  .avp-table-card{ margin:0 12px 14px; border-radius:18px; }
  .avp-table-top{ flex-direction:column; align-items:flex-start; gap:8px; }
}

/* Modal pago (cliente) */
.avp-pay-modal{ position:fixed; inset:0; z-index:99999; }
.avp-pay-backdrop{ position:absolute; inset:0; background:rgba(15,15,20,.55); }
.avp-pay-panel{ position:relative; width:min(560px, calc(100% - 28px)); margin:8vh auto 0; background:#fff; border-radius:22px; overflow:hidden; box-shadow:0 30px 90px rgba(0,0,0,.35); max-height:84vh; display:flex; flex-direction:column; }
@media (max-width:520px){ .avp-pay-panel{ margin:6vh auto 0; width:calc(100% - 20px); max-height:88vh; } }
.avp-pay-head{ background: linear-gradient(135deg, rgba(255,179,0,.92), rgba(255,179,0,.72)); padding:18px 18px 14px; position:relative; }
.avp-pay-close{ position:absolute; top:12px; right:12px; width:40px; height:40px; border-radius:12px; border:1px solid rgba(15,15,20,.14); background:rgba(255,255,255,.55); font-size:22px; line-height:1; cursor:pointer; }
.avp-pay-title{ font-weight:1000; font-size:22px; color:#111; }
.avp-pay-sub{ margin-top:6px; color:#111; opacity:.75; font-weight:800; }
.avp-pay-body{ padding:16px 16px 18px; overflow:auto; }
.avp-pay-summary{ background:#f6fbff; border:1px solid rgba(15,15,20,.08); border-radius:16px; padding:14px 14px; }
.avp-pay-summary .row{ display:flex; justify-content:space-between; gap:12px; padding:6px 0; font-weight:900; color:#111; }
.avp-pay-summary .ok{ color:#16a34a; }
.avp-pay-q{ margin:14px 2px 10px; font-weight:1000; font-size:18px; color:#111; }
.avp-pay-choice{ display:block; border:2px solid rgba(15,15,20,.10); background:#fff; border-radius:18px; padding:12px 12px; margin:10px 0; cursor:pointer; }
.avp-pay-choice input{ margin-right:10px; }
.avp-pay-choice .box{ margin-left:6px; }
.avp-pay-choice .t{ font-weight:1000; font-size:18px; }
.avp-pay-choice .amt{ font-weight:1000; font-size:28px; margin-top:6px; color:#f97316; }
.avp-pay-choice .h{ margin-top:6px; color:#64748b; font-weight:800; }
.avp-pay-choice.is-on{ border-color: rgba(255,179,0,.85); background: rgba(255,179,0,.12); }
.avp-pay-choice .in{ margin-top:10px; display:flex; align-items:center; gap:10px; }
.avp-pay-choice .cur{ font-weight:1000; color:#111; font-size:18px; }
#avp-pay-custom{ width:100%; border:2px solid rgba(15,15,20,.10); border-radius:14px; padding:12px 12px; font-weight:900; font-size:18px; outline:none; }
.avp-pay-methods{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:8px; }
.avp-method{ flex:1 1 180px; border-radius:16px; border:2px solid rgba(15,15,20,.10); background:#f8fafc; padding:14px 14px; font-weight:1000; cursor:pointer; }
.avp-method:hover{ border-color: rgba(255,179,0,.75); }
.avp-nequi-wrap{ margin-top:12px; border:1px solid rgba(15,15,20,.10); border-radius:18px; padding:12px 12px; background:#fff; }
.avp-nequi-note{ color:#64748b; font-weight:800; margin-bottom:10px; }
body.avp-modal-open{ overflow:hidden; }


/* =============================
   Pagos inline en ACCIONES (cliente)
   ============================= */
.avp-pay-inline{
  margin-top: 6px;
}
.avp-pay-summary{
  background:#f6fbff;
  border:1px solid rgba(15,15,20,.08);
  border-radius:16px;
  padding:12px 12px;
}
.avp-pay-summary .row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:6px 0;
  font-weight:900;
  color:#111;
}
.avp-pay-summary .ok{ color:#16a34a; }
.avp-pay-summary .warn{ color:#b45309; }

.avp-pay-q{
  margin:14px 2px 10px;
  font-weight:1000;
  font-size:16px;
  color:#111;
}
.avp-pay-choice{
  display:block;
  border:2px solid rgba(15,15,20,.10);
  background:#fff;
  border-radius:18px;
  padding:12px 12px;
  margin:10px 0;
  cursor:pointer;
}
.avp-pay-choice input{ margin-right:10px; }
.avp-pay-choice .box{ margin-left:6px; }
.avp-pay-choice .t{ font-weight:1000; font-size:16px; }
.avp-pay-choice .amt{ font-weight:1000; font-size:22px; margin-top:6px; color:#f97316; }
.avp-pay-choice .h{ margin-top:6px; color:#64748b; font-weight:800; }
.avp-pay-choice.is-on{
  border-color: rgba(255,179,0,.85);
  background: rgba(255,179,0,.12);
}
.avp-pay-choice .in{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:10px;
}
.avp-pay-choice .cur{ font-weight:1000; color:#111; font-size:18px; }
.avp-pay-custom{
  width:100%;
  border:2px solid rgba(15,15,20,.10);
  border-radius:14px;
  padding:12px 12px;
  font-weight:900;
  font-size:16px;
  outline:none;
}
.avp-pay-methods{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.avp-method{
  flex:1 1 180px;
  border-radius:16px;
  border:2px solid rgba(15,15,20,.10);
  background:#f8fafc;
  padding:12px 12px;
  font-weight:1000;
  cursor:pointer;
}
.avp-method:hover{ border-color: rgba(255,179,0,.75); }
.avp-nequi-note{ color:#64748b; font-weight:800; margin-bottom:10px; }
@media (max-width:520px){
  .avp-method{ flex:1 1 100%; }
}


/* =============================
   Tipografía global del panel cliente (más ligera y compacta)
   ============================= */
.avp-app, .avp-app-shell{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  color:#111 !important;
}

/* Títulos y subtítulos */
.avp-hero-title{ font-size: 22px !important; font-weight: 900 !important; }
.avp-hero-sub{ font-size: 13px !important; font-weight: 700 !important; opacity:.75 !important; }

/* Cards */
.avp-cardx-title, .avp-card-title, .avp-table-title{
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
}

/* Labels y textos secundarios */
.avp-kv .k, .avp-muted, .avp-pay-q, .avp-pay-choice .h, .avp-secure{
  font-size: 13px !important;
  font-weight: 700 !important;
}

/* Valores */
.avp-kv .v{
  font-size: 14px !important;
  font-weight: 900 !important;
}
.avp-metric-value{
  font-size: 20px !important;
  font-weight: 1000 !important;
}

/* Botones */
.avp-btn, .avp-method{
  font-size: 14px !important;
  font-weight: 900 !important;
}

/* Ajuste general: evita que se vea “muy grueso” */
.avp-app-shell strong, .avp-app-shell b{
  font-weight: 900 !important;
}

/* =============================
   PLAN DE PAGOS (PREVIEW) - Premium cards 100% responsive
   ============================= */
.avp-plan-empty{
  padding:10px 12px;
  background:#f6f7fb;
  border:1px solid rgba(15,15,20,.10);
  border-radius:14px;
}

.avp-plan-wrap{ margin-top:10px; }

.avp-plan-summary{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
}

.avp-plan-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
  margin-top:10px;
}

.avp-plan-card{
  position:relative;
  overflow:hidden;
  background: linear-gradient(180deg, #ffffff, #fbfcff);
  border: 1px solid rgba(15,15,20,.10);
  border-radius: 18px;
  padding: 12px 12px;
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
  color:#111;
  min-width: 0;
}

.avp-plan-card:before{
  content:"";
  position:absolute;
  left:0; top:0; right:0;
  height:3px;
  background: rgba(17,17,17,.08);
}

.avp-plan-card--brand{
  border-color: rgba(255,179,0,.55);
  box-shadow: 0 16px 34px rgba(255,179,0,.16);
}

.avp-plan-card--brand:before{ background: rgba(255,179,0,.95); }

.avp-plan-label{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .7px;
  text-transform: uppercase;
  color: rgba(17,17,17,.62);
}

.avp-plan-amount{
  margin-top:6px;
  font-size: 16px;
  font-weight: 1000;
  letter-spacing: .2px;
}

.avp-plan-meta{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.avp-plan-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:1000;
  letter-spacing:.4px;
  border:1px solid rgba(255,179,0,.45);
  background: rgba(255,179,0,.14);
  color:#111;
}

.avp-plan-pill--soft{
  border-color: rgba(15,15,20,.12);
  background: rgba(15,15,20,.05);
}

.avp-plan-pill--warn{
  border-color: rgba(244, 162, 97, .55);
  background: rgba(244, 162, 97, .12);
}

.avp-plan-meta-t{
  font-size: 13px;
  font-weight: 850;
  color: rgba(17,17,17,.70);
}

.avp-plan-section{ margin-top:10px; }

.avp-plan-section-title{
  font-weight: 1000;
  letter-spacing:.2px;
  margin: 8px 2px 6px;
  color:#111;
}

.avp-plan-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.avp-plan-step{
  font-size:12px;
  font-weight:1000;
  letter-spacing:.4px;
  text-transform:uppercase;
  color: rgba(17,17,17,.62);
}

.avp-plan-badge{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:950;
  border:1px solid rgba(15,15,20,.10);
  background: rgba(15,15,20,.04);
  color:#111;
  white-space:nowrap;
}

.avp-plan-mini{
  margin-top:6px;
  font-size:12px;
  font-weight:800;
  color: rgba(17,17,17,.65);
}

.avp-plan-notice{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,179,0,.40);
  background: rgba(255,179,0,.10);
  color:#111;
}

@media (max-width: 980px){
  .avp-plan-summary{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .avp-plan-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 520px){
  .avp-plan-summary{ grid-template-columns: 1fr; }
  .avp-plan-grid{ grid-template-columns: 1fr; }
}

/* En móvil: un poco más compacto */
@media (max-width: 520px){
  .avp-app, .avp-app-shell{ font-size: 13px !important; }
  .avp-hero-title{ font-size: 20px !important; }
  .avp-metric-value{ font-size: 18px !important; }
}


/* =============================
   Nequi embebido (dentro del modal AVP)
   Solo aplica dentro de .avp-nequi-wrap
   ============================= */
.avp-nequi-wrap,
.avp-nequi-wrap *{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif !important;
  box-sizing: border-box;
}

.avp-nequi-wrap{
  border: 1px solid rgba(15,15,20,.10) !important;
  border-radius: 18px !important;
  padding: 14px 14px !important;
  background: #ffffff !important;
}

.avp-nequi-wrap h1,
.avp-nequi-wrap h2,
.avp-nequi-wrap h3{
  margin: 0 0 10px 0 !important;
  font-weight: 1000 !important;
  color: #111 !important;
  line-height: 1.15 !important;
}

.avp-nequi-wrap label{
  display:block !important;
  font-weight: 900 !important;
  color:#111 !important;
  margin: 10px 0 6px 0 !important;
  letter-spacing: .2px !important;
}

.avp-nequi-wrap input[type="text"],
.avp-nequi-wrap input[type="tel"],
.avp-nequi-wrap input[type="number"],
.avp-nequi-wrap input[type="date"],
.avp-nequi-wrap select{
  width:100% !important;
  max-width: 100% !important;
  border-radius: 14px !important;
  border: 2px solid rgba(15,15,20,.10) !important;
  padding: 12px 12px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  outline: none !important;
  background: #fff !important;
}

.avp-nequi-wrap input[type="text"]:focus,
.avp-nequi-wrap input[type="tel"]:focus,
.avp-nequi-wrap input[type="number"]:focus,
.avp-nequi-wrap input[type="date"]:focus,
.avp-nequi-wrap select:focus{
  border-color: rgba(255,179,0,.85) !important;
  box-shadow: 0 0 0 4px rgba(255,179,0,.20) !important;
}

.avp-nequi-wrap button,
.avp-nequi-wrap input[type="submit"],
.avp-nequi-wrap .button{
  width:100% !important;
  border-radius: 16px !important;
  border: 0 !important;
  padding: 14px 14px !important;
  font-weight: 1000 !important;
  font-size: 16px !important;
  cursor: pointer !important;
  background: linear-gradient(135deg, rgba(255,179,0,.95), rgba(255,179,0,.78)) !important;
  color:#111 !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.12) !important;
  margin-top: 12px !important;
}

.avp-nequi-wrap button:hover,
.avp-nequi-wrap input[type="submit"]:hover{
  filter: brightness(.98) !important;
}

.avp-nequi-wrap small,
.avp-nequi-wrap .help,
.avp-nequi-wrap .description{
  display:block !important;
  margin-top: 6px !important;
  color:#64748b !important;
  font-weight: 800 !important;
}

/* Ajuste de layout interno si el shortcode usa filas */
.avp-nequi-wrap .row,
.avp-nequi-wrap .field{
  margin-bottom: 10px !important;
}

@media (max-width: 520px){
  .avp-nequi-wrap{ padding: 12px 12px !important; }
}



/* =============================
   PlaceToPay embebido (iframe) - dentro del módulo Acciones
   ============================= */
.avp-p2p-frame{
  margin-top: 12px;
  width: 100%;
  border: 1px solid rgba(15,15,20,.10);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
}
.avp-p2p-iframe{
  display:block;
  width: 100%;
  height: 78vh;
  border: 0;
  overflow: hidden;
}
@media (max-width: 520px){
  .avp-p2p-iframe{ height: 82vh; }
}

/* ===== Ajuste: hacer ACCIONES más ancho en desktop (sin afectar móvil) ===== */
.avp-grid2{ grid-template-columns: minmax(0,1fr) minmax(0,1fr); }
@media (max-width: 980px){
  .avp-grid2{ grid-template-columns: 1fr; }
}

/* PlaceToPay iframe: ancho completo y altura controlada */
.avp-p2p-frame{ width:100% !important; }
.avp-p2p-iframe{ width:100% !important; min-height: 720px; max-height: 92vh; border:0; display:block; }

/* P2P iframe responsive */
.avp-p2p-frame{width:100% !important; margin-top:12px;}
.avp-p2p-iframe{width:100% !important; border:0 !important; display:block;}

/* Ventanas emergentes de pago (Nequi / PlaceToPay) */
.avp-pay-modal{ position:fixed; inset:0; z-index:99999; display:none; }
.avp-pay-backdrop{ position:absolute; inset:0; background:rgba(15,15,20,.55); }
.avp-pay-panel{
  position:relative;
  width:min(620px, calc(100% - 24px));
  margin:6vh auto 0;
  background:#fff;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.35);
  max-height:88vh;
  display:flex;
  flex-direction:column;
}
.avp-pay-panel--wide{ width:min(980px, calc(100% - 24px)); }
.avp-pay-head{
  background: linear-gradient(135deg, rgba(255,179,0,.92), rgba(255,179,0,.72));
  padding:18px 18px 14px;
  position:relative;
}
.avp-pay-title{ font-weight:1000; font-size:20px; color:#111; }
.avp-pay-sub{ margin-top:6px; color:#111; opacity:.75; font-weight:800; font-size:13px; }
.avp-pay-close{
  position:absolute;
  top:12px;
  right:12px;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(15,15,20,.14);
  background:rgba(255,255,255,.55);
  font-size:22px;
  line-height:1;
  cursor:pointer;
}
.avp-pay-body{ padding:14px 14px 16px; overflow:auto; }
.avp-pay-body--iframe{ padding:0; overflow:auto; background:#fff; }
#avp-p2p-iframe{ width:100%; border:0; display:block; min-height:70vh; }
@media (max-width:520px){
  .avp-pay-panel{ margin:4vh auto 0; width:calc(100% - 16px); max-height:92vh; }
  .avp-pay-panel--wide{ width:calc(100% - 16px); }
  #avp-p2p-iframe{ min-height:78vh; }
}
body.avp-modal-open{ overflow:hidden; }


/* =============================
   PlaceToPay fullscreen overlay
   ============================= */
#avp-p2p-modal .avp-pay-panel--fullscreen{
  width: 100% !important;
  height: 100vh !important;
  max-height: 100vh !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
#avp-p2p-modal .avp-pay-head{
  position: sticky;
  top: 0;
  z-index: 2;
}
#avp-p2p-modal .avp-pay-body--iframe{
  padding: 0 !important;
  overflow: auto !important;
  height: calc(100vh - 74px);
  background: #fff;
}
#avp-p2p-iframe{
  width: 100% !important;
  border: 0 !important;
  display: block !important;
}
@media (max-width:520px){
  #avp-p2p-modal .avp-pay-body--iframe{ height: calc(100vh - 78px); }
}

/* iOS smooth scroll inside PlaceToPay container */
#avp-p2p-modal .avp-pay-body--iframe{
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}


/* =============================
   Ajuste PlaceToPay: modal tipo Nequi (NO fullscreen) + scroll correcto
   ============================= */
#avp-p2p-modal .avp-pay-panel{
  width: min(820px, calc(100% - 24px)) !important;
  margin: 6vh auto 0 !important;
  border-radius: 22px !important;
  max-height: 88vh !important;
  height: auto !important;
}
#avp-p2p-modal .avp-pay-body--iframe{
  height: calc(88vh - 74px) !important;
  overflow: hidden !important; /* el scroll será dentro del iframe */
  -webkit-overflow-scrolling: touch;
  background:#fff;
}
#avp-p2p-iframe{
  width: 100% !important;
  height: 100% !important;
  min-height: 72vh !important;
  border: 0 !important;
  display: block !important;
  overflow: auto !important;
  touch-action: pan-y;
}
@media (max-width:520px){
  #avp-p2p-modal .avp-pay-panel{ width: calc(100% - 16px) !important; margin: 4vh auto 0 !important; max-height: 92vh !important; }
  #avp-p2p-modal .avp-pay-body--iframe{ height: calc(92vh - 78px) !important; }
}


/* =============================
   Responsive table (mobile cards)
   Historial de abonos / movimientos
   ============================= */
@media (max-width: 720px){
  .avp-table-wrap{ overflow-x: hidden !important; }
  .avp-table{ width:100% !important; border-collapse: separate !important; border-spacing: 0 !important; }
  .avp-table thead{ display:none !important; }
  .avp-table tbody, .avp-table tr, .avp-table td{ display:block !important; width:100% !important; }
  .avp-table tr{
    background:#fff !important;
    border:1px solid rgba(15,15,20,.10) !important;
    border-radius:18px !important;
    padding: 10px 12px !important;
    margin: 0 0 12px 0 !important;
    box-shadow: 0 10px 26px rgba(0,0,0,.05) !important;
  }
  .avp-table td{
    display:flex !important;
    align-items:flex-start !important;
    justify-content:space-between !important;
    gap: 12px !important;
    padding: 8px 0 !important;
    border-bottom:1px dashed rgba(15,15,20,.12) !important;
  }
  .avp-table td:last-child{ border-bottom:0 !important; padding-bottom: 2px !important; }
  .avp-table td:before{
    content: attr(data-label) !important;
    flex: 0 0 auto !important;
    max-width: 45% !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .10em !important;
    text-transform: uppercase !important;
    color: rgba(17,17,17,.55) !important;
    padding-top: 2px !important;
  }
  .avp-table td > *{ max-width: 55% !important; text-align:right !important; }
  .avp-table td strong{ font-weight: 1000 !important; }
  .avp-table td.pos{ font-weight: 1000 !important; }
}
