/* ═══════════════════════════════════════════════════════════
   TICKETS — Solo estilos que Bootstrap no cubre nativamente
   ═══════════════════════════════════════════════════════════ */

/* ── Catálogo: card de parque ─────────────────────────────── */
.park-ticket-card {
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.park-ticket-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.25) !important;
}
.park-ticket-card .card-img-wrap {
  position: relative;
  height: 180px;
  overflow: hidden;
  background: #111;
}
.park-ticket-card .card-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.park-ticket-card:hover .card-img-wrap img { transform: scale(1.05); }

.park-ticket-card .price-badge {
  position: absolute;
  top: 10px; right: 10px;
  font-size: .78rem; font-weight: 800;
  letter-spacing: .03em;
}

/* ── Modal: toggle tipo entrada ───────────────────────────── */
.type-btn.active {
  background-color: var(--bs-success) !important;
  color: #fff !important;
  border-color: var(--bs-success) !important;
}

/* ── Tickets visuales en Mis Pedidos ──────────────────────── */
.cart-park-img {
  width: 52px;
  height: 40px;
  object-fit: cover;
  border-radius: 4px;
}

.ticket-card {
  display: grid;
  grid-template-columns: 160px 1fr auto;
  overflow: hidden;
  background: #141b25;
  border: 1px solid rgba(255,255,255,.07);
  border-left: 4px solid #198754;
  border-radius: 6px;
  margin-bottom: .75rem;
  transition: box-shadow .2s, transform .2s;
}
.ticket-card:hover {
  box-shadow: 0 6px 28px rgba(25, 135, 84, .18) !important;
  transform: translateY(-1px);
}

.ticket-card .tc-img {
  width: 160px; height: 130px;
  object-fit: cover; display: block;
}
.ticket-card .tc-img-placeholder {
  width: 160px; height: 130px;
  display: flex; align-items: center; justify-content: center;
  background: #0a1a10;
  color: #198754;
}
.ticket-card .tc-body {
  padding: 1rem 1.25rem;
  display: flex; flex-direction: column; justify-content: space-between;
}
.ticket-card .tc-side {
  padding: 1rem;
  border-left: 2px dashed rgba(255,255,255,.1);
  background: #0f1520;
  display: flex; flex-direction: column;
  align-items: center; justify-content: space-between;
  min-width: 130px; gap: .75rem;
}
.ticket-card .tc-code { font-size: .62rem; font-family: monospace; word-break: break-all; text-align: center; }

/* ── Status badges ────────────────────────────────────────── */
.badge-pendiente  { background: rgba(255,193,7,.18); color: #ffc107; border: 1px solid rgba(255,193,7,.35); font-size:.7rem; padding:3px 9px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.badge-confirmado { background: rgba(25,135,84,.2);  color: #198754; border: 1px solid rgba(25,135,84,.35); font-size:.7rem; padding:3px 9px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.badge-cancelado  { background: rgba(220,53,69,.15); color: #dc3545; border: 1px solid rgba(220,53,69,.35); font-size:.7rem; padding:3px 9px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }

/* ── Responsive tickets ───────────────────────────────────── */
@media (max-width: 768px) {
  .ticket-card { grid-template-columns: 1fr; }
  .ticket-card .tc-img,
  .ticket-card .tc-img-placeholder { width: 100%; height: 140px; }
  .ticket-card .tc-side {
    border-left: none;
    border-top: 2px dashed rgba(25, 135, 84, .35);
    flex-direction: row; min-width: auto;
  }
}

/* -- Wizard de compra (2 pasos) ----------------------------- */
.step-tab {
  color: rgba(255,255,255,.4);
  font-weight: 600;
  border-bottom: 3px solid transparent;
  transition: color .2s, border-color .2s;
}
.step-tab.active {
  color: #fff;
  border-bottom-color: #198754;
}
.step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  font-size: .7rem;
  font-weight: 800;
  transition: background .2s;
}
.step-tab.active .step-num {
  background: #198754;
  color: #fff;
}

/* -- Add-on cards ------------------------------------------- */
.addon-card {
  background: #141b25;
  border-width: 2px !important;
  transition: border-color .2s, background .2s, transform .15s;
  user-select: none;
}
.addon-card:hover {
  background: #1a2232;
  transform: translateY(-1px);
}
.addon-card.border-success {
  background: rgba(25,135,84,.08) !important;
}
