/*
 * Tixomat Ticket Selector
 * Alle Farben/Größen über CSS-Variablen steuerbar.
 */

/* ── Wrapper ── */
.tix-sel {
    max-width: var(--tix-sel-max-width, none);
    color: var(--tix-text, inherit);
    font-family: var(--tix-font-body, 'DM Sans'), sans-serif;
    font-size: var(--tix-body, 15px);
}

/* ── Categories ── */
.tix-sel-categories {
    display: flex;
    flex-direction: column;
    gap: var(--tix-gap, 10px);
}

/* ── Group Headers ── */
.tix-sel-group-header {
    font-size: var(--tix-small, 13px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--tix-text, #475569);
    padding: 12px 0 4px;
    opacity: 0.7;
}
.tix-sel-group-header:first-child { padding-top: 0; }

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

.tix-sel-cat.tix-sel-active {
    border-color: var(--tix-sel-active-border, var(--tix-cat-active-border, currentColor));
    background: var(--tix-sel-active-bg, var(--tix-cat-active-bg, rgba(255,255,255,0.05)));
}

.tix-sel-cat.tix-sel-soldout {
    opacity: 0.4;
    pointer-events: none;
}
.tix-sel-cat.tix-sel-offline {
    opacity: 0.75;
}

/* Info */
.tix-sel-cat-info {
    flex: 1;
    min-width: 0;
}

.tix-sel-cat-name {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    font-weight: 700;
    font-size: var(--tix-font-name, 1rem);
}

.tix-sel-cat-desc {
    font-size: var(--tix-font-desc, 0.85rem);
    opacity: 0.7;
    margin-top: 2px;
}

/* Price */
.tix-sel-cat-price {
    font-weight: 700;
    font-size: var(--tix-font-price, 1rem);
    white-space: nowrap;
    text-align: right;
    flex-shrink: 0;
    min-width: 80px;
}

.tix-sel-price-regular {
    /* normal price, no sale */
}

.tix-sel-price-sale {
    display: block;
    color: var(--tix-sale-color, #ef5350);
    font-size: var(--tix-font-price, 1rem);
}

.tix-sel-price-old {
    display: block;
    text-decoration: line-through;
    opacity: 0.45;
    font-size: 0.75em;
    font-weight: 400;
    line-height: 1.2;
}

.tix-sel-vat {
    display: block;
    font-size: 0.65em;
    font-weight: 400;
    opacity: 0.4;
    line-height: 1.2;
}

.tix-sel-presale-ended {
    text-align: center;
    padding: 20px;
    opacity: 0.6;
    font-size: var(--tix-body, 15px);
}

/* Quantity */
.tix-sel-cat-qty {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.tix-sel-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: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    padding: 0;
}

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

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

.tix-sel-bundle-tickets {
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    opacity: 0.5;
    white-space: nowrap;
}

.tix-sel-soldout-label {
    font-size: var(--tix-btn, 14px);
    opacity: 0.5;
}

.tix-sel-offline-label {
    font-size: var(--tix-small, 13px);
    font-weight: 600;
    opacity: 0.65;
    white-space: nowrap;
    letter-spacing: 0.02em;
}

/* ── Footer ── */
.tix-sel-footer {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.tix-sel-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding-top: 14px;
    border-top: var(--tix-sel-border-width, 1px) solid var(--tix-cat-border, #333);
}

.tix-sel-total-label {
    font-size: var(--tix-body, 15px);
    opacity: 0.8;
}

.tix-sel-vat-note {
    font-size: 0.75em;
    opacity: 0.6;
    font-weight: 400;
}

.tix-sel-total-price {
    font-weight: 700;
    font-size: var(--tix-font-total, 1.3rem);
    font-variant-numeric: tabular-nums;
}

/* Buy Button */
.tix-sel-buy {
    width: 100%;
    padding: 14px;
    border: var(--tix-btn1-border, none);
    border-radius: var(--tix-btn1-radius, 8px);
    background: var(--tix-btn1-bg, #c8ff00);
    color: var(--tix-btn1-color, #000);
    font-weight: 700;
    font-size: var(--tix-btn1-font-size, 1rem);
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
}

.tix-sel-buy:hover:not(:disabled) {
    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-sel-buy:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Express Checkout Button */
.tix-sel-express {
    width: 100%;
    padding: 12px 16px;
    margin-top: 8px;
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    border: none;
    border-radius: var(--tix-buy-radius, 8px);
    font-weight: 600;
    font-size: var(--tix-body, 15px);
    cursor: pointer;
    transition: opacity 0.15s;
}

.tix-sel-express:hover:not(:disabled) {
    opacity: 0.9;
}

.tix-sel-express:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Express Checkout Wrap + Terms */
.tix-sel-express-wrap {
    margin-top: 14px;
    padding-top: 14px;
    border-top: var(--tix-sel-border-width, 1px) solid var(--tix-cat-border, #333);
}

.tix-sel-express-terms {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: var(--tix-small, 13px);
    cursor: pointer;
    line-height: 1.4;
    margin-bottom: 10px;
}

.tix-sel-express-terms a {
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.tix-sel-express-terms-check {
    display: none;
}

.tix-sel-express-terms-custom {
    width: 18px;
    height: 18px;
    min-width: 18px;
    border: 2px solid var(--tix-cat-border, #555);
    border-radius: 4px;
    position: relative;
    transition: border-color 0.2s, background 0.2s;
    margin-top: 1px;
}

.tix-sel-express-terms-check:checked + .tix-sel-express-terms-custom {
    border-color: var(--tix-buy-bg, #c8ff00);
    background: var(--tix-buy-bg, #c8ff00);
}

.tix-sel-express-terms-check:checked + .tix-sel-express-terms-custom::after {
    content: '';
    position: absolute;
    top: 1px;
    left: 5px;
    width: 5px;
    height: 9px;
    border: solid var(--tix-buy-color, #000);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.tix-sel-express-note {
    display: block;
    font-size: var(--tix-label, 12px);
    opacity: 0.45;
    text-align: center;
    margin-top: 6px;
}

/* Message */
.tix-sel-message {
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    font-size: var(--tix-btn, 14px);
    text-align: center;
}

.tix-sel-msg-success {
    background: rgba(46, 125, 50, 0.15);
    color: #4caf50;
}

.tix-sel-msg-error {
    background: rgba(211, 47, 47, 0.15);
    color: #ef5350;
}

/* ── Coupon in Selector ── */
.tix-sel-coupon {
    margin-top: 14px;
    padding-top: 14px;
    border-top: var(--tix-sel-border-width, 1px) solid var(--tix-cat-border, #333);
}
.tix-sel-coupon-input-wrap {
    display: flex;
    gap: 8px;
}
.tix-sel-coupon-code {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid var(--tix-cat-border, #333);
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    background: transparent;
    color: inherit;
    font-size: var(--tix-btn, 14px);
}
.tix-sel-coupon-code::placeholder { opacity: 0.4; }
.tix-sel-coupon-btn {
    padding: 8px 16px;
    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);
    font-size: var(--tix-btn2-font-size, 0.85rem);
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
}
.tix-sel-coupon-btn:hover {
    background: var(--tix-btn2-hover-bg, transparent);
    color: var(--tix-btn2-hover-color, inherit);
}
.tix-sel-coupon-result {
    margin-top: 8px;
    font-size: var(--tix-btn, 14px);
    display: flex;
    align-items: center;
    gap: 8px;
}
.tix-sel-coupon-ok { color: #4caf50; font-weight: 600; }
.tix-sel-coupon-err { color: #ef5350; }
.tix-sel-coupon-remove {
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
    font-size: var(--tix-btn, 14px);
    opacity: 0.5;
    padding: 2px 6px;
}
.tix-sel-coupon-remove:hover { opacity: 1; }

/* Durchgestrichener Original-Preis bei Coupon */
.tix-sel-total-original {
    text-decoration: line-through;
    opacity: 0.4;
    font-size: 0.85em;
    font-weight: 400;
    margin-right: 6px;
}

/* ── Countdown ── */
.tix-countdown {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.tix-countdown-label {
    font-size: var(--tix-btn, 14px);
    opacity: 0.7;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.tix-countdown-units {
    display: flex;
    align-items: center;
    gap: 6px;
}
.tix-countdown-unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 50px;
}
.tix-countdown-num {
    font-size: var(--tix-h1, 28px);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
}
.tix-countdown-lbl {
    font-size: var(--tix-label, 12px);
    opacity: 0.5;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.tix-countdown-sep {
    font-size: 1.5rem;
    font-weight: 700;
    opacity: 0.3;
    margin-top: -14px;
}
.tix-countdown-ended { opacity: 0.3; }

/* ── Responsive ── */
@media (max-width: 767px) {
    .tix-sel-cat {
        flex-wrap: wrap;
    }
    .tix-sel-cat-info {
        width: 100%;
        flex: none;
    }
    .tix-sel-cat-price {
        order: 3;
        text-align: left;
        min-width: 0;
    }
    .tix-sel-cat-qty {
        order: 4;
        margin-left: auto;
    }
    .tix-countdown-num { font-size: 1.4rem; }
    .tix-countdown-unit { min-width: 38px; }
}

/* ── Phase Badge ── */
.tix-sel-phase-badge {
    display: inline-flex;
    align-items: center;
    font-size: var(--tix-label, 12px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 2px 8px;
    border-radius: 3px;
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    line-height: 1.3;
}

/* ── Phasen-Timeline ── */
.tix-sel-phases-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 8px;
    padding: 8px 0 4px;
    border-top: 1px dashed color-mix(in srgb, currentColor 15%, transparent);
    font-size: var(--tix-label, 12px);
}
.tix-sel-phase-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 3px 0;
    position: relative;
    opacity: 0.5;
    transition: opacity 0.2s;
}
.tix-sel-phase-item.tix-sel-phase--active {
    opacity: 1;
    font-weight: 700;
}
.tix-sel-phase-item.tix-sel-phase--past {
    opacity: 0.35;
    text-decoration: line-through;
}
.tix-sel-phase-dot {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: color-mix(in srgb, currentColor 25%, transparent);
    border: 2px solid color-mix(in srgb, currentColor 20%, transparent);
}
.tix-sel-phase--active .tix-sel-phase-dot {
    background: var(--tix-buy-bg, #c8ff00);
    border-color: var(--tix-buy-bg, #c8ff00);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--tix-buy-bg, #c8ff00) 30%, transparent);
}
.tix-sel-phase--past .tix-sel-phase-dot {
    background: color-mix(in srgb, currentColor 15%, transparent);
    border-color: color-mix(in srgb, currentColor 10%, transparent);
}
.tix-sel-phase-name {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.tix-sel-phase-price {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.tix-sel-phase--active .tix-sel-phase-price {
    color: var(--tix-sale-color, #ef5350);
}
.tix-sel-phase--regular.tix-sel-phase--active .tix-sel-phase-price {
    color: inherit;
}
.tix-sel-phase-until {
    color: color-mix(in srgb, currentColor 50%, transparent);
    font-size: var(--tix-label, 12px);
    white-space: nowrap;
    margin-left: auto;
}
/* Vertikale Verbindungslinie */
.tix-sel-phase-item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 3px;
    top: 14px;
    width: 2px;
    height: calc(100% - 2px);
    background: color-mix(in srgb, currentColor 12%, transparent);
}
.tix-sel-phase--active:not(:last-child)::before {
    background: color-mix(in srgb, var(--tix-buy-bg, #c8ff00) 40%, transparent);
}

/* ── Mengenrabatt ── */
.tix-sel-group-discount {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    margin-top: 14px;
    border: 1px dashed color-mix(in srgb, currentColor 25%, transparent);
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    font-size: var(--tix-btn, 14px);
    opacity: 0.7;
    transition: opacity 0.3s, border-color 0.3s, background 0.3s;
}
.tix-sel-group-discount.tix-sel-gd-active {
    opacity: 1;
    border-color: var(--tix-sale-color, #ef5350);
    border-style: solid;
    background: rgba(239, 83, 80, 0.06);
}
.tix-sel-gd-icon { font-size: 1.2rem; flex-shrink: 0; }
.tix-sel-gd-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.tix-sel-gd-title { font-weight: 700; font-size: var(--tix-btn, 14px); }
.tix-sel-gd-tiers { display: flex; flex-wrap: wrap; gap: 4px 12px; }
.tix-sel-gd-tier { white-space: nowrap; }
.tix-sel-gd-badge {
    padding: 4px 10px;
    border-radius: 20px;
    background: var(--tix-sale-color, #ef5350);
    color: #fff;
    font-weight: 700;
    font-size: var(--tix-small, 13px);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ── Kombi-Tickets ── */
.tix-sel-combos {
    display: flex;
    flex-direction: column;
    gap: var(--tix-gap, 10px);
    margin-top: var(--tix-gap, 10px);
    padding-top: var(--tix-gap, 10px);
    border-top: 1px dashed color-mix(in srgb, currentColor 25%, transparent);
}
.tix-sel-combo .tix-sel-combo-icon {
    margin-right: 4px;
}
.tix-sel-combo-events {
    line-height: 1.6;
}
/* ── Spar-Badge (Bundle + Kombi) ── */
.tix-sel-bundle-save {
    display: inline-flex;
    align-items: center;
    font-size: var(--tix-label, 12px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 2px 8px;
    border-radius: 3px;
    background: var(--tix-save-bg, var(--tix-sale-color, #ef5350));
    color: var(--tix-save-text, #fff);
    line-height: 1.3;
}

/* ── Bundle Deal ── */
.tix-sel-bundle-badge {
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    color: var(--tix-sale-color, #ef5350);
    margin-top: 2px;
}
.tix-sel-bundle-active {
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    margin-top: 4px;
    padding: 3px 8px;
    border-radius: 4px;
    animation: ehBundleFade 0.3s ease;
}
.tix-sel-bundle-hint {
    color: var(--tix-sale-color, #ef5350);
    opacity: 0.7;
}
.tix-sel-bundle-applied {
    color: var(--tix-success-color, #4caf50);
    background: rgba(76, 175, 80, 0.1);
}
@keyframes ehBundleFade {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Gemeinsam buchen (Group Booking) ── */
.tix-group-trigger {
    margin-top: 10px;
    text-align: center;
}
.tix-group-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 0;
    border: none;
    background: transparent;
    color: inherit;
    font-weight: 600;
    font-size: var(--tix-small, 13px);
    opacity: 0.45;
    cursor: pointer;
    transition: opacity 0.2s;
}
.tix-group-btn:hover {
    opacity: 0.8;
}

/* Panel */
.tix-group-panel {
    margin-top: 16px;
}

/* Create Form */
.tix-group-create-title {
    font-weight: 700;
    font-size: var(--tix-body, 15px);
}
.tix-group-create-desc {
    font-size: var(--tix-btn, 14px);
    opacity: 0.6;
    margin: 0;
}
.tix-group-create-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.tix-group-create {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.tix-group-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}
.tix-group-header-icon { font-size: 1.2rem; }
.tix-group-header-title { font-weight: 700; font-size: var(--tix-body, 15px); }
.tix-group-join {
    margin-bottom: 12px;
}
.tix-group-join-label {
    display: block;
    font-size: var(--tix-small, 13px);
    opacity: 0.6;
    margin-bottom: 4px;
}
.tix-group-copy-msg {
    font-size: var(--tix-label, 12px);
    opacity: 0.6;
    margin-top: 4px;
}
.tix-group-input-error {
    border-color: var(--tix-sale-color, #ef5350) !important;
}
.tix-group-name-input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--tix-cat-border, #333);
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    background: transparent;
    color: inherit;
    font-size: var(--tix-btn, 14px);
    box-sizing: border-box;
}
.tix-group-name-input::placeholder { opacity: 0.4; }
.tix-group-create-btn {
    width: 100%;
    padding: 12px;
    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-body, 15px);
    cursor: pointer;
    transition: opacity 0.2s;
}
.tix-group-create-btn:hover { opacity: 0.85; }

/* Share Link */
.tix-group-share {
    margin-bottom: 14px;
}
.tix-group-share-label {
    font-size: var(--tix-small, 13px);
    opacity: 0.6;
    margin-bottom: 6px;
}
.tix-group-share-row {
    display: flex;
    gap: 8px;
    align-items: stretch;
}
.tix-group-share-url {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid var(--tix-cat-border, #333);
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    background: transparent;
    color: inherit;
    font-size: var(--tix-small, 13px);
    box-sizing: border-box;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.tix-group-copy-btn {
    padding: 8px 14px;
    border: 1px solid var(--tix-buy-bg, #c8ff00);
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    background: transparent;
    color: var(--tix-buy-bg, #c8ff00);
    font-size: var(--tix-btn, 14px);
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
}
.tix-group-copy-btn:hover {
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
}

/* Member-Input (Freund-Modus) */
.tix-group-member-input-wrap {
    margin-bottom: 14px;
}
.tix-group-member-input-wrap label {
    display: block;
    font-size: var(--tix-small, 13px);
    opacity: 0.6;
    margin-bottom: 4px;
}

/* Overview */
.tix-group-overview-title {
    font-size: var(--tix-body, 15px);
    font-weight: 700;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Members */
.tix-group-members {
    display: flex;
    flex-direction: column;
}
.tix-group-member {
    padding: 12px 0;
    border-bottom: 1px solid var(--tix-cat-border, #333);
}
.tix-group-member:last-child { border-bottom: none; }
.tix-group-member-self {
    background: rgba(255,255,255,0.03);
    margin: 0 -6px;
    padding-left: 6px;
    padding-right: 6px;
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
}
.tix-group-member-header {
    display: flex;
    align-items: center;
    gap: 8px;
}
.tix-group-member-name {
    flex: 1;
    font-weight: 600;
    font-size: var(--tix-body, 15px);
}
.tix-group-member-you {
    font-weight: 400;
    font-size: var(--tix-small, 13px);
    opacity: 0.5;
}
.tix-group-member-org {
    font-weight: 400;
    font-size: var(--tix-label, 12px);
    padding: 1px 6px;
    border-radius: 3px;
    background: var(--tix-buy-bg, #c8ff00);
    color: var(--tix-buy-color, #000);
    margin-left: 4px;
}
.tix-group-member-subtotal {
    font-weight: 700;
    font-size: var(--tix-body, 15px);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.tix-group-member-remove {
    background: none;
    border: none;
    color: inherit;
    cursor: pointer;
    font-size: var(--tix-small, 13px);
    opacity: 0.4;
    padding: 4px 6px;
    transition: opacity 0.15s;
}
.tix-group-member-remove:hover { opacity: 1; }
.tix-group-member-items {
    font-size: var(--tix-small, 13px);
    opacity: 0.6;
    margin-top: 3px;
}
.tix-group-member-pending {
    font-style: italic;
    opacity: 0.35;
}

/* Summary */
.tix-group-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid var(--tix-cat-border, #333);
}
.tix-group-summary-count {
    font-size: var(--tix-btn, 14px);
    opacity: 0.7;
}
.tix-group-summary-total {
    font-weight: 700;
    font-size: var(--tix-h3, 1.1rem);
    font-variant-numeric: tabular-nums;
}

/* Checkout Button */
.tix-group-checkout-btn {
    width: 100%;
    padding: 14px;
    margin-top: 14px;
    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-body, 15px);
    cursor: pointer;
    transition: opacity 0.2s;
}
.tix-group-checkout-btn:hover { opacity: 0.85; }

/* Wait message (non-organizer) */
.tix-group-wait {
    text-align: center;
    padding: 14px;
    font-size: var(--tix-btn, 14px);
    opacity: 0.5;
    font-style: italic;
}

/* Message */
.tix-group-message {
    margin-top: 10px;
    padding: 10px 14px;
    border-radius: var(--tix-sel-radius, var(--tix-radius, 8px));
    font-size: var(--tix-btn, 14px);
    text-align: center;
}
.tix-group-msg-success {
    background: rgba(46, 125, 50, 0.15);
    color: #4caf50;
}
.tix-group-msg-error {
    background: rgba(211, 47, 47, 0.15);
    color: #ef5350;
}

/* ── Cost Split (Thank-You Page) ── */
.tix-co-cost-split {
    margin-top: 6px;
    padding: 16px;
    border: 1px solid var(--tix-co-border, #e5e7eb);
    border-radius: var(--tix-co-radius, 8px);
    background: var(--tix-co-card-bg, #fff);
}
.tix-co-cost-split-title {
    font-size: var(--tix-body, 15px);
    font-weight: 700;
    margin: 0 0 12px;
}
.tix-co-cost-split-list {
    display: flex;
    flex-direction: column;
}
.tix-co-cost-split-member {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--tix-co-border, #e5e7eb);
}
.tix-co-cost-split-member:last-child { border-bottom: none; }
.tix-co-cost-split-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.tix-co-cost-split-name {
    font-weight: 600;
    font-size: var(--tix-body, 15px);
}
.tix-co-cost-split-items {
    font-size: var(--tix-small, 13px);
    opacity: 0.6;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.tix-co-cost-split-amount {
    font-weight: 700;
    font-size: var(--tix-body, 15px);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

/* ── Group member headers in checkout cart ── */
.tix-co-group-header {
    padding: 10px 16px 4px;
    font-weight: 700;
    font-size: var(--tix-btn, 14px);
    opacity: 0.6;
    border-top: 1px dashed var(--tix-co-border, #e5e7eb);
    margin-top: 4px;
}
.tix-co-group-header:first-child {
    border-top: none;
    margin-top: 0;
}

/* ── Sponsor (Thank-You) ── */
.tix-co-sponsor-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 24px;
    border: 1px solid var(--tix-border, #e2e8f0);
    border-radius: var(--tix-radius, 12px);
    text-align: center;
}
.tix-co-sponsor-logo {
    max-height: 60px;
    max-width: 200px;
    object-fit: contain;
}
.tix-co-sponsor-text {
    font-size: var(--tix-body, 15px);
    margin: 0;
    opacity: 0.8;
}

/* ── Checkout Field Errors ── */
.tix-co-field-error .tix-co-input,
.tix-co-field-error .tix-co-select,
.tix-co-field-error .tix-co-textarea {
    border-color: #ef4444 !important;
    box-shadow: 0 0 0 2px rgba(239,68,68,.15);
}
.tix-co-field-error .tix-co-label {
    color: #dc2626;
}
.tix-co-legal.tix-co-field-error,
.tix-co-terms.tix-co-field-error {
    border: 1px solid #ef4444;
    border-radius: var(--tix-radius, 8px);
    padding: 12px;
    background: rgba(239,68,68,.04);
    animation: ehShake .4s ease;
}
.tix-co-legal.tix-co-field-error .tix-co-legal-heading {
    color: #dc2626;
}
@keyframes ehShake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-4px); }
    40%, 80% { transform: translateX(4px); }
}

/* ── Charity Banner ── */
.tix-sel-charity {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    margin-bottom: var(--tix-gap, 10px);
    background: rgba(236, 72, 153, 0.06);
    border: 1px solid rgba(236, 72, 153, 0.2);
    border-radius: var(--tix-radius, 8px);
}
.tix-sel-charity-img {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid rgba(236, 72, 153, 0.15);
}
.tix-sel-charity-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.tix-sel-charity-badge {
    font-size: var(--tix-btn, 14px);
    font-weight: 600;
    color: #be185d;
}
.tix-sel-charity-desc {
    font-size: var(--tix-small, 13px);
    color: var(--tix-text, inherit);
    opacity: 0.7;
}

/* ── Presale Countdown ── */
.tix-sel-presale-soon {
    text-align: center;
    padding: 24px 16px;
}
.tix-sel-presale-countdown {
    margin-bottom: 20px;
}
.tix-sel-presale-label {
    display: block;
    font-size: var(--tix-btn, 14px);
    color: var(--tix-text, inherit);
    opacity: .7;
    margin-bottom: 6px;
}
.tix-sel-presale-timer {
    display: block;
    font-size: var(--tix-h2, 1.3rem);
    font-weight: 700;
    color: var(--tix-text, inherit);
}

/* ── Notify / Waitlist Form ── */
.tix-sel-waitlist {
    padding: 16px 0;
    border-top: 1px solid var(--tix-cat-border, #333);
    margin-top: var(--tix-gap, 10px);
}
.tix-sel-notify-text {
    font-size: var(--tix-btn, 14px);
    color: var(--tix-text, inherit);
    opacity: .8;
    margin: 0 0 10px;
    text-align: center;
}
.tix-sel-notify-fields {
    display: flex;
    gap: 8px;
}
.tix-sel-notify-fields input[type="email"] {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid var(--tix-cat-border, #333);
    border-radius: var(--tix-radius, 8px);
    font-size: var(--tix-btn, 14px);
    font-family: var(--tix-font-body, inherit);
    background: transparent;
    color: inherit;
    outline: none;
    transition: border-color .2s;
}
.tix-sel-notify-fields input[type="email"]:focus {
    border-color: var(--tix-buy-bg, #c8ff00);
}
.tix-sel-notify-btn {
    padding: 10px 20px;
    background: var(--tix-btn1-bg, #c8ff00);
    color: var(--tix-btn1-color, #000);
    border: var(--tix-btn1-border, none);
    border-radius: var(--tix-btn1-radius, 8px);
    font-size: var(--tix-btn1-font-size, .92rem);
    font-weight: 700;
    cursor: pointer;
    font-family: var(--tix-font-body, inherit);
    white-space: nowrap;
    transition: opacity .2s;
}
.tix-sel-notify-btn:hover { opacity: .85; }
.tix-sel-notify-btn:disabled { opacity: .5; cursor: not-allowed; }
.tix-sel-notify-msg {
    margin-top: 10px;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: var(--tix-btn, 14px);
    text-align: center;
}
.tix-sel-notify-msg[hidden] { display: none; }
.tix-sel-notify-msg--error {
    background: rgba(239, 68, 68, .1);
    color: #ef4444;
}
.tix-sel-notify-success {
    font-size: var(--tix-btn, 14px);
    color: var(--tix-success, #4caf50);
    text-align: center;
    margin: 0;
    padding: 8px 0;
}

@media (max-width: 767px) {
    .tix-sel-notify-fields {
        flex-direction: column;
    }
}

/* ── Low Stock Badge ── */
.tix-sel-low-stock {
    display: inline-block;
    background: #fef2f2;
    color: #dc2626;
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    margin-top: 2px;
    animation: tix-pulse 2s ease-in-out infinite;
}
@keyframes tix-pulse {
    50% { opacity: .7; }
}

/* ══════════════════════════════════════
   EXTERNER TICKETSHOP
   ══════════════════════════════════════ */
.tix-sel-external {
    margin-top: 10px;
}

/* Default: Variante 1 (Primary) – wenn externer Shop allein steht */
.tix-sel-external-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px;
    border: var(--tix-btn1-border, none);
    border-radius: var(--tix-btn1-radius, 8px);
    background: var(--tix-btn1-bg, #c8ff00);
    color: var(--tix-btn1-color, #000) !important;
    font-weight: 700;
    font-size: var(--tix-btn1-font-size, 1rem);
    line-height: 1;
    text-decoration: none !important;
    transition: background 0.2s, color 0.2s, border-color 0.2s, opacity 0.2s;
    cursor: pointer;
    font-family: var(--tix-font-body, inherit);
    box-sizing: border-box;
}

.tix-sel-external-btn:hover {
    background: var(--tix-btn1-hover-bg, var(--tix-btn1-bg));
    color: var(--tix-btn1-hover-color, var(--tix-btn1-color, #000)) !important;
    opacity: 0.9;
}

/* Variante 2 (Secondary) – wenn zusätzlich zum internen Selector */
.tix-sel-external--v2 .tix-sel-external-btn {
    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-size: var(--tix-btn2-font-size, 0.9rem);
}

.tix-sel-external--v2 .tix-sel-external-btn: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;
}

.tix-sel-external-icon {
    font-size: 1em;
    line-height: 1;
}

/* ══════════════════════════════════════
   Specials Section
   ══════════════════════════════════════ */

/* ── Specials ── */
.tix-sel-specials-section {
    margin-top: var(--tix-gap, 10px);
}

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

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

.tix-sel-special-badge {
    font-size: 0.75em;
    font-weight: 600;
    color: var(--tix-success-color, #4caf50);
}

.tix-sel-special-value {
    text-decoration: line-through;
    opacity: 0.45;
    font-size: 0.75em;
    font-weight: 400;
    display: block;
    line-height: 1.2;
}
