/* ── Ticket Sales – Amai branding ── */
/* Kleurenpalet: donker navy #0f1524, groen accent #4ade80 / #22c55e, wit tekst */

:root {
    --ts-bg:        #f8f9fb;
    --ts-card:      #ffffff;
    --ts-border:    #e2e8f0;
    --ts-accent:    #00A04D;
    --ts-accent-dk: #16a34a;
    --ts-dark:      #0f1524;
    --ts-text:      #1e293b;
    --ts-muted:     #64748b;
    --ts-radius:    10px;
    --ts-error:     #ef4444;
}

.ts-checkout {
    max-width: 740px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
    color: var(--ts-text);
}

/* ── Sections ── */
.ts-section {
    background: var(--ts-card);
    border: 1px solid var(--ts-border);
    border-radius: var(--ts-radius);
    padding: 28px 32px;
    margin-bottom: 16px;
    box-shadow: 0 1px 4px rgba(15,21,36,.05);
}
.ts-section h3 {
    margin: 0 0 20px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--ts-dark);
    text-transform: uppercase;
    letter-spacing: .06em;
    display: flex;
    align-items: center;
    gap: 8px;
}
.ts-section h3::before {
    content: '';
    display: inline-block;
    width: 4px;
    height: 18px;
    background: var(--ts-accent);
    border-radius: 2px;
}

/* ── Ticket type cards ── */
.ts-ticket-types {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.ts-type-card {
    flex: 1;
    min-width: 160px;
    border: 2px solid var(--ts-border);
    border-radius: 8px;
    padding: 16px 20px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 4px;
    transition: border-color .2s, box-shadow .2s, background .2s;
    background: #fff;
}
.ts-type-card input[type="radio"] { display: none; }
.ts-type-card:hover {
    border-color: var(--ts-accent);
    background: #f0fdf4;
}
.ts-type-card.is-selected {
    border-color: var(--ts-accent);
    background: #f0fdf4;
    box-shadow: 0 0 0 3px rgba(34,197,94,.15);
}
.ts-type-name { font-weight: 600; color: var(--ts-dark); font-size: .95rem; }
.ts-type-price { font-size: 1.25rem; font-weight: 800; color: var(--ts-accent-dk); }
.ts-type-price small { font-size: .72rem; font-weight: 400; color: var(--ts-muted); }

/* ── Fields grid ── */
.ts-fields-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.ts-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.ts-field--full,
.ts-field--count { grid-column: 1 / -1; }
.ts-field--count input { max-width: 100px; }

.ts-field label {
    font-size: .8rem;
    font-weight: 600;
    color: var(--ts-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.ts-field label .req { color: var(--ts-error); }

.ts-field input,
.ts-field textarea,
.ts-field select {
    padding: 10px 13px;
    border: 1.5px solid var(--ts-border);
    border-radius: 7px;
    font-size: .9rem;
    color: var(--ts-text);
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    width: 100%;
    box-sizing: border-box;
    font-family: inherit;
}
.ts-field input:focus,
.ts-field textarea:focus,
.ts-field select:focus {
    outline: none;
    border-color: var(--ts-accent);
    box-shadow: 0 0 0 3px rgba(34,197,94,.15);
}
.ts-field input::placeholder,
.ts-field textarea::placeholder { color: #94a3b8; font-size: .85rem; }

/* ── Attendee blocks ── */
#ts-attendees { display: flex; flex-direction: column; gap: 12px; }
.ts-attendee-block {
    border: 1.5px solid var(--ts-border);
    border-radius: 8px;
    padding: 16px 20px;
    background: #fafafa;
}
.ts-attendee-label {
    margin: 0 0 12px;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--ts-accent-dk);
}

/* ── Discount ── */
.ts-discount-row {
    display: flex;
    gap: 10px;
    align-items: center;
}
.ts-discount-row input {
    flex: 1;
    padding: 10px 13px;
    border: 1.5px solid var(--ts-border);
    border-radius: 7px;
    font-size: .9rem;
    font-family: inherit;
    color: var(--ts-text);
    transition: border-color .2s;
    
}
.ts-discount-row input::placeholder{
text-transform: none;
}

.ts-discount-row input::placeholder { color: #94a3b8; font-size: .85rem; }
.ts-discount-row input:focus {
    outline: none;
    border-color: var(--ts-accent);
    box-shadow: 0 0 0 3px rgba(34,197,94,.15);
}
.ts-discount-msg {
    margin-top: 8px;
    font-size: .875rem;
    padding: 8px 12px;
    border-radius: 6px;
}
.ts-discount-msg.is-success { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }
.ts-discount-msg.is-error   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }

/* ── Price summary ── */
.ts-price-summary { background: linear-gradient(108deg, #26382E 18.81%, #191919 81.19%); border-color: var(--ts-dark); }
.ts-price-summary h3 { color: #fff; }
.ts-price-summary h3::before { background: var(--ts-accent); }
.ts-price-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: .9rem;
    color: rgba(255,255,255,.65);
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.ts-price-row--total {
    padding-top: 14px;
    border-bottom: none;
    font-size: 1.2rem;
    color: #fff;
}

/* ── Buttons ── */
.ts-btn {
    display: inline-block;
    border-radius: 8px;
    border-radius: 8px;
    padding-top: 16px;
    padding-right: 24px;
    padding-bottom: 16px;
    padding-left: 24px;
    font-size: .9rem;
    font-weight: 700;
    cursor: pointer;
    border: none;
    transition: opacity .2s, transform .1s, background .2s;
    font-family: inherit;
    letter-spacing: .02em;
}
.ts-btn:active { transform: scale(.98); }
.ts-btn--primary {
    background: var(--ts-accent);
    color: #fff;
    border-radius: 8px;
    padding-top: 16px;
    padding-right: 24px;
    padding-bottom: 16px;
    padding-left: 24px;
}
.ts-btn--primary:hover { background: var(--ts-accent-dk); color: #fff; }
.ts-btn--secondary {
    background: #f1f5f9;
    color: var(--ts-text);
    border: 1.5px solid var(--ts-border);
}
.ts-btn--secondary:hover { background: #e2e8f0; }
.ts-btn:disabled { opacity: .45; cursor: not-allowed; }

.ts-submit-row { text-align: center; margin-top: 4px; }
.ts-submit-row .ts-btn {
    padding-top: 16px;
    padding-right: 24px;
    padding-bottom: 16px;
    padding-left: 24px;
    width: 100%;
    border-radius: 8px;
    letter-spacing: .06em;
    font-size: 18px;
    font-weight: 300;
    line-height: 180%;
    border: 1px solid var(--wp--preset--color--primary);
    background-color: var(--wp--preset--color--primary);
}

.ts-submit-row .ts-btn:hover{
    background-color: white;
    color: var(--wp--preset--color--primary);
}

/* ── Notices ── */
.ts-notice {
    padding: 14px 18px;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: .9rem;
}
.ts-notice--error   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.ts-notice--warning { background: #fffbeb; color: #b45309; border: 1px solid #fde68a; }
.ts-notice--success { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }

/* ── Thank-you page ── */
.ts-thankyou { max-width: 640px; margin: 0 auto; text-align: center; }
.ts-thankyou__icon {
    width: 72px; height: 72px;
    background: var(--ts-accent); color: var(--ts-dark);
    border-radius: 50%; font-size: 32px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    box-shadow: 0 0 0 8px rgba(34,197,94,.15);
}
.ts-order-summary { text-align: left; margin-top: 30px; }
.ts-order-summary table { width: 100%; border-collapse: collapse; }
.ts-order-summary th, .ts-order-summary td { padding: 10px 12px; border-bottom: 1px solid var(--ts-border); font-size: .9rem; }
.ts-order-summary th { color: var(--ts-muted); font-weight: 500; width: 45%; }

/* ── Failed / cancel page ── */
.ts-failed { max-width: 580px; margin: 0 auto; text-align: center; padding: 40px 20px; }
.ts-failed__icon {
    width: 72px; height: 72px;
    background: #fef2f2; color: #dc2626;
    border-radius: 50%; font-size: 32px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    border: 2px solid #fecaca;
}
.ts-failed h2 { color: var(--ts-dark); margin-bottom: 10px; }
.ts-failed p { color: var(--ts-muted); margin-bottom: 24px; line-height: 1.6; }
.ts-failed__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ── Help text ── */
.ts-help { font-size: .85rem; color: var(--ts-muted); margin-bottom: 14px; }

/* ── Validation errors ── */
.ts-input--error,
.ts-input--error:focus {
    border-color: var(--ts-error) !important;
    box-shadow: 0 0 0 3px rgba(239,68,68,.12) !important;
}
.ts-input--error::placeholder { color: #fca5a5; }
.ts-field-error {
    display: block;
    margin-top: 4px;
    font-size: .78rem;
    color: var(--ts-error);
    font-weight: 600;
}

/* ── Step indicator ── */
.ts-steps {
    display: flex;
    align-items: center;
    margin-bottom: 24px;
}
.ts-step {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.ts-step__number {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid var(--ts-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .85rem;
    color: var(--ts-muted);
    background: #fff;
    flex-shrink: 0;
    transition: background .3s, border-color .3s, color .3s;
}
.ts-step__label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--ts-muted);
    transition: color .3s;
    white-space: nowrap;
}
.ts-step--active .ts-step__number {
    border-color: var(--ts-accent);
    background: var(--ts-accent);
    color: #fff;
}
.ts-step--active .ts-step__label {
    color: var(--ts-text);
}
.ts-step--done .ts-step__number {
    border-color: var(--ts-accent);
    background: var(--ts-accent);
    color: #fff;
    font-size: 0;
}
.ts-step--done .ts-step__number::after {
    content: '✓';
    font-size: .85rem;
}
.ts-step--done .ts-step__label {
    color: var(--ts-muted);
}
.ts-step-connector {
    flex: 1;
    height: 2px;
    background: var(--ts-border);
    margin: 0 14px;
    transition: background .3s;
}
.ts-step-connector--done {
    background: var(--ts-accent);
}

/* ── Step navigation row ── */
.ts-nav-row {
    display: flex;
    margin-top: 8px;
    margin-bottom: 4px;
}
.ts-nav-row--right {
    justify-content: flex-end;
}
.ts-nav-row--space-between {
    justify-content: space-between;
    align-items: center;
}
.ts-nav-row .ts-btn--primary {
    min-width: 200px;
}
.ts-nav-row .ts-btn--secondary {
    padding: 12px 20px;
    font-size: .875rem;
}

/* ── Responsive ── */
@media (max-width: 600px) {
    .ts-section { padding: 20px 16px; }
    .ts-fields-grid { grid-template-columns: 1fr; }
    .ts-ticket-types { flex-direction: column; }
    .ts-failed__actions { flex-direction: column; }
    .ts-step__label { display: none; }
    .ts-nav-row--space-between { gap: 12px; }
    .ts-nav-row .ts-btn--primary { min-width: 0; flex: 1; }
}
