.nupass-ticket-list,
.nupass-block-my-tickets,
.nupass-block-event-tickets,
.nupass-block-event-meta {
  display: grid;
  gap: 16px;
}

.nupass-block-event-meta {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.nupass-meta-item,
.nupass-ticket-card,
.nupass-ticket-user-card,
.wp-block-nupass-notice,
.nupass-empty-state {
  background: #14141b;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 16px;
}

.nupass-meta-item strong,
.nupass-ticket-card h3,
.nupass-ticket-user-card h3 {
  color: #f5f7fa;
}

.nupass-meta-label,
.nupass-ticket-card p,
.nupass-ticket-user-card p,
.nupass-block-footnote small,
.nupass-meta-item small,
.nupass-ticket-card__meta,
.nupass-ticket-quantity-label {
  color: #9ca3af;
}

.nupass-ticket-card {
  display: grid;
  gap: 14px;
}

.nupass-ticket-card__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.nupass-ticket-price {
  font-size: 1.25rem;
  font-weight: 700;
  color: #ff00ce;
  white-space: nowrap;
}

.nupass-ticket-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.nupass-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 600;
}

.nupass-badge.badge-available { background: rgba(22,163,74,.15); color: #4ade80; }
.nupass-badge.badge-soldout,
.nupass-badge.badge-closed,
.nupass-badge.badge-disabled { background: rgba(220,38,38,.15); color: #f87171; }
.nupass-badge.badge-upcoming,
.nupass-badge.badge-inactive { background: rgba(245,158,11,.15); color: #fbbf24; }

.nupass-ticket-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
}

.nupass-ticket-buy-form {
  display: grid;
  grid-template-columns: 100px minmax(0, 1fr);
  gap: 10px 12px;
  align-items: end;
  width: 100%;
}

.nupass-ticket-quantity-label {
  grid-column: 1 / -1;
  font-size: 0.875rem;
}

.nupass-ticket-quantity {
  width: 100%;
  min-height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: #0f0f14;
  color: #f5f7fa;
  padding: 0.75rem 0.9rem;
}

.nupass-ticket-buy-button {
  width: 100%;
}

.nupass-ticket-buy-button.is-disabled {
  opacity: .6;
  cursor: not-allowed;
}

.nupass-ticket-user-card {
  display: grid;
  grid-template-columns: minmax(120px, 180px) 1fr;
  gap: 16px;
  align-items: center;
}

.nupass-ticket-user-card__image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
}

@media (max-width: 782px) {
  .nupass-ticket-card__head,
  .nupass-ticket-user-card {
    grid-template-columns: 1fr;
    display: grid;
  }

  .nupass-ticket-buy-form {
    grid-template-columns: 1fr;
  }
}


.nupass-ticket-open-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;margin-top:.5rem}
.nupass-ticket-page{background:#0b0b0f;color:#f5f7fa;min-height:100vh}
.nupass-ticket-page__wrap{max-width:1100px;margin:0 auto;padding:2rem 1rem}
.nupass-ticket-view{background:#14141b;border:1px solid rgba(255,255,255,.08);border-radius:24px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.nupass-ticket-view__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.5rem 1.5rem 0}
.nupass-ticket-view__eyebrow{margin:0 0 .4rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}
.nupass-ticket-view__title{margin:0;font-size:2rem;line-height:1.1}
.nupass-ticket-view__body{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.8fr);gap:1.5rem;padding:1.5rem}
.nupass-ticket-view__main{display:grid;gap:1rem}
.nupass-ticket-view__image img{display:block;width:100%;height:auto;border-radius:20px}
.nupass-ticket-view__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}
.nupass-ticket-view__detail{background:#1c1c24;border-radius:18px;padding:1rem}
.nupass-ticket-view__detail strong{display:block;color:#9ca3af;font-size:.8rem;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.05em}
.nupass-ticket-view__detail span{display:block;font-weight:600}
.nupass-ticket-view__qrbox{background:#1c1c24;border-radius:20px;padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.nupass-ticket-view__qr{display:block;width:min(100%,280px);height:auto;background:#fff;padding:.75rem;border-radius:18px}
.nupass-ticket-view__hint{color:#9ca3af;margin:.85rem 0 0.5rem}
.nupass-ticket-view__button{text-decoration:none;width:100%}
.badge-active,.badge-valid{background:rgba(22,163,74,.16);color:#86efac}
.badge-used{background:rgba(245,158,11,.16);color:#fcd34d}
.badge-cancelled,.badge-refunded{background:rgba(220,38,38,.16);color:#fca5a5}
@media (max-width: 900px){.nupass-ticket-view__body{grid-template-columns:1fr}.nupass-ticket-view__header{flex-direction:column}.nupass-ticket-view__title{font-size:1.6rem}}


.nupass-scanner__grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr);gap:1.5rem}
.nupass-scanner__panel{background:#14141b;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:1.25rem;display:grid;gap:1rem}
.nupass-scanner__panel-head h2,.nupass-scanner__panel-head h3{margin:0;color:#f5f7fa}
.nupass-scanner__label{font-size:.9rem;color:#9ca3af}
.nupass-scanner__select,.nupass-scanner__input{width:100%;min-height:48px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#0f0f14;color:#f5f7fa;padding:.85rem 1rem}
.nupass-scanner__camera-shell{position:relative;aspect-ratio:16/10;background:#0b0b0f;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
#nupass-scanner-video{display:block;width:100%;height:100%;object-fit:cover;background:#000}
.nupass-scanner__camera-empty{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:1rem;color:#9ca3af;background:linear-gradient(180deg,rgba(11,11,15,.7),rgba(11,11,15,.95))}

#nupass-html5-reader{position:absolute;inset:0;display:none;background:#000}
#nupass-html5-reader.active{display:block}
#nupass-html5-reader video{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:20px}
#nupass-html5-reader__scan_region,#nupass-html5-reader__dashboard{background:transparent!important;border:0!important;color:#f5f7fa!important}
#nupass-html5-reader img{display:none!important}
.nupass-scanner__file-input{position:absolute;left:-9999px}
.nupass-scanner__actions{display:flex;flex-wrap:wrap;gap:.75rem}
.nupass-scanner__status{margin:0;color:#9ca3af}
.nupass-scanner__form{display:grid;gap:.9rem}
.nupass-scan-result{border-radius:20px;padding:1rem;border:1px solid rgba(255,255,255,.08);background:#1c1c24;display:grid;gap:.5rem;min-height:180px;align-content:start}
.nupass-scan-result__message{margin:0;font-size:1rem;font-weight:600}
.nupass-scan-result__meta{display:grid;gap:.35rem;color:#d1d5db}
.nupass-scan-result.is-valid{border-color:rgba(22,163,74,.35);background:rgba(22,163,74,.12)}
.nupass-scan-result.is-used,.nupass-scan-result.is-wrong_event{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.12)}
.nupass-scan-result.is-invalid{border-color:rgba(220,38,38,.35);background:rgba(220,38,38,.12)}
@media (max-width: 900px){.nupass-scanner__grid{grid-template-columns:1fr}}


.nupass-ticket-reason,
.nupass-scanner__hint {
  display: block;
  color: #9ca3af;
  font-size: 0.9rem;
}

.nupass-scanner__hint {
  margin-top: 0.75rem;
}

.nupass-scan-result__actions {
  margin-top: 1rem;
}


.nupass-ticket-price-wrap {
    text-align: right;
}

.nupass-ticket-total-price {
    font-size: 12px;
    color: #c7cad1;
    margin-top: 4px;
}

.nupass-ticket-fee-line {
    font-size: 12px;
    color: #c7cad1;
    margin: 10px 0 0;
}

.nupass-badge.badge-low-stock { background: rgba(245,158,11,.15); color: #fbbf24; }

.nupass-ticket-availability-note {
  font-size: 0.94rem;
  color: #cbd5e1;
}

.nupass-ticket-availability-note.status-low-stock {
  color: #fbbf24;
}

.nupass-ticket-stock-meter {
  width: 100%;
  height: 6px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,0.08);
}

.nupass-ticket-stock-meter__fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #f59e0b 0%, #ff00ce 100%);
}


/* Nupass frontend ticket card UX polish */
.nupass-ticket-window-line{font-size:.88rem;color:#94a3b8;display:flex;align-items:center;gap:.5rem}
.nupass-ticket-window-line::before{content:"🕒";font-size:.85rem;opacity:.8}
.nupass-ticket-card__actions{margin-top:.25rem}
.nupass-ticket-buy-form{display:block;width:100%}
.nupass-ticket-buy-form__row{display:grid;grid-template-columns:minmax(120px,140px) minmax(0,1fr);gap:12px;align-items:end;width:100%}
.nupass-ticket-quantity-wrap{display:grid;gap:8px}
.nupass-ticket-stepper{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;min-height:52px;border:1px solid rgba(255,255,255,.12);background:#0f0f14;border-radius:14px;overflow:hidden}
.nupass-ticket-stepper__btn{appearance:none;border:0;background:#11131a;color:#f5f7fa;min-height:52px;font-size:1.25rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}
.nupass-ticket-stepper__btn:hover{background:#171a22;color:#fff}
.nupass-ticket-stepper__btn:focus-visible{outline:2px solid var(--wp--preset--color--primary,#ff00ce);outline-offset:-2px}
.nupass-ticket-quantity{width:100%;min-height:52px;border:0;background:transparent;color:#f5f7fa;padding:0 .4rem;text-align:center;font-size:1.05rem;font-weight:600;-moz-appearance:textfield}
.nupass-ticket-quantity::-webkit-outer-spin-button,.nupass-ticket-quantity::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.nupass-ticket-buy-button{min-height:52px;border-radius:14px}
.nupass-ticket-availability-note{font-size:.92rem;line-height:1.5}
.nupass-ticket-card.status-low-stock{box-shadow:0 0 0 1px rgba(245,158,11,.18) inset}
@media (max-width: 782px){.nupass-ticket-buy-form__row{grid-template-columns:1fr}.nupass-ticket-stepper{max-width:180px}}


.nupass-event-status-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .45rem .8rem;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 700;
  margin: 0 0 1rem;
  border: 1px solid rgba(255,255,255,.08);
}
.nupass-event-status-pill.status-coming_soon { background: rgba(245,158,11,.15); color: #fbbf24; }
.nupass-event-status-pill.status-sales_open { background: rgba(22,163,74,.15); color: #4ade80; }
.nupass-event-status-pill.status-sales_paused,
.nupass-event-status-pill.status-cancelled,
.nupass-event-status-pill.status-finished,
.nupass-event-status-pill.status-sold_out { background: rgba(220,38,38,.15); color: #f87171; }
.nupass-event-status-pill.status-draft,
.nupass-event-status-pill.status-published { background: rgba(255,255,255,.08); color: #e5e7eb; }


.nupass-ticket-guest-gate{display:flex;flex-direction:column;gap:.75rem;width:100%;}
.nupass-ticket-guest-gate__text{margin:0;font-size:.95rem;opacity:.9;}
.nupass-ticket-guest-gate__actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;}
.nupass-ticket-guest-gate__actions .nupass-btn,.nupass-ticket-guest-gate__actions .wp-element-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;min-height:44px;padding:.8rem 1rem;border-radius:14px;}
.nupass-ticket-guest-gate__actions .nupass-btn--secondary{background:transparent;border:1px solid rgba(255,255,255,.18);color:inherit;}


.nupass-validator-notice{margin:1rem 0;padding:1rem 1.1rem;border-radius:18px;border:1px solid rgba(255,255,255,.08);font-weight:600}.nupass-validator-notice.is-success{background:rgba(22,163,74,.12);border-color:rgba(22,163,74,.35);color:#86efac}.nupass-validator-notice.is-warning{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35);color:#fcd34d}.nupass-validator-notice.is-error{background:rgba(220,38,38,.12);border-color:rgba(220,38,38,.35);color:#fca5a5}
.nupass-validator-card{margin-top:1rem;background:#14141b;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:1.25rem;display:grid;gap:1rem}.nupass-validator-card__head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.nupass-validator-card__title{margin:0;font-size:1.5rem;line-height:1.1}.nupass-validator-card__body{display:grid;gap:1rem}.nupass-validator-card__meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.85rem}.nupass-validator-card__meta>div{background:#1c1c24;border-radius:18px;padding:1rem}.nupass-validator-card__meta strong{display:block;color:#9ca3af;font-size:.8rem;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.05em}.nupass-validator-card__meta span{display:block;font-weight:600}.nupass-validator-card__button{width:100%;min-height:52px}.nupass-validator-card__status-note{margin:0;color:#d1d5db}.badge-forbidden{background:rgba(220,38,38,.16);color:#fca5a5}@media (max-width:900px){.nupass-validator-card__head{flex-direction:column}.nupass-validator-card__title{font-size:1.25rem}}


.nupass-validator-notice{margin:18px 0 0;padding:14px 16px;border-radius:16px;border:1px solid rgba(255,255,255,.1)}
.nupass-validator-notice.is-success{background:rgba(22,163,74,.12);border-color:rgba(22,163,74,.35);color:#bbf7d0}
.nupass-validator-notice.is-warning{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35);color:#fde68a}
.nupass-validator-notice.is-error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.35);color:#fecaca}
.nupass-validator-card{margin-top:20px;background:linear-gradient(180deg,rgba(255,0,206,.08),rgba(20,20,27,1));border:1px solid rgba(255,0,206,.22);border-radius:24px;padding:1.25rem;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.nupass-validator-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.nupass-validator-card__title{margin:0;font-size:1.5rem;line-height:1.1}
.nupass-validator-card__meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}
.nupass-validator-card__meta div{background:#1c1c24;border-radius:18px;padding:1rem;min-width:0}
.nupass-validator-card__meta strong{display:block;color:#9ca3af;font-size:.8rem;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.05em}
.nupass-validator-card__meta span{display:block;font-weight:600;color:#fff}
.nupass-validator-card__form{margin-top:1rem}
.nupass-validator-card__button{width:100%}
.nupass-validator-card__status-note{margin:.75rem 0 0;color:#d1d5db}
@media (max-width:900px){.nupass-validator-card__head{flex-direction:column}.nupass-validator-card__title{font-size:1.3rem}}
