/* ==========================================================================
   RUMBO SALOU - MODAL DE RESERVA
   ──────────────────────────────────────────────────────────────────────────
   Estilos específicos del modal de reserva express.
   Reutiliza variables CSS de style.css (--rs-*).
   ========================================================================== */

.rs-modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,15,35,.75);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:24px;opacity:0;transition:opacity .3s ease;
}
.rs-modal-overlay.rs-open{display:flex;opacity:1}
.rs-modal{
  background:#fff;width:100%;max-width:780px;max-height:92vh;
  border-radius:var(--rs-radius-xl);overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  transform:translateY(20px) scale(.96);
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.rs-modal-overlay.rs-open .rs-modal{transform:translateY(0) scale(1)}

/* Header */
.rs-modal-header{
  padding:22px 28px;border-bottom:1px solid var(--rs-base-3);
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,#fff 0%,#fafbfd 100%);flex-shrink:0;
}
.rs-modal-title{font-size:18px;font-weight:800;color:var(--rs-navy);margin:0;letter-spacing:-.01em}
.rs-modal-close{
  width:36px;height:36px;border-radius:50%;background:var(--rs-base-2);
  display:flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;transition:all .2s ease;color:var(--rs-text-soft);
}
.rs-modal-close:hover{background:var(--rs-coral);color:#fff;transform:rotate(90deg)}
.rs-modal-close svg{width:18px;height:18px}

/* Stepper */
.rs-stepper{
  padding:18px 28px;display:flex;align-items:center;justify-content:center;gap:6px;
  background:var(--rs-base-2);border-bottom:1px solid var(--rs-base-3);flex-shrink:0;
}
.rs-step-dot{display:flex;align-items:center;gap:6px}
.rs-step-dot .dot{
  width:24px;height:24px;border-radius:50%;
  background:var(--rs-base-3);color:var(--rs-text-light);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;transition:all .35s ease;
}
.rs-step-dot.active .dot{background:var(--rs-coral);color:#fff;transform:scale(1.15)}
.rs-step-dot.done .dot{background:var(--rs-teal);color:#fff}
.rs-step-line{flex:0 0 28px;height:2px;background:var(--rs-base-3);transition:background .35s ease}
.rs-step-line.done{background:var(--rs-teal)}

/* Body */
.rs-modal-body{flex:1;overflow-y:auto;padding:28px;scrollbar-width:thin}
.rs-modal-body::-webkit-scrollbar{width:6px}
.rs-modal-body::-webkit-scrollbar-thumb{background:var(--rs-base-3);border-radius:3px}

/* Footer */
.rs-modal-footer{
  padding:18px 28px;border-top:1px solid var(--rs-base-3);
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  background:#fafbfd;flex-shrink:0;
}
.rs-modal-back{
  padding:12px 20px;border:1.5px solid var(--rs-base-3);background:#fff;
  color:var(--rs-text-soft);font-weight:600;font-size:14px;border-radius:10px;
  cursor:pointer;transition:all .2s ease;
}
.rs-modal-back:hover{border-color:var(--rs-navy);color:var(--rs-navy)}
.rs-modal-back:disabled{visibility:hidden}
.rs-modal-next{
  padding:12px 28px;background:var(--rs-gradient-coral);color:#fff;
  font-weight:700;font-size:14px;border-radius:10px;border:none;cursor:pointer;
  transition:all .25s ease;display:inline-flex;align-items:center;gap:8px;
}
.rs-modal-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(199,62,58,.35)}
.rs-modal-next:disabled{opacity:.4;cursor:not-allowed}

/* Steps generic */
.rs-step-content{animation:rsFadeStep .35s ease}
@keyframes rsFadeStep{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.rs-step-title{font-size:22px;font-weight:800;color:var(--rs-navy);margin:0 0 6px;letter-spacing:-.01em}
.rs-step-sub{color:var(--rs-text-soft);font-size:14px;margin:0 0 22px}

/* Banner temporada baja */
.rs-banner-baja{
  background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);
  border:1px solid #f59e0b;border-radius:12px;padding:14px 18px;
  display:flex;align-items:center;gap:12px;margin-bottom:18px;
  font-size:13.5px;color:#78350f;font-weight:500;
}
.rs-banner-baja-icon{
  width:36px;height:36px;border-radius:50%;background:#f59e0b;color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;
}

/* Paso 1: cards de servicio */
.rs-srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.rs-srv-card{
  background:#fff;border:2px solid var(--rs-base-3);border-radius:16px;
  overflow:hidden;cursor:pointer;transition:all .25s ease;
  display:flex;flex-direction:column;position:relative;
}
.rs-srv-card:hover{border-color:var(--rs-coral);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.rs-srv-card.selected{border-color:var(--rs-coral);background:#fff5f5}
.rs-srv-card.selected::after{
  content:"\2713";position:absolute;top:10px;right:10px;
  width:28px;height:28px;border-radius:50%;background:var(--rs-coral);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;
}
.rs-srv-img{aspect-ratio:16/10;background:var(--rs-base-2) center/cover no-repeat}
.rs-srv-body{padding:14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.rs-srv-body h4{font-size:15px;font-weight:700;color:var(--rs-navy);margin:0;line-height:1.3}
.rs-srv-body p{font-size:12.5px;color:var(--rs-text-soft);margin:0;line-height:1.4}
.rs-srv-price{margin-top:auto;font-size:13px;color:var(--rs-coral);font-weight:700;padding-top:6px}

/* Paso 2: calendario */
.rs-cal{background:#fff;border:1px solid var(--rs-base-3);border-radius:16px;padding:18px}
.rs-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.rs-cal-title{font-size:16px;font-weight:700;color:var(--rs-navy);text-transform:capitalize}
.rs-cal-nav{display:flex;gap:6px}
.rs-cal-nav button{
  width:34px;height:34px;border-radius:8px;background:var(--rs-base-2);border:none;
  cursor:pointer;color:var(--rs-navy);font-size:18px;
  display:flex;align-items:center;justify-content:center;transition:all .2s ease;
}
.rs-cal-nav button:hover:not(:disabled){background:var(--rs-navy);color:#fff}
.rs-cal-nav button:disabled{opacity:.3;cursor:not-allowed}
.rs-cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.rs-cal-weekday{text-align:center;font-size:11px;color:var(--rs-text-light);font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:6px 0}
.rs-cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.rs-cal-day{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;
  transition:all .18s ease;border:1.5px solid transparent;
}
.rs-cal-day.empty{visibility:hidden}
.rs-cal-day.disabled{color:var(--rs-base-3);cursor:not-allowed;background:none}
.rs-cal-day.available{background:var(--rs-base-2);color:var(--rs-navy)}
.rs-cal-day.available:hover{background:var(--rs-teal);color:#fff;transform:scale(1.08)}
.rs-cal-day.blocked{background:#fde2e1;color:#c33;cursor:not-allowed;text-decoration:line-through}
.rs-cal-day.partial{
  background:#fff3cd;color:#7a5a00;
  border:1.5px dashed #e0a800;font-weight:700;
  position:relative;
}
.rs-cal-day.partial::after{
  content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  width:6px;height:6px;border-radius:50%;background:#e0a800;
}
.rs-cal-day.partial:hover{background:#ffe084;color:#000;transform:scale(1.08);border-style:solid}
.rs-cal-day.partial.selected{background:var(--rs-coral);color:#fff;border-color:transparent}
.rs-cal-day.partial.selected::after{background:#fff}
.rs-cal-day.loading{
  background:linear-gradient(90deg,#f3f5f8 0%,#e7ecf2 50%,#f3f5f8 100%);
  background-size:200% 100%;
  animation:rs-cal-shimmer 1.4s ease-in-out infinite;
  color:transparent;
}
@keyframes rs-cal-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.rs-cal-day.selected{background:var(--rs-coral);color:#fff;font-weight:800}
.rs-cal-day.today{border-color:var(--rs-teal)}
.rs-cal-legend{display:flex;gap:14px;margin-top:14px;font-size:11.5px;color:var(--rs-text-light);flex-wrap:wrap;justify-content:center}
.rs-cal-legend span{display:inline-flex;align-items:center;gap:5px}
.rs-cal-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}

/* Paso 3: slots */
.rs-slot-list{display:flex;flex-direction:column;gap:12px}
.rs-slot-card{
  background:#fff;border:2px solid var(--rs-base-3);border-radius:14px;padding:18px 22px;
  cursor:pointer;transition:all .2s ease;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.rs-slot-card:hover:not(.disabled){border-color:var(--rs-teal);transform:translateX(4px)}
.rs-slot-card.disabled{
  opacity:.55;cursor:not-allowed;
  background:#fde2e1;border-color:#e8c4c2;
  position:relative;
}
.rs-slot-card.disabled::before{
  content:'🚫 Ocupado';
  position:absolute;top:8px;right:10px;
  background:#c33;color:#fff;
  font-size:10px;font-weight:700;letter-spacing:.05em;
  padding:3px 9px;border-radius:999px;
  text-transform:uppercase;
}
.rs-slot-card.disabled .rs-slot-name{text-decoration:line-through}
.rs-slot-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.rs-slot-name{font-size:15.5px;font-weight:700;color:var(--rs-navy);display:flex;align-items:center;gap:8px}
.rs-slot-time{font-size:13px;color:var(--rs-text-soft)}
.rs-slot-extra{font-size:12px;color:var(--rs-text-light);margin-top:2px}
.rs-slot-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.rs-slot-price-old{font-size:13px;color:var(--rs-text-light);text-decoration:line-through}
.rs-slot-price-now{font-size:20px;font-weight:800;color:var(--rs-navy)}
.rs-slot-price-tag{font-size:10.5px;color:var(--rs-coral);font-weight:700;background:#fff5f5;padding:2px 8px;border-radius:100px;letter-spacing:.5px}

/* Paso 4: contadores */
.rs-counter-wrap{
  background:#fff;border:1px solid var(--rs-base-3);border-radius:14px;padding:20px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;
}
.rs-counter-label{display:flex;flex-direction:column;gap:2px}
.rs-counter-label .l1{font-size:15px;font-weight:700;color:var(--rs-navy)}
.rs-counter-label .l2{font-size:12px;color:var(--rs-text-light)}
.rs-counter{display:flex;align-items:center;gap:14px;background:var(--rs-base-2);padding:6px;border-radius:100px}
.rs-counter button{
  width:36px;height:36px;border-radius:50%;background:#fff;border:none;font-size:18px;font-weight:700;
  color:var(--rs-navy);cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px rgba(0,0,0,.06);
}
.rs-counter button:hover:not(:disabled){background:var(--rs-coral);color:#fff}
.rs-counter button:disabled{opacity:.3;cursor:not-allowed}
.rs-counter-value{font-size:18px;font-weight:800;color:var(--rs-navy);min-width:24px;text-align:center}

.rs-pax-info{background:#eef9f8;border-left:4px solid var(--rs-teal);border-radius:8px;padding:12px 16px;font-size:13px;line-height:1.55;margin-bottom:12px}
.rs-pax-warning{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;padding:12px 16px;font-size:13px;color:#78350f;line-height:1.55;margin-bottom:12px}
.rs-pax-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--rs-text);cursor:pointer;padding:14px;background:var(--rs-base-2);border-radius:10px}
.rs-pax-checkbox input{margin-top:3px;flex-shrink:0}

/* Paso 5: formulario y resumen */
.rs-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.rs-form-field{display:flex;flex-direction:column;gap:5px}
.rs-form-field.full{grid-column:1/-1}
.rs-form-field label{font-size:12.5px;font-weight:600;color:var(--rs-text);letter-spacing:.2px}
.rs-form-field label span{color:var(--rs-coral)}
.rs-form-field input,.rs-form-field textarea{
  padding:11px 14px;border:1.5px solid var(--rs-base-3);border-radius:10px;
  font-size:14px;font-family:inherit;color:var(--rs-text);background:#fff;
  transition:all .2s ease;
}
.rs-form-field input:focus,.rs-form-field textarea:focus{outline:none;border-color:var(--rs-coral);box-shadow:0 0 0 3px rgba(199,62,58,.1)}
.rs-form-field textarea{resize:vertical;min-height:80px}

.rs-summary{
  background:linear-gradient(135deg,#f8fbff 0%,#eef4fb 100%);
  border:1px solid var(--rs-base-3);border-radius:14px;padding:20px 22px;margin-bottom:16px;
}
.rs-summary h4{font-size:13px;text-transform:uppercase;letter-spacing:2px;color:var(--rs-text-light);margin:0 0 12px;font-weight:700}
.rs-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:7px 0}
.rs-summary-row .lbl{color:var(--rs-text-soft)}
.rs-summary-row .val{color:var(--rs-navy);font-weight:600}
.rs-summary-row.total{border-top:1px dashed var(--rs-base-3);margin-top:10px;padding-top:14px;font-size:17px}
.rs-summary-row.total .val{color:var(--rs-coral);font-weight:800;font-size:22px}
.rs-summary-row.deposit{font-size:13px;color:var(--rs-text-light)}

.rs-privacy{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;color:var(--rs-text-soft);margin-bottom:18px;line-height:1.5}
.rs-privacy input{margin-top:3px;flex-shrink:0}
.rs-privacy a{color:var(--rs-coral);text-decoration:underline}

.rs-wa-btn{
  width:100%;padding:18px;background:var(--rs-whatsapp);color:#fff;font-weight:800;font-size:16px;
  border:none;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;
  transition:all .25s ease;box-shadow:0 10px 24px rgba(37,211,102,.35);letter-spacing:.3px;
}
.rs-wa-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 32px rgba(37,211,102,.5)}
.rs-wa-btn:disabled{opacity:.5;cursor:not-allowed;background:#999;box-shadow:none}
.rs-wa-btn svg{width:22px;height:22px;flex-shrink:0}
.rs-wa-note{font-size:11.5px;color:var(--rs-text-light);text-align:center;margin-top:10px}

@media(max-width:640px){
  .rs-modal{max-height:100vh;border-radius:0;max-width:100%}
  .rs-modal-overlay{padding:0;align-items:stretch}
  .rs-modal-header,.rs-modal-body,.rs-modal-footer,.rs-stepper{padding-left:18px;padding-right:18px}
  .rs-step-title{font-size:18px}
  .rs-srv-grid{grid-template-columns:1fr;gap:12px}
  .rs-srv-card{flex-direction:row;align-items:center}
  .rs-srv-img{width:120px;aspect-ratio:1;flex-shrink:0}
  .rs-form-grid{grid-template-columns:1fr}
  .rs-counter-wrap{flex-direction:column;align-items:stretch;gap:16px}
  .rs-step-dot .dot{width:22px;height:22px;font-size:11px}
  .rs-step-line{flex-basis:18px}
}

/* ==========================================================================
   STEP 5 · EXTRAS (packs y bebidas)
   ========================================================================== */

.rs-extras-section{
  font-size:13px;font-weight:700;color:var(--rs-navy);
  letter-spacing:1.5px;text-transform:uppercase;
  margin:18px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--rs-base-3);
}
.rs-extras-section:first-of-type{margin-top:6px}

.rs-extras-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}

.rs-extra-card{
  background:#fff;border:2px solid var(--rs-base-3);border-radius:12px;padding:16px 18px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  transition:all .25s ease;
}
.rs-extra-card.rs-extra-selected{
  border-color:var(--rs-coral);background:#fff5f5;
  box-shadow:0 4px 16px rgba(199,62,58,.12);
}
.rs-extra-info{flex:1;min-width:0}
.rs-extra-head{display:flex;align-items:center;gap:8px;margin-bottom:5px;flex-wrap:wrap}
.rs-extra-icon{font-size:18px;line-height:1}
.rs-extra-nivel{
  font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:2px 8px;border-radius:100px;
  background:var(--rs-base-2);color:var(--rs-navy);
}
.rs-extra-pax{
  font-size:10px;font-weight:600;color:var(--rs-text-light);
  padding:2px 8px;background:#eef9f8;border-radius:100px;
}
.rs-extra-nombre{font-size:14px;font-weight:700;color:var(--rs-navy);margin:0 0 4px;line-height:1.3}
.rs-extra-desc{font-size:12.5px;color:var(--rs-text-soft);margin:0 0 6px;line-height:1.45}
.rs-extra-precio{font-size:15px;font-weight:800;color:var(--rs-coral)}

.rs-extra-counter{display:flex;align-items:center;gap:10px;background:var(--rs-base-2);padding:5px;border-radius:100px;flex-shrink:0}
.rs-extra-counter button{
  width:30px;height:30px;border-radius:50%;background:#fff;border:none;
  font-size:16px;font-weight:700;color:var(--rs-navy);cursor:pointer;
  transition:all .15s ease;box-shadow:0 2px 4px rgba(0,0,0,.05);
}
.rs-extra-counter button:hover:not(:disabled){background:var(--rs-coral);color:#fff}
.rs-extra-counter button:disabled{opacity:.3;cursor:not-allowed}
.rs-extra-cantidad{font-size:15px;font-weight:800;color:var(--rs-navy);min-width:18px;text-align:center}

.rs-step-skip{font-size:12.5px;color:var(--rs-text-light);text-align:center;margin:14px 0 0;font-style:italic}

@media(max-width:640px){
  .rs-extra-card{flex-direction:column;align-items:stretch;gap:12px}
  .rs-extra-counter{align-self:flex-end}
}

/* ==========================================================================
   BOTÓN SUBMIT (reserva confirmar) · variante coral del rs-wa-btn
   ========================================================================== */
.rs-submit-btn{
  width:100%;padding:18px;color:#fff;font-weight:800;font-size:16px;
  background:var(--rs-gradient-coral);
  border:none;border-radius:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:12px;
  transition:all .25s ease;
  box-shadow:0 10px 24px rgba(199,62,58,.35);
  letter-spacing:.3px;
}
.rs-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 32px rgba(199,62,58,.5)}
.rs-submit-btn:disabled{opacity:.5;cursor:not-allowed;background:#999;box-shadow:none}
.rs-submit-btn svg{width:22px;height:22px;flex-shrink:0}

/* ==========================================================================
   ERROR BANNER (dentro del modal body)
   ========================================================================== */
.rs-error-banner{
  background:#fee2e2;border:1px solid #fca5a5;border-radius:10px;
  padding:14px 18px;margin-bottom:18px;color:#991b1b;font-size:13.5px;line-height:1.5;
}
.rs-error-banner strong{display:block;margin-bottom:3px;font-size:14px}

/* ==========================================================================
   SUCCESS SCREEN · pantalla de confirmación tras crear reserva/cheque
   ========================================================================== */
.rs-success-screen{
  text-align:center;padding:20px 8px 8px;
  animation:rsFadeStep .4s ease;
}
.rs-success-icon{
  width:80px;height:80px;border-radius:50%;margin:0 auto 20px;
  background:linear-gradient(135deg,#10b981 0%,#059669 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 28px rgba(16,185,129,.35);
}
.rs-success-icon svg{width:44px;height:44px}
.rs-success-title{
  font-size:24px;font-weight:800;color:var(--rs-navy);
  margin:0 0 8px;letter-spacing:-.01em;
}
.rs-success-sub{
  font-size:14.5px;color:var(--rs-text-soft);line-height:1.55;
  margin:0 0 22px;max-width:440px;margin-left:auto;margin-right:auto;
}
.rs-success-code{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  background:linear-gradient(135deg,#fff5f5 0%,#fef3c7 100%);
  border:1px dashed var(--rs-coral);border-radius:14px;
  padding:14px 28px;margin-bottom:22px;
}
.rs-success-code-lbl{
  font-size:10.5px;letter-spacing:2px;text-transform:uppercase;
  color:var(--rs-text-light);font-weight:600;
}
.rs-success-code-val{
  font-family:ui-monospace,Menlo,Monaco,monospace;
  font-size:22px;font-weight:800;color:var(--rs-coral);letter-spacing:1.5px;
}
.rs-success-summary{
  background:#fafbfd;border:1px solid var(--rs-base-3);border-radius:12px;
  padding:14px 18px;margin-bottom:20px;text-align:left;
}
.rs-success-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:5px 0;font-size:13.5px;color:var(--rs-text-soft);
}
.rs-success-row strong{color:var(--rs-navy);font-weight:600;text-align:right;max-width:60%}
.rs-success-row.total{
  border-top:1px dashed var(--rs-base-3);padding-top:10px;margin-top:6px;
  font-size:16px;
}
.rs-success-row.total strong{color:var(--rs-coral);font-weight:800;font-size:18px}
.rs-success-row.sub{font-size:12.5px;color:var(--rs-text-light)}

.rs-success-close{
  width:100%;padding:13px;background:transparent;border:1.5px solid var(--rs-base-3);
  color:var(--rs-text-soft);font-weight:600;font-size:14px;border-radius:10px;
  cursor:pointer;margin-top:10px;transition:all .2s ease;
}
.rs-success-close:hover{border-color:var(--rs-navy);color:var(--rs-navy)}

/* ==========================================================================
   MODAL CANJEAR · input de código + resumen del cheque
   ========================================================================== */
.rs-codigo-wrap{
  background:linear-gradient(135deg,#fef3c7,#fff5f5);
  border:1px dashed var(--rs-coral);border-radius:14px;padding:24px 22px;text-align:center;
  margin-bottom:14px;
}
.rs-codigo-wrap input{
  width:100%;max-width:380px;
  padding:14px 18px;
  font-family:ui-monospace,Menlo,Monaco,monospace;
  font-size:22px;font-weight:800;letter-spacing:2px;text-align:center;
  border:2px solid var(--rs-base-3);border-radius:12px;
  background:#fff;color:var(--rs-navy);text-transform:uppercase;
}
.rs-codigo-wrap input:focus{outline:none;border-color:var(--rs-coral);box-shadow:0 0 0 4px rgba(199,62,58,.15)}
.rs-codigo-help{margin-top:10px;font-size:12px;color:var(--rs-text-light)}

.rs-canje-resumen{
  background:linear-gradient(135deg,#012b53 0%,#01386d 100%);color:#fff;
  border-radius:14px;padding:18px 20px;margin-bottom:16px;
}
.rs-canje-resumen-head{display:flex;gap:14px;align-items:center}
.rs-canje-icon{font-size:32px;flex-shrink:0}
.rs-canje-titulo{font-size:17px;font-weight:800}
.rs-canje-meta{font-size:12.5px;color:rgba(228,179,99,.85);margin-top:3px}
.rs-canje-extras{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(228,179,99,.3);font-size:12.5px;color:rgba(255,255,255,.85)}

.rs-canje-fecha-sel{
  margin-top:14px;padding:12px 16px;
  background:#eef9f8;border-left:4px solid var(--rs-teal);border-radius:8px;
  font-size:13.5px;color:var(--rs-navy);
}

/* ==========================================================================
   STEP 5 (REGALO) · destinatario + mensaje
   ========================================================================== */
.rs-gift-sendbox{
  margin-top:6px;background:var(--rs-base-2);border:1px solid var(--rs-base-3);
  border-radius:12px;padding:16px 18px;
}
.rs-gift-toggle{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  font-size:13.5px;line-height:1.5;color:var(--rs-text);
}
.rs-gift-toggle input{margin-top:3px;flex-shrink:0;width:18px;height:18px;cursor:pointer}
.rs-gift-toggle small{display:block;color:var(--rs-text-light);font-size:12.5px;margin-top:3px}
.rs-gift-sendbox-date{
  margin-top:14px;padding-top:14px;border-top:1px dashed var(--rs-base-3);
  display:flex;flex-direction:column;gap:6px;
}
.rs-gift-sendbox-date label{
  font-size:12.5px;font-weight:600;color:var(--rs-text);letter-spacing:.2px;
}
.rs-gift-sendbox-date input{
  padding:10px 14px;border:1.5px solid var(--rs-base-3);border-radius:10px;
  font-size:14px;font-family:inherit;color:var(--rs-text);background:#fff;
  max-width:240px;
}
.rs-gift-sendbox-date input:focus{outline:none;border-color:var(--rs-coral);box-shadow:0 0 0 3px rgba(199,62,58,.1)}

/* Lista de contenido del pack */
.rs-extra-contenido{
  margin:8px 0 10px;padding:10px 12px 10px 26px;
  background:var(--rs-base-2);border-radius:8px;
  list-style:disc;
}
.rs-extra-contenido li{
  font-size:12px;color:var(--rs-text-soft);line-height:1.65;
  margin-bottom:2px;
}
.rs-extra-contenido li::marker{color:var(--rs-coral)}
