/*
 * Tixomat Checkout
 * Gleiche Design-Sprache wie der Ticket Selector.
 */

/* Shortcode-Wrapper in Flex/Grid-Layouts volle Breite erzwingen */
:has(> .tix-co) { width: 100%; }

.tix-co {
    width: 100%;
    max-width: 640px;
    box-sizing: border-box;
    font-family: var(--tix-font-body, 'DM Sans'), sans-serif;
    font-size: var(--tix-body, 15px);
}

/* Links: Farbe nicht vom Theme überschreiben lassen (außer Buttons) */
.tix-co a:not(.tix-co-submit):not(.tix-mc-checkout-btn),
.tix-co a:link:not(.tix-co-submit):not(.tix-mc-checkout-btn),
.tix-co a:visited:not(.tix-co-submit):not(.tix-mc-checkout-btn) {
    color: inherit !important;
}

/* ── Sections ── */
.tix-co-section { margin-bottom: 32px; }

.tix-co-heading {
    font-size: var(--tix-h4, 16px);
    font-weight: 700;
    margin: 0 0 16px 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--tix-border, #333);
}

/* ══════════════════════════════════════
   LOGIN
   ══════════════════════════════════════ */
.tix-co-login-section {
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    padding: 14px 16px;
    background: var(--tix-cat-bg, transparent);
}

.tix-co-login-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--tix-body, 15px);
}

.tix-co-link-btn {
    background: none;
    border: none;
    color: var(--tix-input-focus, #c8ff00);
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    font-size: inherit;
    font-family: var(--tix-font-body, inherit);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.tix-co-link-btn:hover { opacity: 0.8; }

.tix-co-login-form {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.08);
}

.tix-co-login-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
}

.tix-co-btn-login {
    padding: 10px 24px;
    border: none;
    border-radius: var(--tix-buy-radius, 8px);
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    font-weight: 700;
    font-size: var(--tix-btn, 14px);
    cursor: pointer;
    font-family: var(--tix-font-body, inherit);
    transition: background 0.2s, opacity 0.2s;
}

.tix-co-btn-login:hover { background: var(--tix-buy-hover, var(--tix-buy-bg)); color: var(--tix-buy-hover-color, var(--tix-buy-color, #000)); opacity: 0.9; }

.tix-co-login-msg {
    font-size: var(--tix-small, 13px);
}

.tix-co-login-msg.success { color: var(--tix-success-color, #4caf50); }
.tix-co-login-msg.error   { color: var(--tix-sale-color, #ef5350); }

/* ══════════════════════════════════════
   WARENKORB (kompakt)
   ══════════════════════════════════════ */
.tix-co-cart {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.tix-co-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    font-size: var(--tix-body, 15px);
}

.tix-co-item-info {
    flex: 1; min-width: 0;
}
.tix-co-item-name {
    font-weight: 700; white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
    display: block;
    font-size: var(--tix-font-name, 1rem);
}
.tix-co-item-bundle-hint {
    display: block;
    font-size: 0.75rem;
    opacity: 0.55;
    font-weight: 400;
    margin-top: 2px;
}

/* Preis – wie tix-sel-cat-price */
.tix-co-item-price {
    font-weight: 700;
    font-size: var(--tix-font-price, 1.1rem);
    white-space: nowrap;
    text-align: right;
    flex-shrink: 0;
    min-width: 80px;
}
.tix-co-item-price-sale {
    display: block;
    color: var(--tix-sale-color, #ef5350);
}
.tix-co-item-price-old {
    display: block;
    text-decoration: line-through;
    opacity: 0.45;
    font-size: 0.75em;
    font-weight: 400;
    line-height: 1.2;
}

/* Qty – inline wie tix-sel-cat-qty */
.tix-co-item-qty {
    display: flex !important; flex-direction: row !important; flex-wrap: nowrap !important;
    align-items: center; gap: 8px; flex-shrink: 0;
}

.tix-co-qty-btn {
    width: var(--tix-btn-size, 36px); height: var(--tix-btn-size, 36px);
    border-radius: var(--tix-btn-radius, 50%);
    border: 1px solid currentColor; background: transparent; color: inherit;
    font-size: 18px; line-height: 1; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background 0.15s, color 0.15s, border-color 0.15s; padding: 0;
    flex-shrink: 0;
}
.tix-co-qty-btn:hover {
    background: var(--tix-buy-bg, #c8ff00); color: var(--tix-buy-color, #000); border-color: var(--tix-buy-bg, #c8ff00);
}

.tix-co-qty-val {
    min-width: 24px; text-align: center;
    font-weight: 700; font-size: 1rem; font-variant-numeric: tabular-nums;
}

.tix-co-item-remove {
    background: none; border: none; color: inherit;
    opacity: 0.3; cursor: pointer; font-size: 14px; padding: 2px;
    transition: opacity 0.15s, color 0.15s; flex-shrink: 0;
}
.tix-co-item-remove:hover { opacity: 1; color: var(--tix-sale-color, #ef5350); }

.tix-co-empty { text-align: center; padding: 40px 20px; }
.tix-co-btn-back {
    display: inline-block; margin-top: 12px; padding: 14px 32px;
    border: 2px solid var(--tix-text, currentColor); color: var(--tix-text, inherit);
    border-radius: var(--tix-buy-radius, 8px); text-decoration: none; font-weight: 700;
    font-size: 1rem; transition: background 0.2s, color 0.2s;
    background: transparent;
}
.tix-co-btn-back:hover {
    background: var(--tix-text, #333); color: var(--tix-co-bg, #fff);
}

/* Weitere Tickets kaufen (Variante 2) */
.tix-co-btn-more {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding: 10px 20px;
    border: var(--tix-btn2-border, 1px solid currentColor);
    border-radius: var(--tix-btn2-radius, 8px);
    background: var(--tix-btn2-bg, transparent);
    color: var(--tix-btn2-color, inherit) !important;
    font-weight: 700;
    font-size: var(--tix-btn2-font-size, 0.9rem);
    text-decoration: none !important;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
    cursor: pointer;
    font-family: var(--tix-font-body, inherit);
}
.tix-co-btn-more:hover {
    background: var(--tix-btn2-hover-bg, var(--tix-btn2-bg, transparent));
    color: var(--tix-btn2-hover-color, var(--tix-btn2-color, inherit)) !important;
    border-color: var(--tix-btn2-hover-bg, currentColor);
    opacity: 0.85;
}

/* ══════════════════════════════════════
   GUTSCHEINCODE
   ══════════════════════════════════════ */
.tix-co-coupon-input-wrap {
    display: flex;
    gap: 8px;
}

.tix-co-coupon-input-wrap .tix-co-input {
    flex: 1;
}

.tix-co-coupon-btn {
    padding: 10px 20px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-input-radius, 6px);
    background: transparent;
    color: inherit;
    font-weight: 600;
    font-size: var(--tix-btn, 14px);
    cursor: pointer;
    font-family: var(--tix-font-body, inherit);
    white-space: nowrap;
    transition: border-color 0.2s, background 0.2s;
}

.tix-co-coupon-btn:hover {
    border-color: var(--tix-input-focus, #c8ff00);
    background: rgba(200, 255, 0, 0.06);
}

.tix-co-coupon-applied {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}

.tix-co-coupon-applied:empty {
    display: none;
    margin: 0;
}

.tix-co-coupon-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    border-radius: 20px;
    background: rgba(200, 255, 0, 0.12);
    font-size: var(--tix-label, 12px);
    font-weight: 700;
}

.tix-co-coupon-code {
    letter-spacing: 0.05em;
}

.tix-co-coupon-remove {
    background: none; border: none; color: inherit;
    opacity: 0.5; cursor: pointer; font-size: 12px;
    padding: 0 2px; transition: opacity 0.15s;
}
.tix-co-coupon-remove:hover { opacity: 1; color: var(--tix-sale-color, #ef5350); }

.tix-co-coupon-msg {
    margin-top: 8px;
    font-size: var(--tix-small, 13px);
    padding: 8px 12px;
    border-radius: var(--tix-radius, 8px);
}
.tix-co-coupon-msg.success { background: rgba(46, 125, 50, 0.12); color: var(--tix-success-color, #4caf50); }
.tix-co-coupon-msg.error   { background: rgba(211, 47, 47, 0.12); color: var(--tix-sale-color, #ef5350); }

/* ══════════════════════════════════════
   FORMULARFELDER
   ══════════════════════════════════════ */
.tix-co-fields { display: flex; flex-wrap: wrap; gap: 12px; }
.tix-co-field { display: flex; flex-direction: column; gap: 4px; }
.tix-co-field-full { width: 100%; }
.tix-co-field-half { width: calc(50% - 6px); }
.tix-co-field-third { width: calc(33.333% - 8px); }
.tix-co-field-twothirds { width: calc(66.666% - 4px); }

/* Firma aufklappbar */
.tix-co-company-wrap { margin-top: 4px; }
.tix-co-company-toggle { font-size: var(--tix-small, 13px); }
.tix-co-company-field { margin-top: 8px; }

.tix-co-label { font-size: var(--tix-small, 13px); font-weight: 600; opacity: 0.8; }
.tix-co-req { color: var(--tix-sale-color, #ef5350); text-decoration: none; margin-left: 2px; }

.tix-co-input,
.tix-co-select,
.tix-co-textarea {
    width: 100%; padding: 10px 14px;
    border: 1px solid var(--tix-input-border, #555);
    border-radius: var(--tix-input-radius, 6px);
    background: var(--tix-input-bg, transparent);
    color: inherit; font-size: var(--tix-body, 15px); font-family: var(--tix-font-body, inherit);
    transition: border-color 0.2s;
    appearance: none; -webkit-appearance: none; box-sizing: border-box;
}

.tix-co-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 12px center;
    padding-right: 36px; cursor: pointer;
}

.tix-co-input:focus, .tix-co-select:focus, .tix-co-textarea:focus {
    outline: none; border-color: var(--tix-input-focus, #c8ff00);
}

.tix-co-textarea { min-height: 80px; resize: vertical; }

/* ── Konto erstellen ── */
.tix-co-create-account {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,0.06);
}

/* Custom Checkbox */
.tix-co-check-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: var(--tix-small, 13px);
    cursor: pointer;
    line-height: 1.4;
}

.tix-co-check {
    display: none;
}

.tix-co-check-custom {
    width: 20px; height: 20px; min-width: 20px;
    border: 2px solid var(--tix-input-border, #555);
    border-radius: 4px;
    position: relative;
    transition: border-color 0.2s, background 0.2s;
    margin-top: 1px;
}

.tix-co-check:checked + .tix-co-check-custom {
    border-color: var(--tix-input-focus, #c8ff00);
    background: var(--tix-input-focus, #c8ff00);
}

.tix-co-check:checked + .tix-co-check-custom::after {
    content: '';
    position: absolute;
    top: 2px; left: 6px;
    width: 5px; height: 10px;
    border: solid var(--tix-buy-color, #000);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* ══════════════════════════════════════
   VERSAND INFO
   ══════════════════════════════════════ */
.tix-co-shipping-info {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 16px;
    border: 1px solid var(--tix-border, #333); border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    font-size: var(--tix-body, 15px); opacity: 0.7;
}
.tix-co-shipping-icon { font-size: 1.3rem; }

/* ══════════════════════════════════════
   ZAHLUNGSARTEN
   ══════════════════════════════════════ */
.tix-co-gateways { display: flex; flex-direction: column; gap: var(--tix-gap, 10px); }

.tix-co-gateway {
    border: 1px solid var(--tix-border, #333); border-radius: var(--tix-radius, 8px);
    padding: 14px 16px; transition: border-color 0.2s, background 0.2s; cursor: pointer;
    background: var(--tix-cat-bg, transparent);
}
.tix-co-gateway.tix-co-gw-active {
    border-color: var(--tix-input-focus, #c8ff00);
    background: rgba(200, 255, 0, 0.04);
}

.tix-co-gw-label {
    display: flex; align-items: center; gap: 10px;
    cursor: pointer; font-weight: 600; font-size: var(--tix-font-name, 1rem);
}

.tix-co-gw-radio { display: none; }

.tix-co-gw-radio-custom {
    width: 20px; height: 20px; border-radius: 50%;
    border: 2px solid var(--tix-input-border, #555); flex-shrink: 0;
    position: relative; transition: border-color 0.2s;
}
.tix-co-gw-radio:checked + .tix-co-gw-radio-custom { border-color: var(--tix-input-focus, #c8ff00); }
.tix-co-gw-radio:checked + .tix-co-gw-radio-custom::after {
    content: ''; position: absolute; top: 50%; left: 50%;
    width: 10px; height: 10px; border-radius: 50%;
    background: var(--tix-input-focus, #c8ff00); transform: translate(-50%, -50%);
}

.tix-co-gw-title { flex: 1; }
.tix-co-gw-icon { flex-shrink: 0; }
.tix-co-gw-icon img { height: 24px; width: auto; display: block; }

.tix-co-gw-fields {
    margin-top: 12px; padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.tix-co-gw-desc { font-size: var(--tix-small, 13px); opacity: 0.6; margin: 0 0 8px 0; }
/* payment_fields() Ausgabe: Text klein und gedimmt halten */
.tix-co-gw-fields > p { font-size: var(--tix-small, 13px); opacity: 0.6; margin: 0 0 8px 0; }

.tix-co-gw-fields input[type="text"],
.tix-co-gw-fields input[type="tel"],
.tix-co-gw-fields input[type="number"],
.tix-co-gw-fields select {
    width: 100%; padding: 10px 14px;
    border: 1px solid var(--tix-input-border, #555); border-radius: var(--tix-input-radius, 6px);
    background: var(--tix-input-bg, transparent); color: inherit;
    font-size: var(--tix-body, 15px); font-family: var(--tix-font-body, inherit); box-sizing: border-box;
}
.tix-co-gw-fields label {
    font-size: var(--tix-small, 13px); font-weight: 600; opacity: 0.8;
    display: block; margin-bottom: 4px;
}

/* ══════════════════════════════════════
   ZUSAMMENFASSUNG
   ══════════════════════════════════════ */
.tix-co-summary {
    padding: 14px 0; margin-bottom: 16px;
}
.tix-co-summary-row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 4px 0; font-size: var(--tix-body, 15px);
}
.tix-co-summary-total {
    font-weight: 700; font-size: var(--tix-h3, 18px);
    padding-top: 10px; margin-top: 6px; border-top: 1px solid var(--tix-border, #333);
}

.tix-co-vat-note {
    font-size: 0.65em;
    font-weight: 400;
    opacity: 0.5;
}

.tix-co-discount-row { color: var(--tix-success-color, #4caf50); }
.tix-co-fee-row { font-size: var(--tix-small, 13px); }
.tix-co-fees:empty { display: none; }

/* ══════════════════════════════════════
   RECHTLICHES
   ══════════════════════════════════════ */
.tix-co-legal {
    margin-bottom: 20px;
    padding: 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    font-size: var(--tix-small, 13px);
}

.tix-co-legal-heading {
    font-size: var(--tix-small, 13px);
    font-weight: 700;
    margin: 0 0 12px 0;
}

.tix-co-legal .tix-co-check-label {
    font-size: var(--tix-small, 13px);
}

.tix-co-legal-checks {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.tix-co-legal-link,
.tix-co-legal-link:link,
.tix-co-legal-link:visited,
.tix-co-legal-link:hover,
.tix-co-legal-link:active,
.tix-co-legal-link:focus {
    color: inherit !important;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: opacity 0.15s;
}
.tix-co-legal-link:hover { opacity: 0.7 !important; }

.tix-co-legal-note {
    font-size: var(--tix-small, 13px);
    opacity: 0.65;
    margin: 0;
    padding-left: 30px;
}

/* ══════════════════════════════════════
   NEWSLETTER
   ══════════════════════════════════════ */
.tix-co-newsletter {
    margin-top: 16px;
    margin-bottom: 24px;
    padding: 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    font-size: var(--tix-small, 13px);
}
.tix-co-newsletter-heading {
    font-size: var(--tix-small, 13px);
    font-weight: 700;
    margin: 0 0 12px 0;
}
.tix-co-newsletter .tix-co-check-label {
    font-size: var(--tix-small, 13px);
}
.tix-co-newsletter-legal {
    font-size: var(--tix-small, 13px);
    opacity: 0.55;
    margin: 6px 0 0;
    padding-left: 30px;
    line-height: 1.4;
}
.tix-co-newsletter-field {
    margin-top: 8px;
    padding-left: 30px;
}

/* ══════════════════════════════════════
   SUBMIT
   ══════════════════════════════════════ */
.tix-co-submit {
    display: block !important; box-sizing: border-box; text-align: center !important; text-decoration: none !important;
    width: 100% !important; padding: 16px !important; margin-top: 28px; border: var(--tix-btn1-border, none) !important;
    border-radius: var(--tix-btn1-radius, 8px) !important;
    background: var(--tix-btn1-bg, #c8ff00) !important; color: var(--tix-btn1-color, #000) !important;
    font-weight: 700 !important; font-size: var(--tix-btn1-font-size, 1.05rem) !important;
    cursor: pointer; transition: background 0.2s, opacity 0.2s; font-family: var(--tix-font-body, inherit);
    line-height: 1.4;
}
.tix-co-submit:hover:not(:disabled) { background: var(--tix-btn1-hover-bg, var(--tix-btn1-bg)) !important; color: var(--tix-btn1-hover-color, var(--tix-btn1-color, #000)) !important; opacity: 0.9; }
.tix-co-submit:disabled { opacity: 0.3 !important; cursor: not-allowed; }

/* Messages */
.tix-co-message {
    margin-top: 12px; padding: 12px 16px;
    border-radius: var(--tix-radius, 8px); font-size: var(--tix-small, 13px); text-align: center;
}
.tix-co-msg-success { background: rgba(46, 125, 50, 0.15); color: var(--tix-success-color, #4caf50); }
.tix-co-msg-error   { background: rgba(211, 47, 47, 0.15); color: var(--tix-sale-color, #ef5350); }

/* Loading */
.tix-co-loading { position: relative; pointer-events: none; }
.tix-co-loading::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.15); border-radius: var(--tix-radius, 8px);
}

/* WC Price */
.tix-co .woocommerce-Price-amount { font-variant-numeric: tabular-nums; }

/* Stripe / iFrames */
.tix-co-gw-fields .wc-stripe-elements-field,
.tix-co-gw-fields iframe {
    border: 1px solid var(--tix-input-border, #555) !important;
    border-radius: var(--tix-input-radius, 6px) !important;
    padding: 10px !important;
}

/* Validation */
.tix-co-field-error .tix-co-input,
.tix-co-field-error .tix-co-select { border-color: var(--tix-sale-color, #ef5350) !important; }
.tix-co-field-error .tix-co-check-custom { border-color: var(--tix-sale-color, #ef5350) !important; }
.tix-co-legal.tix-co-field-error { border-color: var(--tix-sale-color, #ef5350) !important; }
.tix-co-legal.tix-co-field-error .tix-co-legal-heading { color: var(--tix-sale-color, #ef5350); }

/* Google Places Autocomplete dropdown */
.pac-container {
    z-index: 999999 !important;
    border-radius: 8px !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4) !important;
    font-family: var(--tix-font-body, inherit) !important;
}

/* ══════════════════════════════════════
   DANKE-SEITE
   ══════════════════════════════════════ */

.tix-co-ty-banner {
    text-align: center;
    padding: 32px 20px 24px;
    margin-bottom: 24px;
}

.tix-co-ty-icon {
    width: 56px; height: 56px; margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    font-size: 28px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}

.tix-co-ty-title {
    font-size: var(--tix-h2, 22px); font-weight: 700;
    margin: 0 0 8px;
}

.tix-co-ty-subtitle {
    font-size: var(--tix-small, 13px); opacity: 0.6; margin: 0;
}

/* Tickets */
.tix-co-ty-tickets {
    display: flex; flex-direction: column; gap: 8px;
}

.tix-co-ty-ticket {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; padding: 12px 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
}

.tix-co-ty-ticket-info {
    display: flex; flex-direction: column; gap: 2px; min-width: 0;
}

.tix-co-ty-ticket-event {
    font-weight: 700; font-size: var(--tix-small, 13px);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.tix-co-ty-ticket-type {
    font-size: var(--tix-label, 12px); opacity: 0.6;
}

.tix-co-ty-ticket-code {
    font-size: var(--tix-label, 12px); opacity: 0.4;
    font-family: monospace; letter-spacing: 0.05em;
}

.tix-co-ty-ticket-dl {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: var(--tix-buy-radius, 8px);
    background: var(--tix-buy-bg, #c8ff00); color: var(--tix-buy-color, #000) !important;
    font-weight: 700; font-size: var(--tix-label, 12px);
    text-decoration: none; white-space: nowrap; flex-shrink: 0;
    transition: background 0.2s;
}
.tix-co-ty-ticket-dl:hover { background: var(--tix-buy-hover, var(--tix-buy-bg)); color: var(--tix-buy-hover-color, var(--tix-buy-color, #000)); }

.tix-co-ty-dl-icon { font-size: 1.1em; }

.tix-co-ty-ticket-pending {
    font-size: var(--tix-label, 12px); opacity: 0.45; white-space: nowrap; font-style: italic;
}

.tix-co-ty-tickets-note {
    font-size: var(--tix-small, 13px); opacity: 0.6; margin: 0;
    padding: 12px 16px;
    border: 1px dashed var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
}

/* Bestellübersicht */
.tix-co-ty-items {
    display: flex; flex-direction: column; gap: 0;
    margin-bottom: 14px;
}

.tix-co-ty-item {
    display: flex; align-items: baseline; gap: 8px;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    font-size: var(--tix-small, 13px);
}
.tix-co-ty-item:last-child { border-bottom: none; }

.tix-co-ty-item-name { flex: 1; font-weight: 600; }
.tix-co-ty-item-qty { opacity: 0.5; font-size: var(--tix-label, 12px); min-width: 30px; }
.tix-co-ty-item-total { font-weight: 700; min-width: 60px; text-align: right; }

/* Details */
.tix-co-ty-details {
    display: flex; flex-direction: column; gap: 10px;
}

.tix-co-ty-detail {
    display: flex; justify-content: space-between; gap: 12px; font-size: var(--tix-small, 13px);
}

.tix-co-ty-detail-label {
    font-weight: 600; opacity: 0.5; flex-shrink: 0;
}

.tix-co-ty-detail-value { text-align: right; }

.tix-co-ty-status {
    font-weight: 700; padding: 2px 10px; border-radius: 20px;
    font-size: var(--tix-label, 12px); display: inline-block;
}
.tix-co-ty-status-completed,
.tix-co-ty-status-processing { background: rgba(76,175,80,0.15); color: #4caf50; }
.tix-co-ty-status-on-hold    { background: rgba(255,152,0,0.15); color: #ff9800; }
.tix-co-ty-status-pending     { background: rgba(158,158,158,0.15); color: #9e9e9e; }
.tix-co-ty-status-failed,
.tix-co-ty-status-cancelled   { background: rgba(239,83,80,0.15); color: #ef5350; }

/* Zurück-Button */
/* Kombi-Gruppe */
.tix-co-combo-group {
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    overflow: hidden;
}
.tix-co-combo-header {
    border: none !important;
    border-radius: 0 !important;
}

/* Multi-Event-Warnung */
.tix-co-multi-event-notice {
    margin-top: 8px;
    padding: 10px 14px;
    border-radius: 6px;
    background: rgba(255, 152, 0, 0.1);
    border: 1px solid rgba(255, 152, 0, 0.3);
    font-size: var(--tix-small, 13px);
    display: flex;
    align-items: center;
    gap: 8px;
}
.tix-co-multi-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
}

/* MwSt.-Hinweis Danke-Seite */
.tix-co-ty-vat {
    font-size: 0.78em;
    font-weight: 400;
    opacity: 0.6;
    white-space: nowrap;
}

/* Zahlungshinweis + Bankdaten */
.tix-co-ty-payment-notice {
    border: 1px solid var(--tix-co-border, #e5e7eb);
    border-radius: 8px;
    padding: 16px 20px;
}
.tix-co-ty-payment-notice .tix-co-ty-tickets-note {
    margin: 0 0 12px;
}
.tix-co-ty-payment-instructions {
    font-size: var(--tix-small, 13px);
    opacity: 0.8;
    margin: 0 0 12px;
}
.tix-co-ty-payment-instructions p { margin: 0 0 6px; }
.tix-co-ty-bank-details {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--tix-co-border, #e5e7eb);
}
.tix-co-ty-bank-heading {
    font-size: var(--tix-body, 15px);
    font-weight: 700;
    margin: 0 0 10px;
}
.tix-co-ty-bank-account + .tix-co-ty-bank-account {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px dashed var(--tix-co-border, #e5e7eb);
}
.tix-co-ty-bank-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: var(--tix-small, 13px);
}
.tix-co-ty-bank-label {
    opacity: 0.6;
    min-width: 120px;
}
.tix-co-ty-bank-value {
    font-weight: 600;
    text-align: right;
    font-family: monospace, monospace;
    letter-spacing: 0.02em;
}
.tix-co-ty-bank-ref {
    margin: 12px 0 0;
    font-size: var(--tix-small, 13px);
    padding-top: 10px;
    border-top: 1px solid var(--tix-co-border, #e5e7eb);
}

.tix-co-ty-back {
    text-align: center; margin-top: 24px; padding-bottom: 8px;
}

/* Hook-Output (Payment-Gateways etc.) */
.tix-co-ty-hook-output { font-size: var(--tix-small, 13px); }
.tix-co-ty-hook-output table { width: 100%; border-collapse: collapse; }
.tix-co-ty-hook-output td, .tix-co-ty-hook-output th {
    padding: 6px 10px; text-align: left;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.tix-co-ty-hook-output a {
    color: var(--tix-buy-bg, #c8ff00) !important;
    font-weight: 600;
}

/* ══════════════════════════════════════
   3-STEP CHECKOUT
   ══════════════════════════════════════ */

/* Step-Panels: im Normal-Modus alle sichtbar */
.tix-co-step-panel { display: block; }

/* Im Step-Modus: nur aktives Panel sichtbar */
.tix-co-stepped .tix-co-step-panel { display: none; }
.tix-co-stepped .tix-co-step-visible { display: block; }

/* Stepper-Leiste */
.tix-co-stepper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0;
    margin-bottom: 28px;
    padding: 0;
}

.tix-co-step-ind {
    display: flex; align-items: center; gap: 8px;
    opacity: 0.35; transition: opacity 0.3s;
    cursor: default;
}
.tix-co-step-ind.tix-co-step-active { opacity: 1; }
.tix-co-step-ind.tix-co-step-done { opacity: 0.65; cursor: pointer; }

.tix-co-step-num {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 2px solid currentColor;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: var(--tix-small, 13px);
    flex-shrink: 0;
}
.tix-co-step-ind.tix-co-step-active .tix-co-step-num {
    background: var(--tix-buy-bg, #c8ff00); color: var(--tix-buy-color, #000); border-color: var(--tix-buy-bg, #c8ff00);
}
.tix-co-step-ind.tix-co-step-done .tix-co-step-num {
    background: transparent; border-color: var(--tix-buy-bg, #c8ff00); color: var(--tix-buy-bg, #c8ff00);
}

.tix-co-step-label { font-size: var(--tix-small, 13px); font-weight: 600; white-space: nowrap; }

.tix-co-step-line {
    flex: 1; height: 1px;
    background: currentColor; opacity: 0.15;
    margin: 0 12px; min-width: 20px;
}

/* Navigation Buttons */
.tix-co-step-nav {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 8px; padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.tix-co-step-btn {
    padding: 10px 20px; border: var(--tix-btn1-border, none); border-radius: var(--tix-btn1-radius, 8px);
    font-weight: 700; font-size: var(--tix-btn1-font-size, 0.9rem); cursor: pointer;
    font-family: var(--tix-font-body, inherit); transition: background 0.2s, opacity 0.2s;
}
.tix-co-step-next {
    background: var(--tix-btn1-bg, #c8ff00); color: var(--tix-btn1-color, #000);
}
.tix-co-step-next:hover { background: var(--tix-btn1-hover-bg, var(--tix-btn1-bg)); color: var(--tix-btn1-hover-color, var(--tix-btn1-color, #000)); opacity: 0.9; }
.tix-co-step-back {
    background: transparent; color: inherit; opacity: 0.6;
    border: 1px solid var(--tix-border, #333);
}
.tix-co-step-back:hover { opacity: 1; }

/* Mini-Zusammenfassung: im Normal-Modus immer unsichtbar */
.tix-co-summary-mini { display: none; }
.tix-co-stepped .tix-co-summary-mini { display: block; border-top: none; padding-top: 0; }

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */
@media (max-width: 480px) {
    .tix-co-field-half,
    .tix-co-field-third,
    .tix-co-field-twothirds { width: 100%; }

    .tix-co-item { flex-wrap: wrap; position: relative; padding-right: 28px; }
    .tix-co-item-info { width: 100%; }
    .tix-co-item-price { order: 3; margin-left: auto; }
    .tix-co-item-qty { order: 4; }
    .tix-co-item-remove { position: absolute; top: 10px; right: 4px; }

    .tix-co-step-label { display: none; }
    .tix-co-step-btn { font-size: 0.82rem; padding: 8px 14px; }

    .tix-co-ty-ticket { flex-direction: column; align-items: flex-start; }
    .tix-co-ty-detail { flex-direction: column; gap: 2px; }
    .tix-co-ty-detail-label { min-width: auto; }
}

/* ══════════════════════════════════════
   CHECKOUT COUNTDOWN
   ══════════════════════════════════════ */
.tix-co-countdown {
    margin-bottom: 24px;
    border-radius: var(--tix-radius, 8px);
    overflow: hidden;
    border: 1px solid var(--tix-border, #333);
    background: var(--tix-cat-bg, transparent);
}

.tix-co-countdown-track {
    height: 4px;
    background: rgba(255,255,255,0.08);
    position: relative;
    overflow: hidden;
}

.tix-co-countdown-bar {
    height: 100%;
    width: 100%;
    background: var(--tix-buy-bg, #c8ff00);
    transform-origin: left;
    transition: transform 1s linear;
    will-change: transform;
}

.tix-co-countdown-bar.tix-co-countdown-warn {
    background: #ff9800;
}

.tix-co-countdown-bar.tix-co-countdown-crit {
    background: var(--tix-sale-color, #ef5350);
}

.tix-co-countdown-label {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: var(--tix-small, 13px);
    font-weight: 600;
    opacity: 0.85;
}

.tix-co-countdown-time {
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    letter-spacing: 0.03em;
    font-size: var(--tix-body, 15px);
}

.tix-co-countdown-expired {
    text-align: center;
    padding: 20px;
    font-weight: 700;
    color: var(--tix-sale-color, #ef5350);
}

/* ── Charity Banner (Thank-You) ── */
.tix-co-ty-charity {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    margin-top: 16px;
    background: rgba(236, 72, 153, 0.06);
    border: 1px solid rgba(236, 72, 153, 0.2);
    border-radius: var(--tix-radius, 8px);
}
.tix-co-ty-charity-img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid rgba(236, 72, 153, 0.15);
}
.tix-co-ty-charity-info {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
.tix-co-ty-charity-badge {
    font-size: var(--tix-body, 15px);
    font-weight: 600;
    color: #be185d;
}
.tix-co-ty-charity-desc {
    font-size: var(--tix-small, 13px);
    opacity: 0.7;
}

/* ══════════════════════════════════════
   KARTEN-LAYOUT – DANKE-SEITE
   ══════════════════════════════════════ */
.tix-co-thankyou .tix-co-section {
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    padding: 20px;
}

.tix-co-thankyou .tix-co-heading {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 14px;
}

.tix-co-thankyou .tix-co-summary {
    border-top-color: var(--tix-border, #333);
}

.tix-co-thankyou .tix-co-ty-banner {
    margin-bottom: 20px;
}

/* Bankdaten innerhalb der Ticket-Karte */
.tix-co-thankyou .tix-co-ty-payment-notice {
    border: none;
    border-radius: 0;
    padding: 14px 0 0;
    margin-top: 14px;
    border-top: 1px solid var(--tix-border, #333);
}

/* ══════════════════════════════════════
   Specials Upsell im Checkout
   ══════════════════════════════════════ */

/* ══════════════════════════════════════
   SPECIALS UPSELL
   ══════════════════════════════════════ */
.tix-co-specials {
    margin-bottom: 32px;
}

.tix-co-specials-heading {
    font-size: var(--tix-h4, 16px);
    font-weight: 700;
    margin: 0 0 16px 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--tix-border, #333);
}

.tix-co-specials-grid {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.tix-co-special-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    font-size: var(--tix-body, 15px);
    transition: border-color 0.2s;
}

.tix-co-special-image {
    width: 48px;
    height: 48px;
    border-radius: var(--tix-radius, 8px);
    overflow: hidden;
    flex-shrink: 0;
}

.tix-co-special-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tix-co-special-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.tix-co-special-info strong {
    font-weight: 700;
    font-size: var(--tix-font-name, 1rem);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.tix-co-special-desc {
    font-size: 0.75rem;
    opacity: 0.55;
    font-weight: 400;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tix-co-special-savings {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--tix-success-color, #4caf50);
}

.tix-co-special-action {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    flex-shrink: 0;
}

.tix-co-special-price {
    font-weight: 700;
    font-size: var(--tix-font-price, 1.1rem);
    white-space: nowrap;
}

.tix-co-special-add {
    padding: 6px 16px;
    border-radius: var(--tix-buy-radius, 8px);
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    border: none;
    cursor: pointer;
    font-weight: 700;
    font-size: var(--tix-small, 13px);
    white-space: nowrap;
    transition: opacity 0.15s;
}

.tix-co-special-add:hover {
    opacity: 0.85;
}

.tix-co-special-add:disabled {
    opacity: 0.5;
    cursor: default;
}

.tix-co-special-in-cart-badge {
    display: inline-block;
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    color: var(--tix-success-color, #4caf50);
    margin-top: 2px;
}

.tix-co-special-card.tix-co-special-in-cart {
    border-color: var(--tix-buy-bg, #c8ff00);
}

.tix-co-special-card.tix-co-special-soldout {
    opacity: 0.4;
    pointer-events: none;
}

.tix-co-special-soldout-label {
    font-size: var(--tix-small, 13px);
    font-weight: 600;
    opacity: 0.5;
}

/* ══════════════════════════════════════
   TISCHRESERVIERUNG (Checkout)
   ══════════════════════════════════════ */
.tix-co-tables {
    margin-bottom: 32px;
}

.tix-co-tables-heading {
    font-size: var(--tix-h4, 16px);
    font-weight: 700;
    margin: 0 0 16px 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--tix-border, #333);
}

.tix-co-tables-info {
    font-size: var(--tix-label, 12px);
    opacity: 0.6;
    margin: 0 0 12px;
    line-height: 1.5;
}

.tix-co-tables-grid {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.tix-co-table-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--tix-border, #333);
    border-radius: var(--tix-radius, 8px);
    background: var(--tix-cat-bg, transparent);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}

.tix-co-table-card:hover:not(.tix-co-table-soldout) {
    border-color: var(--tix-input-focus, #c8ff00);
}

.tix-co-table-card.tix-co-table-active {
    border-color: var(--tix-buy-bg, #c8ff00);
    background: rgba(200, 255, 0, 0.04);
}

.tix-co-table-card.tix-co-table-soldout {
    opacity: 0.4;
    pointer-events: none;
}

/* Radio-Dot (identisch zu Payment Gateways) */
.tix-co-table-radio-wrap {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}

.tix-co-table-radio {
    display: none;
}

.tix-co-table-radio-dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--tix-input-border, #555);
    position: relative;
    transition: border-color 0.2s;
}

.tix-co-table-radio:checked + .tix-co-table-radio-dot {
    border-color: var(--tix-input-focus, #c8ff00);
}

.tix-co-table-radio:checked + .tix-co-table-radio-dot::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--tix-input-focus, #c8ff00);
    transform: translate(-50%, -50%);
}

.tix-co-table-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.tix-co-table-info strong {
    font-weight: 700;
    font-size: var(--tix-font-name, 1rem);
}

.tix-co-table-desc {
    font-size: 0.75rem;
    opacity: 0.55;
    font-weight: 400;
}

.tix-co-table-meta {
    font-size: 0.75rem;
    opacity: 0.55;
    font-weight: 400;
}

.tix-co-table-action {
    flex-shrink: 0;
    text-align: right;
}

.tix-co-table-avail {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--tix-success-color, #4caf50);
}

.tix-co-table-soldout-label {
    font-size: var(--tix-small, 13px);
    font-weight: 600;
    opacity: 0.5;
}

/* Form (Gäste + Kommentar) */
.tix-co-table-form {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--tix-border, #333);
}

.tix-co-table-form-row {
    margin-bottom: 12px;
}

.tix-co-table-form-label {
    display: block;
    font-size: var(--tix-small, 13px);
    font-weight: 600;
    opacity: 0.7;
    margin-bottom: 6px;
}

.tix-co-table-stepper {
    display: flex;
    align-items: center;
    gap: 6px;
}

.tix-co-table-step-btn {
    width: var(--tix-btn-size, 32px);
    height: var(--tix-btn-size, 32px);
    border-radius: var(--tix-btn-radius, 50%);
    border: 1px solid currentColor;
    background: transparent;
    color: inherit;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    padding: 0;
    flex-shrink: 0;
}

.tix-co-table-step-btn:hover {
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    border-color: var(--tix-buy-bg, #c8ff00);
}

.tix-co-table-guest-val {
    min-width: 24px;
    text-align: center;
    font-weight: 700;
    font-size: var(--tix-body, 15px);
    font-variant-numeric: tabular-nums;
}

/* Status Messages */
.tix-co-table-status {
    font-size: var(--tix-small, 13px);
    padding: 10px 14px;
    border-radius: var(--tix-radius, 8px);
    margin-top: 10px;
}

.tix-co-table-status-ok {
    background: rgba(76, 175, 80, 0.1);
    color: var(--tix-success-color, #4caf50);
}

.tix-co-table-status-err {
    background: rgba(239, 83, 80, 0.1);
    color: var(--tix-sale-color, #ef5350);
}
