/* ═══════════════════════════════════════════
   Tixomat – Gewinnspiel (Raffle)
   ═══════════════════════════════════════════ */

.tix-raffle {
    background: #fff;
    border: 1px solid var(--ep-border, #e5e7eb);
    border-radius: var(--ep-radius, 12px);
    overflow: hidden;
    font-family: var(--tix-font-body, inherit);
}

/* ── Header ── */
.tix-raffle-header {
    background: var(--tix-raffle-header-bg, var(--tix-primary, #FF5500));
    color: var(--tix-raffle-header-color, #fff) !important;
    padding: 24px 28px 20px;
}
.tix-raffle-title {
    font-size: var(--tix-h2, 22px);
    font-weight: 700;
    margin: 0 0 6px;
    color: var(--tix-raffle-header-color, #fff) !important;
    line-height: 1.3;
}
.tix-raffle-desc,
.tix-raffle-desc p {
    color: var(--tix-raffle-header-color, #fff) !important;
}
.tix-raffle-desc {
    font-size: var(--tix-btn, 14px);
    opacity: .9;
    line-height: 1.5;
}
.tix-raffle-desc p {
    margin: 0 0 6px;
}
.tix-raffle-desc p:last-child { margin-bottom: 0; }

/* ── Preise ── */
.tix-raffle-prizes {
    padding: 20px 28px;
    border-bottom: 1px solid var(--ep-border, #e5e7eb);
}
.tix-raffle-prizes-title {
    font-size: var(--tix-body, 15px);
    font-weight: 600;
    margin: 0 0 10px;
    color: var(--ep-heading, #0D0B09);
}
.tix-raffle-prizes-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.tix-raffle-prizes-list li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--tix-btn, 14px);
    padding: 8px 12px;
    background: #FAF8F4;
    border-radius: 8px;
}
.tix-raffle-prize-qty {
    font-weight: 700;
    color: var(--tix-primary, #FF5500);
    min-width: 28px;
}
.tix-raffle-prize-name {
    flex: 1;
    color: var(--ep-text, #334155);
}
.tix-raffle-prize-badge {
    font-size: var(--tix-label, 12px);
    font-weight: 600;
    background: #dbeafe;
    color: #1d4ed8;
    padding: 2px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: .03em;
}

/* ── Countdown ── */
.tix-raffle-countdown {
    padding: 14px 28px;
    background: #fefce8;
    border-bottom: 1px solid var(--ep-border, #e5e7eb);
    font-size: var(--tix-btn, 14px);
    color: #854d0e;
    text-align: center;
}
.tix-raffle-timer {
    font-weight: 700;
}

/* ── Formular ── */
.tix-raffle-form {
    padding: 24px 28px;
}
.tix-raffle-form-fields {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
}
.tix-raffle-form input[type="text"],
.tix-raffle-form input[type="email"] {
    flex: 1;
    padding: 12px 14px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: var(--tix-body, 15px);
    font-family: var(--tix-font-body, inherit);
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.tix-raffle-form input:focus {
    border-color: var(--tix-primary, #FF5500);
    box-shadow: 0 0 0 3px rgba(255,85,0,.12);
}

/* ── Zustimmungs-Checkbox ── */
.tix-raffle-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 14px;
    font-size: var(--tix-small, 13px);
    line-height: 1.4;
    color: var(--ep-text, #334155);
    cursor: pointer;
}
.tix-raffle-consent input[type="checkbox"] {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--tix-primary, #FF5500);
}
.tix-raffle-consent a {
    color: var(--tix-primary, #FF5500);
    text-decoration: underline;
}

.tix-raffle-submit {
    width: 100%;
    padding: 13px 24px;
    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, 1rem);
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, opacity .2s;
    font-family: var(--tix-font-body, inherit);
}
.tix-raffle-submit:hover {
    background: var(--tix-btn1-hover-bg, var(--tix-btn1-bg));
    color: var(--tix-btn1-hover-color, var(--tix-btn1-color));
}
.tix-raffle-submit:disabled {
    opacity: .55;
    cursor: not-allowed;
}

/* ── Nachrichten ── */
.tix-raffle-msg {
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: var(--tix-btn, 14px);
    line-height: 1.4;
    text-align: center;
}
.tix-raffle-msg[hidden] { display: none; }
.tix-raffle-msg.tix-raffle-msg--success {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid #a7f3d0;
}
.tix-raffle-msg.tix-raffle-msg--error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

/* ── Teilnehmerzähler ── */
.tix-raffle-count {
    padding: 12px 28px 16px;
    font-size: var(--tix-small, 13px);
    color: var(--ep-muted, #64748b);
    text-align: center;
    margin: 0;
}
.tix-raffle-max {
    opacity: .7;
}

/* ── Geschlossen ── */
.tix-raffle-closed {
    padding: 28px;
    text-align: center;
    color: var(--ep-muted, #64748b);
}
.tix-raffle-closed p {
    margin: 0 0 8px;
}

/* ── Gewinner ── */
.tix-raffle-winners {
    padding: 20px 28px 24px;
}
.tix-raffle-winners-title {
    font-size: var(--tix-body, 15px);
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--ep-heading, #0D0B09);
}
.tix-raffle-winners-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.tix-raffle-winner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 14px;
    background: #f0fdf4;
    border-radius: 8px;
    border: 1px solid #bbf7d0;
}
.tix-raffle-winner-name {
    font-weight: 600;
    color: #166534;
    font-size: var(--tix-body, 15px);
}
.tix-raffle-winner-prize {
    font-size: var(--tix-small, 13px);
    color: #15803d;
    text-align: right;
}

/* ── Erfolgs-Bestätigung (ersetzt Formular nach Teilnahme) ── */
.tix-raffle-success {
    padding: 28px;
    text-align: center;
}
.tix-raffle-success-icon {
    font-size: 2.5rem;
    margin-bottom: 8px;
}
.tix-raffle-success-title {
    font-size: var(--tix-h3, 18px);
    font-weight: 600;
    color: #065f46;
    margin: 0 0 6px;
}
.tix-raffle-success-text {
    font-size: var(--tix-btn, 14px);
    color: var(--ep-muted, #64748b);
    margin: 0;
}

/* ── Responsive ── */
@media (max-width: 600px) {
    .tix-raffle-header {
        padding: 20px;
    }
    .tix-raffle-prizes,
    .tix-raffle-form,
    .tix-raffle-winners,
    .tix-raffle-closed,
    .tix-raffle-success {
        padding-left: 20px;
        padding-right: 20px;
    }
    .tix-raffle-countdown {
        padding-left: 20px;
        padding-right: 20px;
    }
    .tix-raffle-form-fields {
        flex-direction: column;
    }
    .tix-raffle-title {
        font-size: 1.15rem;
    }
}
