/* Componentes globais reutilizaveis do portal */
.brand,
.nav a,
.badge,
.card,
.panel,
.event-card,
.message,
.btn,
.qty-btn,
.qty-input {
  transition:all .18s ease;
}

.card:hover,
.panel:hover {
  box-shadow:var(--shadow-soft);
}

.btn,
.button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  border:0;
  font-weight:800;
  cursor:pointer;
}

.btn-primary {
  background:var(--pc-comp-button-primary-bg);
  color:#fff;
}

.btn,
.button,
.qty-btn{
  touch-action:manipulation;
}

.text-muted { color:var(--muted); }
.surface { background:var(--surface); }
.surface-soft { background:var(--surface-2); }


/* Estados e cards compartilhados do portal */
.ticket-price-free{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid #86efac;
  background:#f0fdf4;
  color:#166534;
  font-weight:900;
}

.field-error{color:var(--danger)}

.portal-hub-card,
.order-note-box{
  background:var(--surface-2);
  box-shadow:none;
}

.portal-summary-list{
  display:grid;
  gap:10px;
}

.portal-summary-list .summary__row{
  gap:14px;
}

.portal-state-panel{
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  background:#fff;
}

.portal-state-panel--info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.portal-state-panel--success{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.portal-state-panel--warning{background:#fffbeb;border-color:#fde68a;color:#92400e}
.portal-state-panel--danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}

.portal-state-panel__title{
  margin:0 0 4px;
  font-size:15px;
  font-weight:900;
}

.portal-state-panel__text{
  margin:0;
  line-height:1.5;
}

.portal-state-panel__meta{
  margin-top:8px;
  font-size:12px;
  color:inherit;
  opacity:.82;
}

.portal-action-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.portal-action-list--stack{
  display:grid;
  gap:12px;
}

.portal-section-card{
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}

.portal-section-card__head{
  padding:18px 20px;
  border-bottom:1px solid var(--line);
}

.portal-section-card__body{
  padding:20px;
}

.portal-section-card__eyebrow{
  display:block;
  margin-bottom:6px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
  font-weight:800;
}

.portal-section-card__title{
  margin:0;
  font-size:20px;
  line-height:1.2;
}

.portal-section-card__description{
  margin:8px 0 0;
  color:var(--muted);
}

.portal-empty-card{
  padding:18px;
  border:1px dashed var(--line);
  border-radius:18px;
  background:#fff;
}

@media (max-width: 760px){
  .portal-action-list .btn{flex:1}
  .portal-section-card__head,
  .portal-section-card__body,
  .portal-state-panel{padding:16px}
}
