/* ============================================================
   CAPITAL DF — MÓDULO DE INGRESSOS (Público)
   Estilos para o fluxo de compra de ingressos
   ============================================================ */

/* ==============================================
   1. PAGE HERO (Banner interno)
   ============================================== */
.page-hero {
  position: relative;
  padding: 11.5rem 0 5rem;
  background: linear-gradient(160deg, var(--blue-dark) 0%, #0d2240 60%, var(--blue-petrol) 100%);
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../../img/estadio.webp') center/cover no-repeat;
  opacity: .08;
}

.page-hero__deco {
  position: absolute;
  right: -2rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: clamp(8rem, 16vw, 14rem);
  font-family: var(--font-heading);
  font-weight: 700;
  color: rgba(69, 167, 218, .05);
  letter-spacing: -4px;
  line-height: 1;
  user-select: none;
  pointer-events: none;
}

.page-hero__content {
  position: relative;
  z-index: 2;
}

.page-hero__tag {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .75rem;
  font-family: var(--font-heading);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue-primary);
  background: rgba(69, 167, 218, .12);
  border: 1px solid rgba(69, 167, 218, .25);
  padding: .35rem .9rem;
  border-radius: 50px;
  margin-bottom: 1.2rem;
}

.page-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  color: rgba(255,255,255,.45);
  margin-bottom: 1rem;
}

.page-hero__breadcrumb a {
  color: rgba(255,255,255,.45);
  transition: color var(--transition-smooth);
}

.page-hero__breadcrumb a:hover {
  color: var(--blue-primary);
}

.page-hero__breadcrumb .separator {
  font-size: .6rem;
  opacity: .4;
}

.page-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.05;
  letter-spacing: 2px;
  color: #fff;
  margin-bottom: .5rem;
}

.page-hero__subtitle {
  font-size: 1rem;
  color: rgba(255,255,255,.5);
  max-width: 600px;
}

/* Animações de entrada do hero */
@keyframes pageHeroUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
.page-hero__tag        { animation: pageHeroUp .55s cubic-bezier(.22,.61,.36,1) .10s both; }
.page-hero__breadcrumb { animation: pageHeroUp .50s cubic-bezier(.22,.61,.36,1) .05s both; }
.page-hero__title      { animation: pageHeroUp .60s cubic-bezier(.22,.61,.36,1) .26s both; }
.page-hero__subtitle   { animation: pageHeroUp .55s cubic-bezier(.22,.61,.36,1) .42s both; }

/* ==============================================
   2. LISTA DE EVENTOS (Ingressos)
   ============================================== */
.tickets-section {
  padding: var(--section-py) 0;
  background: var(--blue-dark);
  min-height: 60vh;
}

/* Filtros */
.tickets-filters {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}

.tickets-filters__search {
  flex: 1;
  min-width: 240px;
  position: relative;
}

.tickets-filters__search input {
  width: 100%;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  padding: .7rem 1rem .7rem 2.8rem;
  font-size: .88rem;
  color: #fff;
  transition: all var(--transition-smooth);
  font-family: var(--font-body);
}

.tickets-filters__search input::placeholder {
  color: rgba(255,255,255,.35);
}

.tickets-filters__search input:focus {
  outline: none;
  border-color: var(--blue-primary);
  background: rgba(255,255,255,.08);
  box-shadow: 0 0 0 3px rgba(var(--blue-primary-rgb), .15);
}

.tickets-filters__search i {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(255,255,255,.35);
  font-size: .95rem;
}

.tickets-filters__select {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  padding: .7rem 1rem;
  font-size: .85rem;
  color: rgba(255,255,255,.7);
  font-family: var(--font-body);
  cursor: pointer;
  transition: all var(--transition-smooth);
  min-width: 160px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='rgba(255,255,255,0.4)' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .75rem center;
  background-size: .65rem;
  padding-right: 2.2rem;
}

.tickets-filters__select:focus {
  outline: none;
  border-color: var(--blue-primary);
}

.tickets-filters__select option {
  background: var(--blue-dark);
  color: #fff;
}

/* Cards de evento */
.ticket-event-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition-smooth);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.ticket-event-card:hover {
  transform: translateY(-4px);
  border-color: rgba(var(--blue-primary-rgb), .3);
  box-shadow: 0 12px 40px rgba(0,0,0,.3);
}

.ticket-event-card__image {
  position: relative;
  height: 200px;
  overflow: hidden;
}

.ticket-event-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}

.ticket-event-card:hover .ticket-event-card__image img {
  transform: scale(1.05);
}

.ticket-event-card__badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: .3rem .8rem;
  border-radius: 50px;
  backdrop-filter: blur(8px);
}

.ticket-event-card__badge--open {
  background: rgba(16,185,129,.15);
  border: 1px solid rgba(16,185,129,.3);
  color: #10b981;
}

.ticket-event-card__badge--soon {
  background: rgba(245,158,11,.15);
  border: 1px solid rgba(245,158,11,.3);
  color: #f59e0b;
}

.ticket-event-card__badge--closed {
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.25);
  color: #ef4444;
}

.ticket-event-card__date-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: rgba(var(--blue-dark-rgb), .85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  padding: .5rem .7rem;
  text-align: center;
  min-width: 56px;
}

.ticket-event-card__date-badge .day {
  display: block;
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  color: #fff;
}

.ticket-event-card__date-badge .month {
  display: block;
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--blue-primary);
  margin-top: 2px;
}

.ticket-event-card__body {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.ticket-event-card__championship {
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--blue-primary);
  margin-bottom: .5rem;
}

.ticket-event-card__title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 1rem;
  line-height: 1.2;
}

.ticket-event-card__meta {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-bottom: 1.25rem;
}

.ticket-event-card__meta-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .82rem;
  color: rgba(255,255,255,.5);
}

.ticket-event-card__meta-item i {
  color: rgba(var(--blue-primary-rgb), .6);
  width: 16px;
  text-align: center;
}

.ticket-event-card__price {
  display: flex;
  align-items: baseline;
  gap: .35rem;
  margin-bottom: 1.25rem;
  margin-top: auto;
}

.ticket-event-card__price .label {
  font-size: .75rem;
  color: rgba(255,255,255,.4);
}

.ticket-event-card__price .value {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
}

/* ==============================================
   3. DETALHE DO EVENTO
   ============================================== */
.event-detail {
  padding: var(--section-py) 0;
  background: var(--blue-dark);
}

/* Barra fixa mobile - oculta no desktop */
.mobile-fixed-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1050;
  padding: .75rem 1rem;
  background: var(--blue-dark);
  border-top: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 -4px 24px rgba(0, 0, 0, .6);
}

.mobile-fixed-bar .btn-capital {
  margin: 0;
  border-radius: var(--radius-md);
}

.event-detail__gallery {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  height: 400px;
}

.event-detail__gallery > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.event-detail__gallery-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(var(--blue-dark-rgb), .55) 0%, rgba(var(--blue-dark-rgb), .35) 35%, rgba(var(--blue-dark-rgb), .92) 100%),
    radial-gradient(ellipse at center, transparent 30%, rgba(0, 0, 0, .35) 100%);
}

.event-detail__gallery-content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1.5rem 2rem;
  z-index: 2;
}

.event-detail__gallery-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.event-detail__gallery-tag {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #fff;
  background: rgba(var(--blue-primary-rgb), .85);
  border: 1px solid rgba(255, 255, 255, .2);
  padding: .4rem .9rem;
  border-radius: 50px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, .25);
}

.event-detail__gallery-tag i {
  font-size: .8rem;
  color: #ffd54a;
}

.event-detail__gallery-date {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .78rem;
  font-weight: 600;
  color: #fff;
  background: rgba(0, 0, 0, .45);
  border: 1px solid rgba(255, 255, 255, .15);
  padding: .4rem .9rem;
  border-radius: 50px;
  backdrop-filter: blur(8px);
}

.event-detail__gallery-matchup {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  margin: auto 0;
}

.event-detail__gallery-team {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .65rem;
  text-align: center;
}

.event-detail__gallery-shield {
  width: 100px;
  height: 100px;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, .55));
  transition: transform .3s ease;
}

.event-detail__gallery-team:hover .event-detail__gallery-shield {
  transform: scale(1.06);
}

.event-detail__gallery-shield--ph {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 50%;
  font-size: 1.4rem;
  color: rgba(255, 255, 255, .55);
}

.event-detail__gallery-team-name {
  font-family: var(--font-heading, inherit);
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .6);
  max-width: 160px;
  line-height: 1.2;
}

.event-detail__gallery-vs {
  display: flex;
  align-items: center;
  justify-content: center;
}

.event-detail__gallery-vs span {
  font-family: var(--font-heading, inherit);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 2px;
  color: var(--blue-primary);
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(var(--blue-primary-rgb), .35);
  padding: .25rem .7rem;
  border-radius: 6px;
  backdrop-filter: blur(8px);
  text-shadow: 0 2px 8px rgba(0, 0, 0, .5);
}

.event-detail__gallery-title {
  margin: auto 0;
  text-align: center;
}

.event-detail__gallery-title h2 {
  font-family: var(--font-heading, inherit);
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 2px;
  text-shadow: 0 4px 18px rgba(0, 0, 0, .6);
  margin: 0;
}

.event-detail__gallery-footer {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.event-detail__gallery-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .78rem;
  font-weight: 500;
  color: #fff;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .15);
  padding: .4rem .85rem;
  border-radius: 50px;
  backdrop-filter: blur(8px);
}

.event-detail__gallery-chip i {
  color: var(--blue-primary);
  font-size: .85rem;
}

.event-detail__info-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 2rem;
}

.event-detail__championship-tag {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--blue-primary);
  background: rgba(var(--blue-primary-rgb), .1);
  border: 1px solid rgba(var(--blue-primary-rgb), .2);
  padding: .3rem .8rem;
  border-radius: 50px;
  margin-bottom: 1rem;
}

.event-detail__title {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.15;
  margin-bottom: 1.5rem;
}

.event-detail__meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.event-detail__meta-block {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}

.event-detail__meta-block .icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  background: rgba(var(--blue-primary-rgb), .1);
  color: var(--blue-primary);
  flex-shrink: 0;
}

.event-detail__meta-block .label {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,.4);
  margin-bottom: 2px;
}

.event-detail__meta-block .value {
  font-size: .92rem;
  font-weight: 600;
  color: #fff;
}

.event-detail__description {
  color: rgba(255,255,255,.55);
  line-height: 1.8;
  font-size: .92rem;
  margin-bottom: 2rem;
}

.event-detail__description p + p {
  margin-top: 1rem;
}

/* Mapa do estádio */
.event-detail__venue-map {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  text-align: center;
  margin-top: 2rem;
}

.event-detail__venue-map .map-placeholder {
  width: 100%;
  height: 220px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.03);
  border: 1px dashed rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.3);
  font-size: .85rem;
  gap: .5rem;
}

/* ==============================================
   4. SELEÇÃO DE INGRESSOS
   ============================================== */
.ticket-selector {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 2rem;
  position: sticky;
  top: 100px;
}

.ticket-selector__title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.ticket-selector__title i {
  color: var(--blue-primary);
}

.ticket-type {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
  padding: 1.25rem;
  margin-bottom: 1rem;
  transition: all var(--transition-smooth);
  cursor: pointer;
}

.ticket-type:hover,
.ticket-type.selected {
  border-color: rgba(var(--blue-primary-rgb), .4);
  background: rgba(var(--blue-primary-rgb), .06);
}

.ticket-type.selected {
  box-shadow: 0 0 0 1px rgba(var(--blue-primary-rgb), .3);
}

.ticket-type__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: .5rem;
}

.ticket-type__name {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  text-transform: uppercase;
}

.ticket-type__badge-tipo {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  padding: .15em .55em;
  border-radius: 3px;
  vertical-align: middle;
  margin-left: .4rem;
  background: rgba(69,167,218,.15);
  color: var(--blue-primary);
}

.ticket-type__badge-tipo--meia {
  background: rgba(34,197,94,.12);
  color: #22c55e;
}

.ticket-type__price {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--blue-primary);
}

.ticket-type__desc {
  font-size: .8rem;
  color: rgba(255,255,255,.4);
  margin-bottom: .75rem;
}

.ticket-type__qty {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.ticket-type__qty-btn {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.05);
  color: #fff;
  font-size: .85rem;
  cursor: pointer;
  transition: all var(--transition-smooth);
}

.ticket-type__qty-btn:hover {
  background: var(--blue-primary);
  border-color: var(--blue-primary);
}

.ticket-type__qty-value {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  min-width: 24px;
  text-align: center;
}

.ticket-type__availability {
  font-size: .72rem;
  color: rgba(255,255,255,.35);
  margin-top: .5rem;
}

.ticket-type__availability i {
  color: #10b981;
}

.ticket-type--disabled {
  opacity: .4;
  cursor: default;
}
.ticket-type--disabled:hover {
  border-color: rgba(255,255,255,.08) !important;
  background: rgba(255,255,255,.03) !important;
  box-shadow: none !important;
}
.ticket-type--disabled .ticket-type__qty-btn:disabled {
  cursor: not-allowed;
}
.ticket-type__price--free {
  font-size: .85rem;
  color: rgba(255,255,255,.3);
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: .3px;
}

.ticket-selector__divider {
  height: 1px;
  background: rgba(255,255,255,.08);
  margin: 1.5rem 0;
}

.ticket-selector__summary {
  margin-bottom: 1.5rem;
}

.ticket-selector__summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .4rem 0;
  font-size: .88rem;
}

.ticket-selector__summary-row .label {
  color: rgba(255,255,255,.5);
}

.ticket-selector__summary-row .value {
  font-weight: 600;
}

.ticket-selector__summary-row--total {
  padding-top: .75rem;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: .5rem;
}

.ticket-selector__summary-row--total .label {
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 600;
  text-transform: uppercase;
  color: #fff;
}

.ticket-selector__summary-row--total .value {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--blue-primary);
}

/* ==============================================
   5. CHECKOUT / PAGAMENTO
   ============================================== */
.checkout-section {
  padding: var(--section-py) 0;
  background: var(--blue-dark);
  min-height: 80vh;
}

.checkout-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  margin-bottom: 3rem;
}

.checkout-step {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .82rem;
  font-weight: 500;
  color: rgba(255,255,255,.35);
  transition: all var(--transition-smooth);
}

.checkout-step__number {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.15);
  font-size: .8rem;
  font-weight: 700;
  transition: all var(--transition-smooth);
}

.checkout-step--active {
  color: #fff;
}

.checkout-step--active .checkout-step__number {
  background: var(--blue-primary);
  border-color: var(--blue-primary);
  color: #fff;
}

.checkout-step--done {
  color: rgba(255,255,255,.6);
}

.checkout-step--done .checkout-step__number {
  background: rgba(16,185,129,.15);
  border-color: #10b981;
  color: #10b981;
}

.checkout-step__connector {
  width: 40px;
  height: 2px;
  background: rgba(255,255,255,.1);
  border-radius: 2px;
}

.checkout-step--done + .checkout-step__connector,
.checkout-step__connector--done {
  background: rgba(16,185,129,.4);
}

/* Formulário */
.checkout-form-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 2rem;
  margin-bottom: 1.5rem;
}

.checkout-form-card__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.checkout-form-card__title i {
  color: var(--blue-primary);
}

.form-floating-capital {
  position: relative;
  margin-bottom: 1rem;
}

.form-floating-capital input,
.form-floating-capital select,
.form-floating-capital textarea {
  width: 100%;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  padding: 1rem 1rem .5rem;
  font-size: .88rem;
  color: #fff;
  font-family: var(--font-body);
  transition: all var(--transition-smooth);
}

.form-floating-capital input:focus,
.form-floating-capital select:focus,
.form-floating-capital textarea:focus {
  outline: none;
  border-color: var(--blue-primary);
  background: rgba(255,255,255,.08);
  box-shadow: 0 0 0 3px rgba(var(--blue-primary-rgb), .12);
}

.form-floating-capital label {
  position: absolute;
  top: 50%;
  left: 1rem;
  transform: translateY(-50%);
  font-size: .85rem;
  color: rgba(255,255,255,.4);
  pointer-events: none;
  transition: all .2s ease;
}

.form-floating-capital input:focus ~ label,
.form-floating-capital input:not(:placeholder-shown) ~ label,
.form-floating-capital select:focus ~ label,
.form-floating-capital select:not([value=""]) ~ label {
  top: .5rem;
  transform: translateY(0);
  font-size: .68rem;
  color: var(--blue-primary);
  letter-spacing: .5px;
}

/* Métodos de pagamento */
.payment-methods {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: .75rem;
  margin-bottom: 1.5rem;
}

.payment-method {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  padding: 1.25rem 1rem;
  background: rgba(255,255,255,.03);
  border: 2px solid rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition-smooth);
}

.payment-method:hover {
  border-color: rgba(var(--blue-primary-rgb), .3);
  background: rgba(var(--blue-primary-rgb), .05);
}

.payment-method.active {
  border-color: var(--blue-primary);
  background: rgba(var(--blue-primary-rgb), .08);
}

.payment-method__icon {
  font-size: 1.5rem;
  color: rgba(255,255,255,.5);
  transition: color var(--transition-smooth);
}

.payment-method.active .payment-method__icon {
  color: var(--blue-primary);
}

.payment-method__label {
  font-size: .78rem;
  font-weight: 600;
  color: rgba(255,255,255,.6);
}

.payment-method.active .payment-method__label {
  color: #fff;
}

/* Resumo lateral */
.checkout-summary {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 2rem;
  position: sticky;
  top: 100px;
}

.checkout-summary__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1.5rem;
}

.checkout-summary__event {
  display: flex;
  gap: 1rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 1.25rem;
}

.checkout-summary__event-img {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
}

.checkout-summary__event-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.checkout-summary__event-info .name {
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: .3rem;
}

.checkout-summary__event-info .detail {
  font-size: .78rem;
  color: rgba(255,255,255,.45);
  display: flex;
  align-items: center;
  gap: .35rem;
}

.checkout-summary__items {
  margin-bottom: 1.25rem;
}

.checkout-summary__item {
  display: flex;
  justify-content: space-between;
  padding: .4rem 0;
  font-size: .85rem;
}

.checkout-summary__item .label {
  color: rgba(255,255,255,.55);
}

.checkout-summary__item .value {
  font-weight: 600;
}

/* Benefícios de sócio no resumo do checkout */
.checkout-summary__item--beneficio .label {
  color: rgba(52, 211, 153, .85);
}
.beneficio-tag {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  padding: .1rem .35rem;
  background: rgba(5,150,105,.25);
  color: #34d399;
  border-radius: 4px;
  border: 1px solid rgba(52,211,153,.3);
  vertical-align: middle;
  margin-left: .3rem;
}
.beneficio-gratuito {
  color: #34d399 !important;
}

.checkout-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.08);
}

.checkout-summary__total .label {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  text-transform: uppercase;
}

.checkout-summary__total .value {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--blue-primary);
}

.checkout-summary__secure {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.06);
  font-size: .75rem;
  color: rgba(255,255,255,.35);
}

.checkout-summary__secure i {
  color: #10b981;
  font-size: .9rem;
}

/* ==============================================
   6. CONFIRMAÇÃO DA COMPRA
   ============================================== */
.confirmation-section {
  padding: var(--section-py) 0;
  background: var(--blue-dark);
  min-height: 80vh;
  display: flex;
  align-items: center;
}

.confirmation-card {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}

.confirmation-card__icon {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: rgba(16,185,129,.1);
  border: 2px solid rgba(16,185,129,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  font-size: 2.5rem;
  color: #10b981;
  animation: scaleIn .5s cubic-bezier(.34,1.56,.64,1);
}

@keyframes scaleIn {
  from { transform: scale(0); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.confirmation-card__title {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: .75rem;
}

.confirmation-card__subtitle {
  font-size: 1rem;
  color: rgba(255,255,255,.55);
  margin-bottom: 2rem;
}

.confirmation-card__order-number {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  padding: .6rem 1.25rem;
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: 1px;
  margin-bottom: 2rem;
}

.confirmation-card__order-number i {
  color: var(--blue-primary);
}

.confirmation-ticket {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 2rem;
  text-align: left;
  margin-bottom: 2rem;
  position: relative;
}

.confirmation-ticket::before,
.confirmation-ticket::after {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  background: var(--blue-dark);
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
}

.confirmation-ticket::before {
  left: -12px;
}

.confirmation-ticket::after {
  right: -12px;
}

.confirmation-ticket__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 1.25rem;
  border-bottom: 1px dashed rgba(255,255,255,.1);
  margin-bottom: 1.25rem;
}

.confirmation-ticket__event-name {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
}

.confirmation-ticket__event-comp {
  font-size: .75rem;
  color: var(--blue-primary);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.confirmation-ticket__qr {
  width: 72px;
  height: 72px;
  background: rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.3);
  font-size: 1.8rem;
}

.confirmation-ticket__details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.confirmation-ticket__detail .label {
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,.35);
  margin-bottom: 2px;
}

.confirmation-ticket__detail .value {
  font-size: .88rem;
  font-weight: 600;
}

.confirmation-card__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* ==============================================
   7. ÁREA DO USUÁRIO / MINHA CONTA
   ============================================== */
.account-section {
  padding: var(--section-py) 0;
  background: var(--blue-dark);
  min-height: 80vh;
}

.account-sidebar {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  position: sticky;
  top: 100px;
}

.account-sidebar__user {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 1rem;
}

.account-sidebar__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--gradient-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.account-sidebar__name {
  font-weight: 600;
  font-size: .92rem;
}

.account-sidebar__email {
  font-size: .75rem;
  color: rgba(255,255,255,.4);
}

.account-sidebar__nav {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}

.account-sidebar__nav-item a {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .65rem .85rem;
  border-radius: var(--radius-sm);
  font-size: .85rem;
  font-weight: 500;
  color: rgba(255,255,255,.55);
  transition: all var(--transition-smooth);
}

.account-sidebar__nav-item a i {
  font-size: .95rem;
  width: 20px;
  text-align: center;
}

.account-sidebar__nav-item a:hover,
.account-sidebar__nav-item.active a {
  background: rgba(var(--blue-primary-rgb), .1);
  color: #fff;
}

.account-sidebar__nav-item.active a {
  border-left: 3px solid var(--blue-primary);
}

/* Tabela de pedidos */
.orders-table-wrapper {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.orders-table {
  width: 100%;
  border-collapse: collapse;
}

.orders-table thead th {
  font-family: var(--font-heading);
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,.4);
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
  text-align: left;
}

.orders-table tbody td {
  padding: 1rem 1.25rem;
  font-size: .85rem;
  color: rgba(255,255,255,.7);
  border-bottom: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
}

.orders-table tbody tr {
  transition: background var(--transition-smooth);
}

.orders-table tbody tr:hover {
  background: rgba(255,255,255,.03);
}

.order-status {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .75rem;
  font-weight: 600;
  padding: .25rem .65rem;
  border-radius: 50px;
}

.order-status--confirmed {
  background: rgba(16,185,129,.12);
  color: #10b981;
}

.order-status--pending {
  background: rgba(245,158,11,.12);
  color: #f59e0b;
}

.order-status--cancelled {
  background: rgba(239,68,68,.12);
  color: #ef4444;
}

.order-action-btn {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
  background: transparent;
  color: rgba(255,255,255,.45);
  font-size: .85rem;
  cursor: pointer;
  transition: all var(--transition-smooth);
}

.order-action-btn:hover {
  background: rgba(var(--blue-primary-rgb), .15);
  border-color: var(--blue-primary);
  color: var(--blue-primary);
}

/* ==============================================
   8. LOGIN / CADASTRO
   ============================================== */
.auth-section {
  background: var(--blue-dark);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  position: relative;
  overflow: hidden;
}

/* Fundo estádio */
.auth-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../../img/estadio.webp') center/cover no-repeat;
  filter: brightness(.3) saturate(.6);
  transform: scale(1.05);
  animation: authBgZoom 25s ease-in-out infinite alternate;
}

/* Overlay gradiente */
.auth-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(69,167,218,.12) 0%, transparent 60%),
    linear-gradient(180deg, rgba(9,20,39,.6) 0%, rgba(9,20,39,.92) 100%);
  pointer-events: none;
}

@keyframes authBgZoom {
  0%   { transform: scale(1.05); }
  100% { transform: scale(1.12); }
}

.auth-card {
  width: 100%;
  max-width: 440px;
  background: rgba(9,20,39,.75);
  backdrop-filter: blur(20px) saturate(1.3);
  -webkit-backdrop-filter: blur(20px) saturate(1.3);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  position: relative;
  z-index: 1;
  animation: authCardEntrance .8s cubic-bezier(.22,1,.36,1) both;
}

@keyframes authCardEntrance {
  0% {
    opacity: 0;
    transform: translateY(40px) scale(.96);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

.auth-card__logo {
  display: block;
  height: 56px;
  margin: 0 auto 2rem;
  animation: authFadeUp .7s cubic-bezier(.22,1,.36,1) .2s both;
}

/* ==============================================
   8. BOX DE COMPRA PENDENTE (Minha Conta)
   ============================================== */
.pending-purchase {
  background: linear-gradient(135deg, rgba(69,167,218,.12), rgba(69,167,218,.04));
  border: 1px solid rgba(69,167,218,.25);
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 2rem;
  animation: authFadeUp .5s cubic-bezier(.22,1,.36,1) both;
}

.pending-purchase__header {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.pending-purchase__icon-box {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(69,167,218,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--blue-primary);
  flex-shrink: 0;
}

.pending-purchase__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.pending-purchase__subtitle {
  font-size: .8rem;
  color: rgba(255,255,255,.45);
  margin: .15rem 0 0;
}

.pending-purchase__close {
  margin-left: auto;
  background: none;
  border: none;
  color: rgba(255,255,255,.3);
  font-size: 1rem;
  cursor: pointer;
  padding: .25rem;
  transition: color .2s;
}
.pending-purchase__close:hover {
  color: rgba(239,68,68,.8);
}

.pending-purchase__event {
  display: flex;
  gap: 1rem;
  align-items: center;
  background: rgba(0,0,0,.2);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1.25rem;
}

.pending-purchase__img {
  width: 90px;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
}

.pending-purchase__event-name {
  font-family: var(--font-heading);
  font-size: .95rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 .4rem;
}

.pending-purchase__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 1rem;
  font-size: .78rem;
  color: rgba(255,255,255,.5);
}
.pending-purchase__meta i {
  color: var(--blue-primary);
  margin-right: .2rem;
}

@media (max-width: 575px) {
  .pending-purchase__event { flex-direction: column; align-items: flex-start; }
  .pending-purchase__img { width: 100%; height: 120px; }
}

.auth-card__title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: .5rem;
  animation: authFadeUp .7s cubic-bezier(.22,1,.36,1) .35s both;
}

.auth-card__subtitle {
  font-size: .88rem;
  color: rgba(255,255,255,.45);
  text-align: center;
  margin-bottom: 2rem;
  animation: authFadeUp .7s cubic-bezier(.22,1,.36,1) .45s both;
}

@keyframes authFadeUp {
  0% {
    opacity: 0;
    transform: translateY(18px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.auth-tabs {
  display: flex;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.04);
  padding: 4px;
  margin-bottom: 2rem;
  animation: authFadeUp .7s cubic-bezier(.22,1,.36,1) .55s both;
}

#loginForm,
#registerForm {
  animation: authFadeUp .5s cubic-bezier(.22,1,.36,1) .65s both;
}

.auth-tab {
  flex: 1;
  padding: .6rem;
  text-align: center;
  font-size: .82rem;
  font-weight: 600;
  border-radius: 6px;
  color: rgba(255,255,255,.45);
  cursor: pointer;
  transition: all var(--transition-smooth);
  border: none;
  background: none;
}

.auth-tab.active {
  background: var(--blue-primary);
  color: #fff;
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.5rem 0;
}

.auth-divider span {
  font-size: .75rem;
  color: rgba(255,255,255,.3);
  white-space: nowrap;
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.08);
}

.auth-social-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  padding: .7rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.7);
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-smooth);
  font-family: var(--font-body);
  margin-bottom: .75rem;
}

.auth-social-btn:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.2);
}

.auth-social-btn i {
  font-size: 1.1rem;
}

.auth-card__footer {
  text-align: center;
  font-size: .8rem;
  color: rgba(255,255,255,.35);
  margin-top: 1.5rem;
}

.auth-card__footer a {
  color: var(--blue-primary);
  font-weight: 600;
}

/* ==============================================
   9. RESPONSIVO
   ============================================== */
@media (max-width: 991px) {
  .ticket-selector {
    position: static;
    margin-top: 0;
  }

  .checkout-summary {
    position: static;
    margin-top: 2rem;
  }

  .account-sidebar {
    position: static;
    margin-bottom: 2rem;
  }

  /* Botão fixo no rodapé mobile */
  .mobile-fixed-bar {
    display: block;
  }

  /* Esconder botão original dentro do ticket-selector no mobile */
  .ticket-selector > #btnFinalizar {
    display: none;
  }

  /* Esconder botão pagar desktop no mobile */
  .btn-pagar-desktop {
    display: none !important;
  }

  /* Espaço extra no rodapé para não cobrir conteúdo */
  .event-detail,
  .checkout-section {
    padding-bottom: 5rem;
  }
}

@media (max-width: 767px) {
  .page-hero {
    padding: 9.5rem 0 3rem;
  }

  .checkout-steps {
    flex-wrap: wrap;
    gap: .25rem;
  }

  .checkout-step__connector {
    width: 20px;
  }

  .payment-methods {
    grid-template-columns: 1fr 1fr;
  }

  .confirmation-ticket__details {
    grid-template-columns: 1fr;
  }

  .event-detail__meta-grid {
    grid-template-columns: 1fr;
  }

  .event-detail__gallery {
    height: 240px;
  }

  .orders-table-wrapper {
    overflow-x: auto;
  }

  .orders-table {
    min-width: 600px;
  }
}

@media (max-width: 575px) {
  .tickets-filters {
    flex-direction: column;
  }

  .tickets-filters__search {
    width: 100%;
  }

  .tickets-filters__select {
    width: 100%;
  }

  .confirmation-card__actions {
    flex-direction: column;
  }

  .confirmation-card__actions .btn-capital {
    width: 100%;
    justify-content: center;
  }
}

/* ==============================================
   CHECKOUT AUTH TOGGLE (guest vs login)
   ============================================== */
.checkout-auth-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin-bottom: 1.5rem;
}

.checkout-auth-btn {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: 1.1rem 1.25rem;
  background: rgba(255,255,255,.03);
  border: 2px solid rgba(255,255,255,.08);
  border-radius: var(--radius-sm);
  color: rgba(255,255,255,.55);
  cursor: pointer;
  transition: all var(--transition-smooth);
  text-align: left;
  font-family: var(--font-body);
}

.checkout-auth-btn i {
  font-size: 1.5rem;
  flex-shrink: 0;
  transition: color var(--transition-smooth);
}

.checkout-auth-btn strong {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: rgba(255,255,255,.75);
  margin-bottom: 2px;
  transition: color var(--transition-smooth);
}

.checkout-auth-btn span {
  display: block;
  font-size: .72rem;
  color: rgba(255,255,255,.35);
  line-height: 1.3;
}

.checkout-auth-btn:hover {
  border-color: rgba(var(--blue-primary-rgb), .3);
  background: rgba(var(--blue-primary-rgb), .04);
}

.checkout-auth-btn.active {
  border-color: var(--blue-primary);
  background: rgba(var(--blue-primary-rgb), .08);
  box-shadow: 0 0 0 1px rgba(var(--blue-primary-rgb), .2);
}

.checkout-auth-btn.active i {
  color: var(--blue-primary);
}

.checkout-auth-btn.active strong {
  color: #fff;
}

@media (max-width: 575px) {
  .checkout-auth-toggle {
    grid-template-columns: 1fr;
  }
}

/* Logged user card */
.checkout-logged-user {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem;
  background: rgba(16,185,129,.06);
  border: 1px solid rgba(16,185,129,.2);
  border-radius: var(--radius-sm);
  margin-bottom: 1.5rem;
  animation: fadeSlideIn .35s ease both;
}

@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.checkout-logged-user__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(16,185,129,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: #10b981;
  flex-shrink: 0;
}

.checkout-logged-user__info {
  flex: 1;
}

.checkout-logged-user__info strong {
  display: block;
  font-size: .92rem;
  font-weight: 600;
  color: #fff;
}

.checkout-logged-user__info span {
  display: block;
  font-size: .78rem;
  color: rgba(255,255,255,.45);
}

.checkout-logged-user__logout {
  background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.2);
  border-radius: var(--radius-sm);
  padding: .4rem .75rem;
  font-size: .75rem;
  font-weight: 600;
  color: #ef4444;
  cursor: pointer;
  transition: all var(--transition-smooth);
  font-family: var(--font-body);
  display: flex;
  align-items: center;
  gap: .35rem;
}

.checkout-logged-user__logout:hover {
  background: rgba(239,68,68,.2);
  border-color: rgba(239,68,68,.4);
}

/* ==============================================
   LOGIN MODAL (Checkout)
   ============================================== */
.login-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  visibility: hidden;
  transition: all .3s ease;
}

.login-modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.login-modal {
  background: linear-gradient(170deg, #0f2a4a 0%, #0a1e38 50%, #081a30 100%);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  max-width: 460px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  transform: translateY(20px) scale(.97);
  transition: transform .35s cubic-bezier(.22,.61,.36,1);
  box-shadow: 0 24px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.04) inset;
}

.login-modal-overlay.active .login-modal {
  transform: translateY(0) scale(1);
}

.login-modal__close {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.5);
  font-size: .9rem;
  cursor: pointer;
  transition: all var(--transition-smooth);
  z-index: 2;
}

.login-modal__close:hover {
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.3);
  color: #ef4444;
}

.login-modal__header {
  text-align: center;
  margin-bottom: 1.75rem;
}

.login-modal__logo {
  width: 56px;
  margin-bottom: 1rem;
}

.login-modal__title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: .4rem;
}

.login-modal__subtitle {
  font-size: .85rem;
  color: rgba(255,255,255,.45);
}

.login-modal__tabs {
  display: flex;
  background: rgba(255,255,255,.05);
  border-radius: var(--radius-sm);
  padding: 4px;
  margin-bottom: 1.5rem;
}

.login-modal__tab {
  flex: 1;
  padding: .6rem;
  text-align: center;
  font-size: .82rem;
  font-weight: 600;
  color: rgba(255,255,255,.45);
  border: none;
  background: transparent;
  border-radius: calc(var(--radius-sm) - 2px);
  cursor: pointer;
  transition: all var(--transition-smooth);
  font-family: var(--font-body);
}

.login-modal__tab:hover {
  color: rgba(255,255,255,.7);
}

.login-modal__tab.active {
  background: var(--blue-primary);
  color: #fff;
  box-shadow: 0 2px 12px rgba(var(--blue-primary-rgb), .35);
}

.login-modal__divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.5rem 0;
}

.login-modal__divider::before,
.login-modal__divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,.08);
}

.login-modal__divider span {
  font-size: .75rem;
  color: rgba(255,255,255,.3);
  white-space: nowrap;
}

.login-modal__social-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 1.25rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-sm);
  font-size: .85rem;
  font-weight: 600;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: all var(--transition-smooth);
  font-family: var(--font-body);
}

.login-modal__social-btn:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
  color: #fff;
}

.login-modal::-webkit-scrollbar {
  width: 6px;
}

.login-modal::-webkit-scrollbar-track {
  background: transparent;
}

.login-modal::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.1);
  border-radius: 3px;
}

@media (max-width: 575px) {
  .login-modal {
    padding: 1.75rem;
    max-height: 95vh;
  }

  .login-modal__title {
    font-size: 1.25rem;
  }
}

/* ==============================================
   CHECKOUT — ANIMAÇÕES DE ENTRADA
   ============================================== */
@keyframes checkoutFadeUp {
  from { opacity: 0; transform: translateY(25px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes checkoutFadeRight {
  from { opacity: 0; transform: translateX(-25px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes checkoutFadeLeft {
  from { opacity: 0; transform: translateX(25px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes checkoutScaleIn {
  from { opacity: 0; transform: scale(.92); }
  to   { opacity: 1; transform: scale(1); }
}
.ck-anim { opacity: 0; animation-fill-mode: both; animation-timing-function: cubic-bezier(.22,.61,.36,1); }
.ck-anim--up    { animation-name: checkoutFadeUp; }
.ck-anim--right { animation-name: checkoutFadeRight; }
.ck-anim--left  { animation-name: checkoutFadeLeft; }
.ck-anim--scale { animation-name: checkoutScaleIn; }

/* ==============================================
   CHECKOUT — SELECT GROUP + CHOICES.JS TEMA ESCURO
   ============================================== */
.checkout-select-group {
  position: relative;
  z-index: 100;
  margin-bottom: 1rem;
}

.checkout-select-group__label {
  display: block;
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--blue-primary);
  margin-bottom: .4rem;
}

/* Choices.js — tema escuro público */
.checkout-form-card .choices {
  width: 100%;
  font-family: var(--font-body);
  margin-bottom: 0;
}

.checkout-form-card .choices__inner {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: var(--radius-sm) !important;
  padding: .7rem 1rem !important;
  font-size: .88rem !important;
  color: #fff !important;
  min-height: unset !important;
  display: flex;
  align-items: center;
  transition: all var(--transition-smooth);
}

.checkout-form-card .choices.is-open .choices__inner,
.checkout-form-card .choices__inner:focus-within {
  border-color: var(--blue-primary) !important;
  background: rgba(255,255,255,.08) !important;
  box-shadow: 0 0 0 3px rgba(var(--blue-primary-rgb), .12) !important;
}

.checkout-form-card .choices__list--single {
  padding: 0 !important;
}

.checkout-form-card .choices__list--single .choices__item {
  color: #fff !important;
  font-weight: 600;
}

.checkout-form-card .choices[data-type*=select-one]::after {
  border-color: rgba(255,255,255,.45) transparent transparent !important;
  right: 14px !important;
  top: 50% !important;
  transform: translateY(-25%);
}

.checkout-form-card .choices[data-type*=select-one].is-open::after {
  border-color: transparent transparent var(--blue-primary) !important;
  transform: translateY(-75%);
}

.checkout-form-card .choices__list--dropdown,
.checkout-form-card .choices .choices__list--dropdown,
.checkout-form-card .choices__list[aria-expanded] {
  background-color: #0f2a4a !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.5) !important;
  margin-top: 4px !important;
  z-index: 9999 !important;
}

.checkout-form-card .choices__list--dropdown .choices__item,
.checkout-form-card .choices__list--dropdown .choices__item--selectable,
.checkout-form-card .choices__list--dropdown .choices__item--choice {
  background-color: transparent !important;
  color: rgba(255,255,255,.65) !important;
  font-size: .86rem !important;
  padding: .65rem 1rem !important;
  transition: background .15s ease, color .15s ease;
}

.checkout-form-card .choices__list--dropdown .choices__item.is-highlighted,
.checkout-form-card .choices__list--dropdown .choices__item--selectable.is-highlighted {
  background-color: rgba(var(--blue-primary-rgb), .14) !important;
  color: var(--blue-primary) !important;
}

.checkout-form-card .choices__list--dropdown .choices__item.is-selected {
  background-color: rgba(var(--blue-primary-rgb), .06) !important;
  color: rgba(255,255,255,.9) !important;
  font-weight: 600;
}

.checkout-form-card .choices__list--dropdown .choices__item.is-selected.is-highlighted {
  background-color: rgba(var(--blue-primary-rgb), .18) !important;
  color: var(--blue-primary) !important;
}

.checkout-form-card .choices__list--dropdown .choices__item.is-selected::after {
  content: '✓';
  float: right;
  color: var(--blue-primary);
  font-size: .8rem;
  font-weight: 700;
}

/* ─────────────────────────────────────────
   TICKETS FILTERS — CHOICES.JS TEMA ESCURO
   ───────────────────────────────────────── */
.tickets-filters .choices {
  min-width: 200px;
  font-family: var(--font-body);
  margin-bottom: 0;
}
.tickets-filters .choices__inner {
  background: rgba(255,255,255,.05) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: var(--radius-sm) !important;
  padding: .7rem 1rem !important;
  font-size: .85rem !important;
  color: rgba(255,255,255,.7) !important;
  min-height: unset !important;
  display: flex;
  align-items: center;
  transition: all var(--transition-smooth);
}
.tickets-filters .choices.is-open .choices__inner,
.tickets-filters .choices__inner:focus-within {
  border-color: var(--blue-primary) !important;
  background: rgba(255,255,255,.08) !important;
  box-shadow: 0 0 0 3px rgba(var(--blue-primary-rgb), .12) !important;
}
.tickets-filters .choices__list--single { padding: 0 !important; }
.tickets-filters .choices__list--single .choices__item {
  color: rgba(255,255,255,.7) !important;
}
.tickets-filters .choices[data-type*=select-one]::after {
  border-color: rgba(255,255,255,.4) transparent transparent !important;
  right: 14px !important;
  top: 50% !important;
  transform: translateY(-25%);
}
.tickets-filters .choices[data-type*=select-one].is-open::after {
  border-color: transparent transparent var(--blue-primary) !important;
  transform: translateY(-75%);
}
.tickets-filters .choices__list--dropdown,
.tickets-filters .choices .choices__list--dropdown,
.tickets-filters .choices__list[aria-expanded] {
  background-color: #0f2a4a !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.5) !important;
  margin-top: 4px !important;
  z-index: 9999 !important;
}
.tickets-filters .choices__list--dropdown .choices__item,
.tickets-filters .choices__list--dropdown .choices__item--selectable,
.tickets-filters .choices__list--dropdown .choices__item--choice {
  background-color: transparent !important;
  color: rgba(255,255,255,.65) !important;
  font-size: .85rem !important;
  padding: .6rem 1rem !important;
  transition: background .15s, color .15s;
}
.tickets-filters .choices__list--dropdown .choices__item.is-highlighted,
.tickets-filters .choices__list--dropdown .choices__item--selectable.is-highlighted {
  background-color: rgba(var(--blue-primary-rgb), .14) !important;
  color: var(--blue-primary) !important;
}
.tickets-filters .choices__list--dropdown .choices__item.is-selected {
  background-color: rgba(var(--blue-primary-rgb), .06) !important;
  color: rgba(255,255,255,.9) !important;
  font-weight: 600;
}

/* ==============================================
   ESCUDOS / MATCHUP — Páginas de Ingressos
   ============================================== */

/* Matchup nos cards de evento (eventos.html)
   Escudos flutuando no banner, sem card interno */
.ticket-event-card { position: relative; }

.ticket-event-card__image::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(3,12,27,.04), rgba(3,12,27,.18) 45%, rgba(3,12,27,.68));
  pointer-events: none;
}

.ticket-event-card__badge,
.ticket-event-card__date-badge { z-index: 5; }

.ticket-event-card__matchup {
  position: absolute;
  top: 100px;
  left: 50%;
  z-index: 6;
  width: min(calc(100% - 2.4rem), 260px);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: .85rem;
  margin: 0;
  padding: 0;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.ticket-event-card__matchup-team {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
  text-align: center;
  font-size: .62rem;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
  text-shadow: 0 3px 12px rgba(0,0,0,.85);
}

.ticket-event-card__matchup-team span {
  max-width: 82px;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.ticket-event-card__matchup-shield,
.ticket-event-card__matchup-shield-ph {
  width: 56px;
  height: 56px;
  object-fit: contain;
  filter: drop-shadow(0 10px 14px rgba(0,0,0,.72)) drop-shadow(0 0 10px rgba(var(--blue-primary-rgb), .22));
  transition: transform .35s ease, filter .35s ease;
}

.ticket-event-card:hover .ticket-event-card__matchup-shield,
.ticket-event-card:hover .ticket-event-card__matchup-shield-ph {
  transform: translateY(-3px) scale(1.06);
  filter: drop-shadow(0 14px 18px rgba(0,0,0,.78)) drop-shadow(0 0 14px rgba(var(--blue-primary-rgb), .32));
}

.ticket-event-card__matchup-shield-ph {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.45rem;
  color: rgba(255,255,255,.75);
}

.ticket-event-card__matchup-vs {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-family: var(--font-heading);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: 1.4px;
  color: #fff;
  background: rgba(var(--blue-primary-rgb), .78);
  border: 1px solid rgba(255,255,255,.24);
  box-shadow: 0 10px 24px rgba(0,0,0,.42), 0 0 18px rgba(var(--blue-primary-rgb), .26), inset 0 1px 0 rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

@media (max-width: 575px) {
  .ticket-event-card__image { height: 190px; }
  .ticket-event-card__matchup { top: 95px; width: calc(100% - 2.4rem); max-width: 245px; gap: .55rem; }
  .ticket-event-card__matchup-team { gap: .25rem; font-size: .52rem; letter-spacing: .4px; }
  .ticket-event-card__matchup-team span { max-width: 70px; -webkit-line-clamp: 1; }
  .ticket-event-card__matchup-shield,
  .ticket-event-card__matchup-shield-ph { width: 42px; height: 42px; }
  .ticket-event-card__matchup-vs { width: 30px; height: 30px; font-size: .56rem; letter-spacing: 1px; }
}

/* Matchup no hero do detalhe do evento */
.page-hero__matchup {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.page-hero__matchup-team {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.page-hero__matchup-shield {
  width: clamp(36px, 5vw, 56px);
  height: clamp(36px, 5vw, 56px);
  object-fit: contain;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, .4));
}

/* Matchup no card de detalhe do evento */
.event-detail__matchup {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  margin-bottom: .5rem;
}

.event-detail__matchup-team {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.event-detail__matchup-shield {
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.event-detail__matchup-shield-ph {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .06);
  border-radius: 50%;
  font-size: 1.6rem;
  color: rgba(255, 255, 255, .25);
}

.event-detail__matchup-vs {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--blue-primary);
  letter-spacing: 3px;
}
