:root{
  --page-bg:#f5f5f5;
  --panel-bg:#ffffff;
  --line:#d2d7df;
  --line-dark:#c6ccd5;
  --left-bg:#eef1f5;
  --text:#1f2937;
  --muted:#6b7280;
  --accent:#4d6bff;
  --accent-dark:#3153f0;
  --accent-soft:#edf3ff;
  --danger:#b42318;
  --success:#067647;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--page-bg);
  font-family:Arial, Helvetica, sans-serif;
  color:var(--text);
}

a{color:inherit}
button,input,textarea{font:inherit}

.viewport{
  min-height:100%;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding:16px 0 40px;
}

.card{
  width:544px;
  background:var(--panel-bg);
  border:1px solid #dfdfdf;
  padding:12px 18px 24px;
}

.title{
  margin:8px 0 12px;
  text-align:center;
  font-size:31px;
  line-height:1.15;
  letter-spacing:.2px;
  font-weight:500;
  color:#0f172a;
}

.subtitle{
  margin:0 0 16px;
  text-align:center;
  color:var(--muted);
  font-size:15px;
}

.field{ margin-bottom:18px; }

.input-group,
.plain-field,
#payment-element-wrapper{
  display:flex;
  align-items:center;
  width:100%;
  border:1px solid var(--line-dark);
  border-radius:4px;
  background:#fff;
}

.input-group{overflow:hidden}

.left-icon{
  width:60px;
  min-width:60px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--left-bg);
  border-right:1px solid var(--line-dark);
  color:var(--accent);
  align-self:stretch;
}

.left-icon svg{width:28px;height:28px;display:block}

.input-group > input,
.plain-field{
  width:100%;
  min-height:60px;
  padding:0 14px;
  border:0;
  outline:0;
  background:#fff;
  color:#111827;
  font-size:18px;
}

textarea.plain-field{
  min-height:120px;
  height:120px;
  resize:vertical;
  padding-top:13px;
}

input::placeholder, textarea::placeholder{color:#707b89;opacity:1}

.payment-heading{
  margin:16px 0 8px;
  font-size:15px;
  color:var(--muted);
}

#payment-element-wrapper{
  min-height:82px;
  padding:14px;
}

.brands{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  align-items:center;
  column-gap:10px;
  margin:10px 0 24px;
  padding:8px 6px 4px;
}

.brand{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:44px;
}

.accordion{
  border:1px solid var(--line-dark);
  border-radius:3px;
  overflow:hidden;
  background:#fff;
}

.accordion-head{
  width:100%;
  border:0;
  background:#edf3ff;
  min-height:62px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 22px;
  color:var(--accent);
  font-size:19px;
  cursor:pointer;
}

.chevron{
  width:16px;
  height:16px;
  border-right:2px solid var(--accent);
  border-bottom:2px solid var(--accent);
  transform:rotate(-135deg);
  margin-top:8px;
  transition:transform .2s ease, margin-top .2s ease;
}

.accordion.closed .chevron{
  transform:rotate(45deg);
  margin-top:-4px;
}

.accordion-body{
  padding:19px 24px 24px;
  background:#fff;
  border-top:1px solid var(--line);
}

.accordion.closed .accordion-body{display:none}

.checkout-extra{padding:18px 0 0}

.installment-note{
  margin:8px 0 22px;
  font-size:18px;
  line-height:1.55;
  color:#1f1f1f;
}

.pay-btn{
  width:100%;
  min-height:64px;
  border:0;
  border-radius:5px;
  background:#4b6ef3;
  color:#fff;
  font-size:24px;
  font-weight:500;
  cursor:pointer;
  margin:0 0 14px;
}

.pay-btn[disabled]{
  cursor:not-allowed;
  opacity:.65;
}

.secure-note{
  margin:0 0 24px;
  text-align:center;
  color:var(--muted);
  font-size:14px;
}

.bank-logos{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:14px 12px;
  align-items:center;
  justify-items:center;
  color:#9f9f9f;
  margin:0 auto 22px;
  max-width:450px;
  filter:grayscale(1);
  opacity:.96;
}

.bank-logo{
  min-height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#9b9b9b;
  font-weight:700;
  font-size:13px;
  line-height:1;
  text-align:center;
  white-space:nowrap;
}

.bank-logo.small{font-size:12px}
.bank-logo.medium{font-size:14px}
.bank-logo.large{font-size:17px}
.bank-logo.stack{line-height:.92}

.campaign-link-wrap{
  text-align:center;
  margin:8px 0 28px;
  font-size:16px;
}

.campaign-badge{
  display:inline-block;
  min-width:65px;
  padding:2px 10px 3px;
  border-radius:5px;
  background:#4b6ef3;
  color:#fff;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
  margin-right:6px;
  vertical-align:middle;
}

.campaign-link{
  color:#3b5eff;
  text-decoration:none;
  vertical-align:middle;
}

.provider-note{
  margin:0;
  text-align:center;
  color:#111;
  font-size:17px;
  line-height:1.55;
}

.provider-brand{
  display:inline-block;
  color:#3153f0;
  font-style:italic;
  font-weight:700;
  font-size:22px;
  letter-spacing:-.4px;
  vertical-align:middle;
}

.message,
.status-box{
  border-radius:8px;
  padding:12px 14px;
  margin:0 0 16px;
  font-size:15px;
  line-height:1.45;
}

.message{display:none}
.message.visible{display:block}
.message.error,
.status-box.error{background:#fef3f2;color:var(--danger);border:1px solid #fecdca}
.message.info,
.status-box.info{background:#eff8ff;color:#175cd3;border:1px solid #b2ddff}
.message.success,
.status-box.success{background:#ecfdf3;color:var(--success);border:1px solid #abefc6}

.summary{
  border:1px solid var(--line-dark);
  border-radius:8px;
  background:#fff;
  padding:16px;
  margin-top:16px;
}

.summary-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
  border-bottom:1px dashed #e5e7eb;
}

.summary-row:last-child{border-bottom:0}
.summary-label{color:var(--muted)}
.summary-value{font-weight:600;text-align:right}
.status-actions{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}
.secondary-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 16px;
  border-radius:6px;
  border:1px solid var(--line-dark);
  text-decoration:none;
  background:#fff;
}

.spinner{
  width:18px;
  height:18px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.45);
  border-top-color:#fff;
  display:inline-block;
  animation:spin .9s linear infinite;
  vertical-align:middle;
  margin-right:10px;
}

@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width:600px){
  .viewport{padding:0}
  .card{width:100%;border-left:0;border-right:0;border-radius:0;padding:12px 14px 22px}
  .brands{grid-template-columns:repeat(2, 1fr);row-gap:10px}
  .bank-logos{grid-template-columns:repeat(4, 1fr)}
}


.card-element-wrapper {
  border: 1px solid var(--line-dark);
  border-radius: 4px;
  background: #fff;
  padding: 18px 16px 14px;
  min-height: 78px;
}

#card-element {
  min-height: 26px;
}

.card-errors {
  min-height: 20px;
  margin-top: 10px;
  color: #b42318;
  font-size: 14px;
}


#stripe-loading{margin-bottom:10px}
.stripe-grid{
  display:block;
  padding:14px;
  min-height:auto;
}
.stripe-field{margin-bottom:14px;width:100%}
.stripe-row{display:grid;grid-template-columns:1fr;gap:12px}
.stripe-label{display:block;margin:0 0 6px;color:var(--muted);font-size:14px}
.stripe-input{
  border:1px solid var(--line-dark);
  border-radius:8px;
  background:#fff;
  padding:16px 14px;
  min-height:56px;
  width:100%;
  box-sizing:border-box;
}
.stripe-input--ready{border-color:#b9c2cf}
.stripe-input--focus{border-color:var(--accent); box-shadow:0 0 0 3px rgba(77,107,255,.10)}
.stripe-input--invalid{border-color:#fda29b}
@media (max-width:600px){.stripe-row{grid-template-columns:1fr}}



.order-summary{
  border:1px solid var(--line-dark);
  border-radius:6px;
  background:#fff;
  padding:16px 18px;
  margin:0 0 18px;
}
.order-summary h2{margin:0 0 14px;font-size:20px;color:#0f172a}
.summary-grid{display:grid;grid-template-columns:1fr;gap:12px}
.summary-row{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid #edf0f4;padding-bottom:10px}
.summary-row:last-child{border-bottom:0;padding-bottom:0}
.summary-label{color:var(--muted);font-size:14px}
.summary-value{color:#111827;font-size:15px;text-align:right;font-weight:600}
.summary-seats{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.seat-pill{border:1px solid #cdd5df;background:#f8fafc;border-radius:999px;padding:6px 10px;font-size:12px;color:#334155}
.hold-note{margin:10px 0 0;font-size:13px;color:#b45309}
.status-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.secondary-btn,.primary-link-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 16px;border-radius:5px;text-decoration:none;font-size:16px}
.secondary-btn{border:1px solid var(--line-dark);background:#fff;color:#0f172a}
.primary-link-btn{border:0;background:#4b6ef3;color:#fff}
.status-box{border-radius:6px;padding:14px 16px;font-size:16px;line-height:1.45}
.status-box.info{background:#eff6ff;color:#1d4ed8}
.status-box.success{background:#ecfdf3;color:#067647}
.status-box.error{background:#fef3f2;color:#b42318}
.page-hint{margin:12px 0 0;color:var(--muted);font-size:14px;text-align:center}
.message{display:none;border-radius:6px;padding:14px 16px;font-size:15px;line-height:1.45;margin:0 0 16px}
.message.visible{display:block}
.message.info{background:#eff6ff;color:#1d4ed8}
.message.success{background:#ecfdf3;color:#067647}
.message.error{background:#fef3f2;color:#b42318}
.card-element-wrapper{display:block;padding:16px}
.stripe-grid{display:grid;gap:14px}
.stripe-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stripe-field{display:flex;flex-direction:column;gap:8px}
.stripe-label{font-size:14px;color:#64748b}
.stripe-input{border:1px solid var(--line-dark);border-radius:4px;background:#fff;min-height:52px;padding:16px 14px;transition:border-color .18s ease, box-shadow .18s ease}
.stripe-input--focus{border-color:#4d6bff;box-shadow:0 0 0 3px rgba(77,107,255,.12)}
.stripe-input--invalid{border-color:#b42318}
.card-errors{font-size:14px;color:#b42318;min-height:18px}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;margin-right:10px;vertical-align:middle;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ticket-shell{max-width:1120px;margin:0 auto;padding:20px 16px 40px}
.ticket-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin:0 0 20px}
.ticket-page-title{margin:0;font-size:32px;color:#0f172a}
.ticket-page-subtitle{margin:6px 0 0;color:#64748b;font-size:15px}
.ticket-actions{display:flex;gap:10px;flex-wrap:wrap}
.ticket-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:18px}
.ticket-card-ui{background:#fff;border-radius:24px;overflow:hidden;border:1px solid #dbe1ea;box-shadow:0 10px 24px rgba(15,23,42,.08)}
.ticket-card-head{background:#2563eb;color:#fff;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.ticket-brand{font-size:22px;font-weight:800;letter-spacing:-.02em}
.ticket-badge{border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:6px 10px;font-size:12px}
.ticket-card-body{padding:20px}
.ticket-event{margin:0 0 6px;font-size:25px;color:#0f172a}
.ticket-meta-list{display:grid;grid-template-columns:repeat(3, 1fr);gap:12px;margin:16px 0 18px}
.ticket-meta-label{color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.ticket-meta-value{color:#111827;font-weight:700;font-size:20px}
.ticket-qr-wrap{display:flex;justify-content:center;margin:18px 0}
.ticket-qr{width:210px;height:210px;border-radius:16px;border:1px solid #dbe1ea;background:#fff;padding:12px}
.ticket-strip{background:#0f172a;color:#fff;padding:12px 16px;text-align:center;font-size:18px;font-weight:700;letter-spacing:.08em}
.ticket-footer{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
.ticket-mini{border:1px solid #e5e7eb;border-radius:14px;padding:12px;background:#f8fafc}
.ticket-mini .ticket-meta-label{font-size:11px}
.ticket-mini .ticket-meta-value{font-size:15px}
.mono-code{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;word-break:break-all}
.center-muted{text-align:center;color:var(--muted);font-size:14px}
@media (max-width: 720px){.card{width:min(100%, 544px);margin:0 12px}.ticket-page-title{font-size:26px}}
@media (max-width: 520px){.stripe-row{grid-template-columns:1fr}.ticket-meta-list{grid-template-columns:1fr}.ticket-footer{grid-template-columns:1fr}.ticket-qr{width:180px;height:180px}}



/* ===== FINAL PAYNKOLAY CHECKOUT OVERRIDE ===== */
.card-element-wrapper{
  display:block !important;
  padding:16px !important;
}

.stripe-grid{
  display:grid !important;
  gap:14px !important;
}

.stripe-field{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  min-width:0 !important;
}

.stripe-row{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,120px) !important;
  gap:14px !important;
  align-items:end !important;
}

.stripe-label{
  display:block !important;
  margin:0 !important;
  font-size:14px !important;
  line-height:1.25 !important;
  color:#64748b !important;
}

.stripe-input{
  width:100% !important;
  box-sizing:border-box !important;
  border:1px solid var(--line-dark) !important;
  border-radius:8px !important;
  background:#fff !important;
  min-height:64px !important;
  padding:16px 14px !important;
  transition:border-color .18s ease, box-shadow .18s ease !important;
}

.stripe-input--ready{
  border-color:#b9c2cf !important;
}

.stripe-input--focus{
  border-color:#4d6bff !important;
  box-shadow:0 0 0 3px rgba(77,107,255,.12) !important;
}

.stripe-input--invalid{
  border-color:#b42318 !important;
}

.card-errors{
  min-height:18px !important;
  font-size:14px !important;
  color:#b42318 !important;
}

@media (max-width:600px){
  .stripe-row{
    grid-template-columns:minmax(0,1fr) minmax(0,118px) !important;
    gap:12px !important;
  }

  .stripe-input{
    min-height:68px !important;
    padding:18px 14px !important;
  }
}

@media (max-width:420px){
  .stripe-row{
    grid-template-columns:1fr !important;
  }

  .stripe-input{
    min-height:70px !important;
  }
}
/* ===== END FINAL PAYNKOLAY CHECKOUT OVERRIDE ===== */

