/* v3 — La Dolce Vita Widget Theme
   Basis: pretix widget/v2.css (1408 Z.) — vollwertiger Ersatz (nicht Override).
   Monochrome Dark/Glass-Palette konsistent zu custom.css der Shop-Seite.
   Layout/Sizing bleibt identisch — nur Farben, Borders und Surfaces ersetzt.
   ============================================================================ */

:root {
    /* Pretix-kompatible Token-Namen, Werte monochrom ------------------------ */
    --pretix-brand-primary: #ffffff;
    --pretix-brand-success: #ffffff;
    --pretix-brand-info:    #ffffff;
    --pretix-brand-warning: #ffffff;
    --pretix-brand-danger:  #d77272;
    --pretix-link-contrast-color: #000000;
    --pretix-link-hover-contrast-color: #000000;
    --pretix-brand-primary-lighten-5:  #ffffff;
    --pretix-brand-primary-lighten-20: #ffffff;
    --pretix-brand-primary-lighten-30: #ffffff;
    --pretix-brand-primary-lighten-40: #ffffff;
    --pretix-brand-primary-lighten-48: #ffffff;
    --pretix-brand-primary-lighten-50: #ffffff;
    --pretix-brand-primary-lighten-53: #ffffff;
    --pretix-brand-primary-lighten-55: #ffffff;
    --pretix-brand-primary-darken-5:   #e6e6e6;
    --pretix-brand-primary-darken-10:  #cccccc;
    --pretix-brand-primary-darken-15:  #b3b3b3;
    --pretix-brand-primary-darken-17:  #a6a6a6;
    --pretix-brand-primary-darken-20:  #999999;
    --pretix-brand-primary-darken-30:  #6f6f6f;
    --pretix-brand-primary-tint-90:    rgba(255,255,255,0.10);
    --pretix-brand-primary-shade-25:   rgba(255,255,255,0.85);
    --pretix-brand-primary-shade-42:   rgba(255,255,255,0.70);
    --pretix-brand-primary-lighten-28-saturate-20: #ffffff;
    --pretix-brand-primary-lighten-23-saturate-2:  #ffffff;
    --pretix-brand-success-lighten-10: rgba(255,255,255,0.16);
    --pretix-brand-success-lighten-20: rgba(255,255,255,0.12);
    --pretix-brand-success-lighten-30: rgba(255,255,255,0.10);
    --pretix-brand-success-lighten-35: rgba(255,255,255,0.10);
    --pretix-brand-success-lighten-38: rgba(255,255,255,0.08);
    --pretix-brand-success-lighten-40: rgba(255,255,255,0.08);
    --pretix-brand-success-lighten-48: rgba(255,255,255,0.06);
    --pretix-brand-success-lighten-50: rgba(255,255,255,0.06);
    --pretix-brand-success-darken-5:   #e6e6e6;
    --pretix-brand-success-darken-10:  #cccccc;
    --pretix-brand-success-darken-12:  #bfbfbf;
    --pretix-brand-success-darken-15:  #b3b3b3;
    --pretix-brand-success-darken-17:  #a6a6a6;
    --pretix-brand-success-darken-20:  #999999;
    --pretix-brand-success-darken-30:  #737373;
    --pretix-brand-success-tint-50:    rgba(255,255,255,0.50);
    --pretix-brand-success-tint-85:    rgba(255,255,255,0.08);
    --pretix-brand-success-shade-25:   rgba(255,255,255,0.90);
    --pretix-brand-success-shade-42:   rgba(255,255,255,0.70);
    --pretix-brand-info-lighten-23: rgba(255,255,255,0.08);
    --pretix-brand-info-lighten-25: rgba(255,255,255,0.08);
    --pretix-brand-info-lighten-30: rgba(255,255,255,0.06);
    --pretix-brand-info-lighten-33: rgba(255,255,255,0.06);
    --pretix-brand-info-darken-5:   #e6e6e6;
    --pretix-brand-info-darken-10:  #cccccc;
    --pretix-brand-info-darken-17:  #a6a6a6;
    --pretix-brand-info-darken-20:  #999999;
    --pretix-brand-info-darken-30:  #737373;
    --pretix-brand-info-tint-85:    rgba(255,255,255,0.08);
    --pretix-brand-info-shade-25:   rgba(255,255,255,0.85);
    --pretix-brand-info-shade-42:   rgba(255,255,255,0.70);
    --pretix-brand-warning-lighten-12: rgba(255,255,255,0.14);
    --pretix-brand-warning-lighten-31: rgba(255,255,255,0.10);
    --pretix-brand-warning-lighten-35: rgba(255,255,255,0.10);
    --pretix-brand-warning-lighten-40: rgba(255,255,255,0.08);
    --pretix-brand-warning-lighten-41: rgba(255,255,255,0.08);
    --pretix-brand-warning-lighten-43: rgba(255,255,255,0.06);
    --pretix-brand-warning-darken-5:  #e6e6e6;
    --pretix-brand-warning-darken-10: #cccccc;
    --pretix-brand-warning-darken-15: #b3b3b3;
    --pretix-brand-warning-darken-17: #a6a6a6;
    --pretix-brand-warning-darken-20: #999999;
    --pretix-brand-warning-darken-25: #808080;
    --pretix-brand-warning-darken-30: #737373;
    --pretix-brand-warning-darken-35: #595959;
    --pretix-brand-warning-tint-50:   rgba(255,255,255,0.50);
    --pretix-brand-warning-tint-85:   rgba(255,255,255,0.08);
    --pretix-brand-warning-shade-25:  rgba(255,255,255,0.85);
    --pretix-brand-warning-shade-42:  rgba(255,255,255,0.70);
    --pretix-brand-warning-transparent-60: rgba(255,255,255,0.15);
    --pretix-brand-danger-lighten-5:  #ca6262;
    --pretix-brand-danger-lighten-15: #d78888;
    --pretix-brand-danger-lighten-25: rgba(215,114,114,0.35);
    --pretix-brand-danger-lighten-30: rgba(215,114,114,0.30);
    --pretix-brand-danger-lighten-33: rgba(215,114,114,0.25);
    --pretix-brand-danger-lighten-43: rgba(215,114,114,0.15);
    --pretix-brand-danger-lighten-45: rgba(215,114,114,0.12);
    --pretix-brand-danger-darken-5:   #bb3f3f;
    --pretix-brand-danger-darken-10:  #a83838;
    --pretix-brand-danger-darken-15:  #953232;
    --pretix-brand-danger-darken-17:  #8d2f2f;
    --pretix-brand-danger-darken-20:  #822b2b;
    --pretix-brand-danger-darken-30:  #5b1f1f;
    --pretix-brand-danger-tint-50:    rgba(215,114,114,0.40);
    --pretix-brand-danger-tint-85:    rgba(215,114,114,0.15);
    --pretix-brand-danger-shade-25:   #e08d8d;
    --pretix-brand-danger-shade-42:   #eab1b1;
    --pretix-border-radius-base:  9999px;
    --pretix-border-radius-large: 9999px;
    --pretix-border-radius-small: 9999px;

    /* LDV-native Tokens ----------------------------------------------------- */
    --ldv-bg:         rgba(10,10,10,0.92);
    --ldv-text:       #ffffff;
    --ldv-text-muted: rgba(255,255,255,0.60);
    --ldv-text-dim:   rgba(255,255,255,0.40);
    --ldv-glass-02:   rgba(255,255,255,0.06);
    --ldv-glass-04:   rgba(255,255,255,0.08);
    --ldv-glass-06:   rgba(255,255,255,0.10);
    --ldv-glass-08:   rgba(255,255,255,0.15);
    --ldv-border-faint:  rgba(255,255,255,0.08);
    --ldv-border-subtle: rgba(255,255,255,0.14);
    --ldv-border-medium: rgba(255,255,255,0.22);
    --ldv-border-strong: rgba(255,255,255,0.35);
}

.pretix-widget-hidden { display: none }

/* ============================================================================
   1. Widget-Container & Typografie
   ========================================================================== */
.pretix-widget {
    margin: 10px 0;
    padding: 0 10px;
    border: 1px solid var(--ldv-border-subtle);
    background: var(--ldv-bg);
    -webkit-backdrop-filter: blur(18px) saturate(120%);
    backdrop-filter: blur(18px) saturate(120%);
    color: var(--ldv-text);
    position: relative;
    min-height: 208px;
    border-radius: 18px;
    font-weight: 400;
    letter-spacing: 0.01em;
}

.pretix-widget a, .pretix-widget-alert-box a {
    color: var(--ldv-text);
    text-decoration: underline;
    text-decoration-color: var(--ldv-border-strong);
    text-underline-offset: 3px;
}

.pretix-widget a:hover, .pretix-widget a:focus,
.pretix-widget-alert-box a:hover, .pretix-widget-alert-box a:focus {
    color: var(--ldv-text);
    text-decoration-color: var(--ldv-text);
}

.pretix-widget a:focus, .pretix-widget-alert-box a:focus {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
    z-index: 999;
}

.pretix-widget img, .pretix-widget-alert-box img { border: 0 }
.pretix-widget b, .pretix-widget strong,
.pretix-widget-alert-box b, .pretix-widget-alert-box strong { font-weight: 700 }

.pretix-widget h3, .pretix-widget-alert-box h3 {
    font-size: 22px;
    font-weight: 700;
    padding: 0 15px;
    letter-spacing: 0.02em;
    color: var(--ldv-text);
}

/* ============================================================================
   2. Buttons — Primary (Pill, weißer Hintergrund, schwarzer Text)
   ========================================================================== */
.pretix-widget button,
.pretix-widget input[type="button"],
.pretix-widget a.pretix-widget-button,
.pretix-widget-alert-box button,
.pretix-widget-alert-box input[type="button"],
.pretix-widget-alert-box a.pretix-widget-button {
    overflow: visible;
    text-transform: uppercase;
    cursor: pointer;
    display: inline-block;
    margin-bottom: 0;
    text-align: center;
    vertical-align: middle;
    touch-action: manipulation;
    background-image: none;
    border: 1px solid transparent;
    white-space: nowrap;
    text-decoration: none;
    padding: 10px 22px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.42857;
    letter-spacing: 0.08em;
    border-radius: var(--pretix-border-radius-base);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    color: #000000;
    background-color: #ffffff;
    border-color: #ffffff;
    transition: background-color .2s ease, border-color .2s ease, color .2s ease;
}

.pretix-widget button:focus, .pretix-widget button.focus,
.pretix-widget input[type="button"]:focus, .pretix-widget input[type="button"].focus,
.pretix-widget a.pretix-widget-button:focus, .pretix-widget a.pretix-widget-button.focus,
.pretix-widget-alert-box button:focus, .pretix-widget-alert-box button.focus,
.pretix-widget-alert-box input[type="button"]:focus, .pretix-widget-alert-box input[type="button"].focus,
.pretix-widget-alert-box a.pretix-widget-button:focus, .pretix-widget-alert-box a.pretix-widget-button.focus {
    color: #000000;
    background-color: #e6e6e6;
    border-color: #e6e6e6;
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
    text-decoration: none;
}

.pretix-widget button:hover,
.pretix-widget input[type="button"]:hover,
.pretix-widget a.pretix-widget-button:hover,
.pretix-widget-alert-box button:hover,
.pretix-widget-alert-box input[type="button"]:hover,
.pretix-widget-alert-box a.pretix-widget-button:hover {
    color: #000000;
    background-color: #f0f0f0;
    border-color: #f0f0f0;
}

.pretix-widget button:active, .pretix-widget button.active,
.open > .pretix-widget button.dropdown-toggle,
.pretix-widget input[type="button"]:active, .pretix-widget input[type="button"].active,
.open > .pretix-widget input[type="button"].dropdown-toggle,
.pretix-widget a.pretix-widget-button:active, .pretix-widget a.pretix-widget-button.active,
.open > .pretix-widget a.pretix-widget-button.dropdown-toggle,
.pretix-widget-alert-box button:active, .pretix-widget-alert-box button.active,
.open > .pretix-widget-alert-box button.dropdown-toggle,
.pretix-widget-alert-box input[type="button"]:active, .pretix-widget-alert-box input[type="button"].active,
.open > .pretix-widget-alert-box input[type="button"].dropdown-toggle,
.pretix-widget-alert-box a.pretix-widget-button:active, .pretix-widget-alert-box a.pretix-widget-button.active,
.open > .pretix-widget-alert-box a.pretix-widget-button.dropdown-toggle {
    color: #000000;
    background-color: #d9d9d9;
    background-image: none;
    border-color: #d9d9d9;
}

.pretix-widget button.disabled, .pretix-widget button[disabled],
fieldset[disabled] .pretix-widget button,
.pretix-widget input[type="button"].disabled, .pretix-widget input[type="button"][disabled],
fieldset[disabled] .pretix-widget input[type="button"],
.pretix-widget a.pretix-widget-button.disabled, .pretix-widget a.pretix-widget-button[disabled],
fieldset[disabled] .pretix-widget a.pretix-widget-button {
    cursor: not-allowed;
    filter: alpha(opacity=45);
    opacity: 0.45;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.pretix-widget button .badge,
.pretix-widget input[type="button"] .badge,
.pretix-widget a.pretix-widget-button .badge,
.pretix-widget-alert-box button .badge,
.pretix-widget-alert-box input[type="button"] .badge,
.pretix-widget-alert-box a.pretix-widget-button .badge {
    color: #ffffff;
    background-color: #000000;
}

/* ============================================================================
   3. Buttons — btn-default (Glass-Secondary)
   ========================================================================== */
.pretix-widget button.pretix-widget-btn-default,
.pretix-widget input[type="button"].pretix-widget-btn-default,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default,
.pretix-widget-alert-box button.pretix-widget-btn-default,
.pretix-widget-alert-box input[type="button"].pretix-widget-btn-default,
.pretix-widget-alert-box a.pretix-widget-button.pretix-widget-btn-default {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-04);
    border-color: var(--ldv-border-medium);
}

.pretix-widget button.pretix-widget-btn-default:focus,
.pretix-widget button.pretix-widget-btn-default.focus,
.pretix-widget input[type="button"].pretix-widget-btn-default:focus,
.pretix-widget input[type="button"].pretix-widget-btn-default.focus,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default:focus,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default.focus,
.pretix-widget-alert-box button.pretix-widget-btn-default:focus,
.pretix-widget-alert-box input[type="button"].pretix-widget-btn-default:focus,
.pretix-widget-alert-box a.pretix-widget-button.pretix-widget-btn-default:focus {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-08);
    border-color: var(--ldv-border-strong);
}

.pretix-widget button.pretix-widget-btn-default:hover,
.pretix-widget input[type="button"].pretix-widget-btn-default:hover,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default:hover,
.pretix-widget-alert-box button.pretix-widget-btn-default:hover,
.pretix-widget-alert-box input[type="button"].pretix-widget-btn-default:hover,
.pretix-widget-alert-box a.pretix-widget-button.pretix-widget-btn-default:hover {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-06);
    border-color: var(--ldv-border-strong);
}

.pretix-widget button.pretix-widget-btn-default:active,
.pretix-widget button.pretix-widget-btn-default.active,
.pretix-widget input[type="button"].pretix-widget-btn-default:active,
.pretix-widget input[type="button"].pretix-widget-btn-default.active,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default:active,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default.active {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-08);
    background-image: none;
    border-color: var(--ldv-border-strong);
}

.pretix-widget button.pretix-widget-btn-default .badge,
.pretix-widget input[type="button"].pretix-widget-btn-default .badge,
.pretix-widget a.pretix-widget-button.pretix-widget-btn-default .badge {
    color: #000000;
    background-color: #ffffff;
}

/* ============================================================================
   4. Checkbox-Buttons (Variants-Auswahl)
   ========================================================================== */
.pretix-widget label.pretix-widget-btn-checkbox,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-04);
    border-color: var(--ldv-border-medium);
    border-radius: var(--pretix-border-radius-base);
    border-width: 1px;
    border-style: solid;
    position: relative;
    cursor: pointer;
    padding: 8px 26px;
    min-height: 40px;
    box-sizing: border-box;
    font-weight: 500;
    letter-spacing: 0.04em;
}

.pretix-widget label.pretix-widget-btn-checkbox:focus,
.pretix-widget label.pretix-widget-btn-checkbox.focus,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox:focus {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-08);
    border-color: var(--ldv-border-strong);
}

.pretix-widget label.pretix-widget-btn-checkbox:hover,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox:hover {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-06);
    border-color: var(--ldv-border-strong);
}

.pretix-widget label.pretix-widget-btn-checkbox:active,
.pretix-widget label.pretix-widget-btn-checkbox.active {
    color: var(--ldv-text);
    background-color: var(--ldv-glass-08);
    background-image: none;
    border-color: var(--ldv-border-strong);
}

.pretix-widget label.pretix-widget-btn-checkbox:has(input:checked),
.pretix-widget-alert-box label.pretix-widget-btn-checkbox:has(input:checked) {
    background-color: #ffffff;
    border-color: #ffffff;
    color: #000000;
}

.pretix-widget label.pretix-widget-btn-checkbox:focus-within,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox:focus-within {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
    z-index: 999;
}

.pretix-widget label.pretix-widget-btn-checkbox .badge,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox .badge {
    color: #000000;
    background-color: #ffffff;
}

.pretix-widget label.pretix-widget-btn-checkbox input,
.pretix-widget-alert-box label.pretix-widget-btn-checkbox input {
    position: absolute;
    left: 10px;
}

/* Cart-Icon -------------------------------------------------------------- */
.pretix-widget .pretix-widget-icon-cart,
.pretix-widget-alert-box .pretix-widget-icon-cart {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: text-bottom;
    fill: var(--ldv-text);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%23ffffff' d='M2.267 6.756c0-.312-.202-.563-.453-.563-.252 0-.454.251-.454.563 0 .312.202.563.454.563.251 0 .453-.251.453-.563Zm3.174 0c0-.312-.202-.563-.454-.563-.251 0-.453.251-.453.563 0 .312.202.563.453.563.252 0 .454-.251.454-.563Zm.453-4.785c0-.154-.103-.282-.227-.282H1.413c-.035-.211-.039-.563-.28-.563H.227c-.124 0-.227.128-.227.282 0 .153.103.281.227.281h.722l.627 3.62c-.049.127-.216.466-.216.603 0 .153.103.281.227.281h3.627c.124 0 .227-.128.227-.281 0-.154-.103-.282-.227-.282H1.955c.036-.088.085-.18.085-.281 0-.102-.032-.212-.046-.308l3.698-.537c.117-.018.202-.141.202-.281V1.971Z' transform='matrix(2.52069 0 0 2.02994 -.035 -.523)'/%3E%3C/svg%3E%0A");
}

.pretix-widget label.pretix-widget-btn-checkbox:has(input:checked) .pretix-widget-icon-cart {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%23000000' d='M4.534 3.097a.317.317 0 0 1-.067.197L3.56 4.42a.207.207 0 0 1-.16.084.207.207 0 0 1-.159-.084l-.907-1.126a.317.317 0 0 1-.067-.197c0-.154.103-.282.227-.282.06 0 .117.031.159.084l.521.642V2.252c0-.154.102-.281.226-.281.124 0 .227.127.227.281v1.289l.521-.642a.205.205 0 0 1 .159-.084c.124 0 .227.128.227.282ZM2.267 6.756c0-.312-.202-.563-.453-.563-.252 0-.454.251-.454.563 0 .312.202.563.454.563.251 0 .453-.251.453-.563Zm3.174 0c0-.312-.202-.563-.454-.563-.251 0-.453.251-.453.563 0 .312.202.563.453.563.252 0 .454-.251.454-.563Zm.453-4.785c0-.154-.103-.282-.227-.282H1.413c-.035-.211-.039-.563-.28-.563H.227c-.124 0-.227.128-.227.282 0 .153.103.281.227.281h.722l.627 3.62c-.049.127-.216.466-.216.603 0 .153.103.281.227.281h3.627c.124 0 .227-.128.227-.281 0-.154-.103-.282-.227-.282H1.955c.036-.088.085-.18.085-.281 0-.102-.032-.212-.046-.308l3.698-.537c.117-.018.202-.141.202-.281V1.971Z' transform='matrix(2.52069 0 0 2.02994 -.035 -.523)'/%3E%3C/svg%3E%0A");
}

/* ============================================================================
   5. Inputs & Selects
   ========================================================================== */
.pretix-widget input[type="text"],
.pretix-widget input[type="number"],
.pretix-widget select,
.pretix-widget-alert-box input[type="text"],
.pretix-widget-alert-box input[type="number"],
.pretix-widget-alert-box select {
    line-height: normal;
    border: 1px solid var(--ldv-border-medium);
    border-radius: var(--pretix-border-radius-base);
    min-height: 40px;
    padding: 8px 14px;
    color: var(--ldv-text);
    background-color: var(--ldv-glass-04);
    box-shadow: none;
    -webkit-box-shadow: none;
    -webkit-transition: border-color .15s ease-in-out, background-color .15s ease-in-out;
    -o-transition: border-color .15s ease-in-out, background-color .15s ease-in-out;
    transition: border-color .15s ease-in-out, background-color .15s ease-in-out;
}

.pretix-widget input[type="text"]::-moz-placeholder,
.pretix-widget input[type="number"]::-moz-placeholder,
.pretix-widget select::-moz-placeholder { color: var(--ldv-text-dim); opacity: 1 }
.pretix-widget input[type="text"]:-ms-input-placeholder,
.pretix-widget input[type="number"]:-ms-input-placeholder,
.pretix-widget select:-ms-input-placeholder { color: var(--ldv-text-dim) }
.pretix-widget input[type="text"]::-webkit-input-placeholder,
.pretix-widget input[type="number"]::-webkit-input-placeholder,
.pretix-widget select::-webkit-input-placeholder { color: var(--ldv-text-dim) }

.pretix-widget input[type="text"]:focus,
.pretix-widget input[type="number"]:focus,
.pretix-widget select:focus,
.pretix-widget-alert-box input[type="text"]:focus,
.pretix-widget-alert-box input[type="number"]:focus,
.pretix-widget-alert-box select:focus {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
    z-index: 999;
    background-color: var(--ldv-glass-06);
    border-color: var(--ldv-border-strong);
}

.pretix-widget input[type=number],
.pretix-widget-alert-box input[type=number] { padding-right: 0 }

.pretix-widget input[type="checkbox"],
.pretix-widget input[type="radio"],
.pretix-widget-alert-box input[type="checkbox"],
.pretix-widget-alert-box input[type="radio"] {
    box-sizing: border-box;
    padding: 0;
    accent-color: var(--ldv-text);
}

.pretix-widget input[type="checkbox"]:focus,
.pretix-widget input[type="radio"]:focus,
.pretix-widget-alert-box input[type="checkbox"]:focus,
.pretix-widget-alert-box input[type="radio"]:focus {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
}

.pretix-widget-use-custom-spinners input[type=number] {
    padding-right: 12px;
    -moz-appearance: textfield;
}
.pretix-widget-use-custom-spinners input[type=number]::-webkit-outer-spin-button,
.pretix-widget-use-custom-spinners input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* ============================================================================
   6. Messages & Loading
   ========================================================================== */
.pretix-widget .pretix-widget-resume-button { margin-left: 10px }
.pretix-widget .pretix-widget-clickable { cursor: pointer }

.pretix-widget .pretix-widget-info-message {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 12px 14px;
    text-align: left;
    margin: 12px 0;
    background-color: var(--ldv-glass-04);
    border: 1px solid var(--ldv-border-medium);
    color: var(--ldv-text);
    border-radius: 12px;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-info-message { flex-direction: column }
.pretix-widget.pretix-widget-mobile .pretix-widget-resume-button { margin-top: 10px; margin-left: 0 }

.pretix-widget .pretix-widget-error-message {
    padding: 12px 14px;
    text-align: center;
    margin: 12px 0;
    background-color: rgba(215,114,114,0.12);
    border: 1px solid rgba(215,114,114,0.45);
    color: #eab1b1;
    border-radius: 12px;
}

.pretix-widget .pretix-widget-error-action { padding: 10px; text-align: center }

.pretix-widget .pretix-widget-loading {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.65);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    text-align: center;
    border-radius: 18px;
}

.pretix-widget .pretix-widget-loading svg {
    margin: 40px;
    position: absolute;
    top: 50%;
    margin-top: -64px;
    position: -webkit-sticky;
    position: sticky;
    top: min(50vh, 50%);
    -webkit-animation: pretix-widget-spin 6s linear infinite;
    -moz-animation: pretix-widget-spin 6s linear infinite;
    animation: pretix-widget-spin 6s linear infinite;
}

.pretix-widget .pretix-widget-loading svg path,
.pretix-widget .pretix-widget-loading svg circle { fill: var(--ldv-text) !important }

@-moz-keyframes pretix-widget-spin { 100% { -moz-transform: rotate(360deg) } }
@-webkit-keyframes pretix-widget-spin { 100% { -webkit-transform: rotate(360deg) } }
@keyframes pretix-widget-spin {
    100% { -webkit-transform: rotate(360deg); transform: rotate(360deg) }
}

/* ============================================================================
   7. Item-Rows & Kategorien
   ========================================================================== */
.pretix-widget .pretix-widget-item-row,
.pretix-widget .pretix-widget-category { clear: both }

.pretix-widget .pretix-widget-item-title {
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--ldv-text);
}

.pretix-widget .pretix-widget-item-row {
    padding: 14px 0;
    border-bottom: 1px solid var(--ldv-border-faint);
}
.pretix-widget .pretix-widget-item-row:last-child { border-bottom: none }

.pretix-widget .pretix-widget-category { margin: 12px 0 }
.pretix-widget .pretix-widget-category-description { padding: 0 15px; color: var(--ldv-text-muted) }
.pretix-widget .pretix-widget-category-name {
    margin: 12px 0 0 0;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--ldv-text);
}

.pretix-widget .pretix-widget-item-info-col {
    width: 50%;
    float: left;
    padding: 0 15px;
    box-sizing: border-box;
}
.pretix-widget .pretix-widget-item-price-col,
.pretix-widget .pretix-widget-item-availability-col {
    width: 25%;
    float: left;
    padding: 0 15px;
    box-sizing: border-box;
}
.pretix-widget .pretix-widget-item-description p,
.pretix-widget .pretix-widget-item-meta { margin: 0; color: var(--ldv-text-muted) }
.pretix-widget .pretix-widget-item-price-col { text-align: right }

.pretix-widget del.pretix-widget-pricebox-original-price { color: var(--ldv-text-dim) }
.pretix-widget ins.pretix-widget-pricebox-new-price {
    font-size: 115%;
    font-weight: 700;
    text-decoration: none;
    color: var(--ldv-text);
}

.pretix-widget .pretix-widget-clear { clear: both }
.pretix-widget .pretix-widget-category-description p { margin: 0 0 10px }
.pretix-widget .pretix-widget-pricebox-tax { display: block; color: var(--ldv-text-muted); font-size: 0.85em }

/* Quantity-Group ---------------------------------------------------------- */
.pretix-widget .pretix-widget-item-count-group { display: flex }
.pretix-widget .pretix-widget-item-count-group input {
    border-radius: 0;
    border-left: none;
    border-right: none;
    text-align: center;
}
.pretix-widget .pretix-widget-item-count-group button span { vertical-align: 25%; line-height: 0.5 }
.pretix-widget .pretix-widget-item-count-dec {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    width: 2.5em;
    z-index: 2;
}
.pretix-widget .pretix-widget-item-count-inc {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    width: 2.5em;
}
.pretix-widget .pretix-widget-item-count-multiple {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 5px;
    text-align: center;
}
.pretix-widget .pretix-widget-pricebox-price-input {
    display: inline;
    width: 100px;
    box-sizing: border-box;
    text-align: right;
}
.pretix-widget .pretix-widget-item-count-single-label {
    display: block;
    text-align: center;
    width: 100%;
}

/* ============================================================================
   8. Attribution / Back / Voucher / Seating
   ========================================================================== */
.pretix-widget .pretix-widget-attribution {
    padding: 12px 15px;
    text-align: center;
    font-size: 11px;
    color: var(--ldv-text-dim);
    letter-spacing: 0.05em;
}
.pretix-widget .pretix-widget-attribution a { color: var(--ldv-text-muted) }

.pretix-widget .pretix-widget-item-picture-link {
    width: 60px;
    height: 60px;
    margin-right: 10px;
    float: left;
    border-radius: 8px;
    overflow: hidden;
}
.pretix-widget .pretix-widget-item-picture { max-width: 100% }

.pretix-widget .pretix-widget-action {
    margin-left: 75%;
    width: 25%;
    padding: 0 15px;
    box-sizing: border-box;
}
.pretix-widget .pretix-widget-action button { width: 100% }

.pretix-widget .pretix-widget-voucher-text { margin: 10px 0; padding: 0 15px; color: var(--ldv-text-muted) }
.pretix-widget .pretix-widget-voucher-headline {
    margin: 12px 0 6px 0;
    color: var(--ldv-text);
    font-weight: 700;
}
.pretix-widget .pretix-widget-voucher-input-wrap {
    padding: 0 15px;
    width: 75%;
    box-sizing: border-box;
    float: left;
}
.pretix-widget .pretix-widget-voucher input { width: 100%; box-sizing: border-box }
.pretix-widget .pretix-widget-voucher-button-wrap {
    padding: 0 15px;
    width: 25%;
    box-sizing: border-box;
    float: left;
}
.pretix-widget .pretix-widget-voucher button { width: 100% }

.pretix-widget .pretix-widget-seating-waitinglist { margin: 15px 0 }
.pretix-widget .pretix-widget-seating-waitinglist-text {
    padding: 0 15px;
    width: 75%;
    box-sizing: border-box;
    float: left;
    color: var(--ldv-text-muted);
}
.pretix-widget .pretix-widget-seating-waitinglist-button-wrap {
    padding: 0 15px;
    width: 25%;
    box-sizing: border-box;
    float: left;
}
.pretix-widget .pretix-widget-seating-waitinglist-button { width: 100% }

.pretix-widget .pretix-widget-item-with-picture .pretix-widget-main-item-row .pretix-widget-item-title-and-description {
    margin-left: 70px;
}
.pretix-widget .pretix-widget-item-availability-col { text-align: center }

.pretix-widget .pretix-widget-item-availability-col .pretix-widget-collapse-indicator {
    width: 100%;
    border: 1px solid var(--ldv-border-medium);
    border-radius: var(--pretix-border-radius-base);
    height: 40px;
    padding: 8px 14px;
    color: var(--ldv-text);
    background-color: var(--ldv-glass-04);
}
.pretix-widget .pretix-widget-item-availability-col .pretix-widget-collapse-indicator::before {
    content: "";
    display: inline-block;
    width: 14px;
    height: 14px;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23ffffff' d='M6.395 4.151a.268.268 0 0 0-.177.077l-.386.386a.259.259 0 0 0-.077.177c.002.067.029.13.077.179l3.033 3.031-3.033 3.032a.255.255 0 0 0-.077.177.253.253 0 0 0 .077.178l.386.385a.268.268 0 0 0 .177.077.27.27 0 0 0 .178-.077l3.595-3.595a.259.259 0 0 0 .077-.177.255.255 0 0 0-.077-.176L6.573 4.228a.257.257 0 0 0-.178-.077Z'/%3E%3C/svg%3E");
    transition: transform .5s;
}
.pretix-widget .pretix-widget-item-availability-col .pretix-widget-collapse-indicator[aria-expanded=true]::before {
    transform: rotate(90deg);
}

.pretix-widget .pretix-widget-availability-gone {
    font-weight: 700;
    color: var(--pretix-brand-danger);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.pretix-widget .pretix-widget-availability-unavailable {
    color: var(--ldv-text-muted);
}

.pretix-widget .pretix-widget-item-variations {
    overflow: hidden;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: 0;
    margin-bottom: 0;
    -moz-transition-duration: 0.5s;
    -webkit-transition-duration: 0.5s;
    -o-transition-duration: 0.5s;
    transition-duration: 0.5s;
    transition-timing-function: ease-in-out;
}

/* ============================================================================
   9. Event-Header / Event-List
   ========================================================================== */
.pretix-widget .pretix-widget-event-header { padding-top: 12px; text-align: center; color: var(--ldv-text) }
.pretix-widget .pretix-widget-event-details { padding-top: 8px; text-align: center; color: var(--ldv-text-muted) }
.pretix-widget .pretix-widget-event-location { display: none; padding-top: 8px; text-align: center; color: var(--ldv-text-muted) }
.pretix-widget .pretix-widget-event-description { padding: 0 15px; color: var(--ldv-text-muted) }

.pretix-widget .pretix-widget-event-list-back,
.pretix-widget .pretix-widget-back {
    padding-top: 10px;
    padding-bottom: 10px;
    text-align: center;
    display: block;
}
.pretix-widget .pretix-widget-event-list-back a,
.pretix-widget .pretix-widget-back a {
    display: block;
    color: var(--ldv-text-muted);
}
.pretix-widget .pretix-widget-event-list-back a:hover,
.pretix-widget .pretix-widget-back a:hover { color: var(--ldv-text) }

.pretix-widget .pretix-widget-event-list { padding: 10px 0; cursor: pointer }

.pretix-widget .pretix-widget-event-list-entry {
    display: flex;
    flex-direction: row;
    padding: 10px 0;
    flex-wrap: wrap;
    color: var(--ldv-text);
    border-bottom: 1px solid var(--ldv-border-faint);
    transition: background-color .2s ease;
}
.pretix-widget .pretix-widget-event-list-entry:has(.pretix-widget-event-list-entry-availability) {
    text-decoration: none;
}
.pretix-widget .pretix-widget-event-list-entry:hover,
.pretix-widget .pretix-widget-event-list-entry:active,
.pretix-widget .pretix-widget-event-list-entry:focus {
    background: var(--ldv-glass-04);
    text-decoration: none;
}

.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-name {
    width: 50%;
    padding: 6px 10px;
    box-sizing: border-box;
    font-weight: 600;
}
.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-location {
    padding: 6px 10px;
    box-sizing: border-box;
    display: none;
    color: var(--ldv-text-muted);
}
.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-date {
    width: 25%;
    padding: 6px 10px;
    box-sizing: border-box;
    color: var(--ldv-text-muted);
}
.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-availability {
    width: 25%;
    text-align: right;
    padding: 8px 10px 4px;
    box-sizing: border-box;
}

.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-availability span {
    position: relative;
    display: inline;
    padding: 6px 10px 4px 18px;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--status-text-color, var(--ldv-text));
    background-color: var(--status-bg-color, var(--ldv-glass-04));
    border: 1px solid var(--status-border-color, var(--ldv-border-medium));
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 9999px;
}
.pretix-widget .pretix-widget-event-list-entry .pretix-widget-event-list-entry-availability span:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 10px;
    height: 100%;
    background: var(--status-border-color, var(--ldv-border-medium));
    border-top-left-radius: 9999px;
    border-bottom-left-radius: 9999px;
}

/* Availability-Status — alle monochrom mit subtiler Differenzierung -------- */
.pretix-widget .pretix-widget-event-availability-green,
.pretix-widget .pretix-widget-day-availability-green {
    --status-bg-color: rgba(255,255,255,0.10);
    --status-text-color: #ffffff;
    --status-border-color: rgba(255,255,255,0.55);
}
.pretix-widget .pretix-widget-event-availability-orange,
.pretix-widget .pretix-widget-day-availability-orange {
    --status-bg-color: rgba(255,255,255,0.08);
    --status-text-color: rgba(255,255,255,0.85);
    --status-border-color: rgba(255,255,255,0.40);
}
.pretix-widget .pretix-widget-event-availability-none,
.pretix-widget .pretix-widget-day-availability-none {
    --status-bg-color: rgba(255,255,255,0.04);
    --status-text-color: rgba(255,255,255,0.55);
    --status-border-color: rgba(255,255,255,0.20);
}
.pretix-widget .pretix-widget-event-availability-red,
.pretix-widget .pretix-widget-day-availability-red {
    --status-bg-color: rgba(215,114,114,0.12);
    --status-text-color: #eab1b1;
    --status-border-color: rgba(215,114,114,0.50);
}
.pretix-widget .pretix-widget-event-list .pretix-widget-event-availability-low .pretix-widget-event-list-entry-availability span:before,
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-availability-low.pretix-widget-event-calendar-event:before {
    background: linear-gradient(to bottom,
        rgba(255,255,255,0.80) 1em,
        var(--status-border-color) 2.5em);
}

/* ============================================================================
   10. Kalender (Woche / Monat)
   ========================================================================== */
.pretix-widget .pretix-widget-event-calendar {
    padding-top: 12px;
    word-break: break-word;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table {
    display: flex;
    flex-direction: row;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-week-col {
    flex: 1;
    margin: 0;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-week-col:first-child { margin-left: 0 }
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-week-col:last-child { margin-right: 0 }
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-week-col:nth-child(even) {
    background-color: rgba(255,255,255,0.025);
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-week-col .pretix-widget-event-calendar-events {
    margin: 4px;
}

.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-head {
    display: flex;
    flex-direction: row;
    padding: 8px 0;
    color: var(--ldv-text);
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-head strong {
    width: 50%;
    text-align: center;
    display: block;
    letter-spacing: 0.05em;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-head .pretix-widget-event-calendar-next-month,
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-head .pretix-widget-event-calendar-previous-month {
    display: block;
    width: 25%;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-head .pretix-widget-event-calendar-next-month { text-align: right }

.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-event {
    position: relative;
    display: block;
    border-radius: 9999px;
    border: 1px solid var(--status-border-color, var(--ldv-border-medium));
    background-color: var(--status-bg-color, var(--ldv-glass-04));
    color: var(--status-text-color, var(--ldv-text));
    padding: 6px 10px 6px 20px;
    cursor: pointer;
    margin-bottom: 6px;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 0.03em;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-event:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 10px;
    height: 100%;
    background: var(--status-border-color, var(--ldv-border-medium));
    border-top-left-radius: 9999px;
    border-bottom-left-radius: 9999px;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-event:last-child { margin-bottom: 0 }

.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-table {
    width: 100%;
    border-spacing: 0;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-table th,
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-table td {
    width: 14.2857142857%;
    vertical-align: top;
    padding: 5px;
    border-bottom: 1px solid var(--ldv-border-faint);
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-table th {
    border-bottom-width: 2px;
    border-bottom-color: var(--ldv-border-subtle);
    color: var(--ldv-text-muted);
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: 11px;
    padding-bottom: 8px;
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-table td:has(.pretix-widget-event-calendar-day):nth-child(even) {
    background: rgba(255,255,255,0.025);
}

.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-calendar-day {
    font-weight: 700;
    font-size: 86%;
    padding: 6px 6px 1em;
    color: var(--ldv-text);
}
.pretix-widget .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-calendar-day {
    padding-bottom: 8px;
    background-color: var(--ldv-glass-02);
    border-bottom: 2px solid var(--ldv-border-subtle);
    color: var(--ldv-text-muted);
    font-size: 100%;
    letter-spacing: 0.04em;
}

.pretix-widget .pretix-widget-seating-link-wrapper {
    padding: 0 15px;
    margin: 15px 0 10px;
}
.pretix-widget .pretix-widget-seating-link {
    display: block;
    width: 100%;
}

/* ============================================================================
   11. Event-List-Filter
   ========================================================================== */
.pretix-widget-event-list-filter-form { margin-bottom: 15px }
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-fieldset {
    display: flex;
    flex-direction: row;
    align-items: end;
    border: none;
    padding: 0;
    margin: 0;
}
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-fieldset > legend {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-field {
    display: block;
    width: 100%;
    margin: 0 15px 0 0;
}
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-field label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--ldv-text-muted);
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-field select {
    display: block;
    width: 100%;
}
.pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-field:last-child { margin: 0 }

.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-fieldset { display: block }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-filter-form .pretix-widget-event-list-filter-field {
    display: block;
    margin: 0 0 8px;
}

/* ============================================================================
   12. Animations & Misc
   ========================================================================== */
@keyframes pretix-widget-bounce-in {
    0%   { transform: scale(0) }
    50%  { transform: scale(1.5) }
    100% { transform: scale(1) }
}
.pretix-widget-visibility-hidden { visibility: hidden }

.pretix-widget-shake-once {
    animation: pretix-widget-shake .2s;
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
}
@keyframes pretix-widget-shake {
    0%   { transform: skewX(0deg) }
    20%  { transform: skewX(-5deg) }
    40%  { transform: skewX(5deg) }
    60%  { transform: skewX(-5deg) }
    80%  { transform: skewX(5deg) }
    100% { transform: skewX(0deg) }
}

/* ============================================================================
   13. Frame / Lightbox / Alert (modale Kontexte)
   ========================================================================== */
.pretix-widget-alert-holder,
.pretix-widget-frame-holder,
.pretix-widget-lightbox-holder {
    margin: auto;
    border: none;
    background: transparent;
    overflow: visible;
}
.pretix-widget-alert-holder::backdrop,
.pretix-widget-frame-holder::backdrop,
.pretix-widget-lightbox-holder::backdrop {
    background: rgba(0,0,0,0.78);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
}
.pretix-widget-alert-holder:focus,
.pretix-widget-frame-holder:focus,
.pretix-widget-lightbox-holder:focus {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
}
.pretix-widget-alert-holder:not([open]),
.pretix-widget-frame-holder:not([open]),
.pretix-widget-lightbox-holder:not([open]) { display: none }

.pretix-widget-frame-isloading:focus { outline: none }
.pretix-widget-frame-isloading:focus svg {
    outline: 2px solid var(--ldv-text);
    border-radius: 100%;
}

.pretix-widget-frame-loading p,
.pretix-widget-lightbox-loading p {
    text-align: center;
    width: 256px;
    margin: 0 auto;
    color: var(--pretix-brand-danger);
}
.pretix-widget-frame-loading svg,
.pretix-widget-lightbox-loading svg {
    margin: 40px;
    -webkit-animation: pretix-widget-spin 6s linear infinite;
    animation: pretix-widget-spin 6s linear infinite;
    filter: brightness(0) invert(1);
}

.pretix-widget-frame-close,
.pretix-widget-lightbox-close {
    position: absolute;
    top: -14px;
    right: -14px;
    z-index: 2;
}
.pretix-widget-frame-close button,
.pretix-widget-lightbox-close button {
    color: #000000;
    cursor: pointer;
    font-weight: 700;
    font-family: sans-serif;
    text-decoration: none;
    padding: 4px 0;
    display: inline-block;
    line-height: 16px;
    border: none;
    width: 28px;
    height: 28px;
    background: #ffffff;
    border-radius: 14px;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0,0,0,0.4);
}
.pretix-widget-frame-close button:focus,
.pretix-widget-lightbox-close button:focus {
    outline: 2px solid var(--ldv-text);
    outline-offset: 2px;
}
.pretix-widget-frame-close svg,
.pretix-widget-lightbox-close svg {
    display: inline-block;
    border: none;
}
.pretix-widget-frame-close svg path,
.pretix-widget-lightbox-close svg path { fill: #000000 }

.pretix-widget-frame-inner,
.pretix-widget-lightbox-inner,
.pretix-widget-alert-box {
    position: relative;
    background: var(--ldv-bg);
    -webkit-backdrop-filter: blur(20px) saturate(120%);
    backdrop-filter: blur(20px) saturate(120%);
    border: 1px solid var(--ldv-border-subtle);
    border-radius: 16px;
    box-shadow: 0 12px 60px rgba(0,0,0,0.55);
    box-sizing: border-box;
    padding: 10px;
    color: var(--ldv-text);
}

.pretix-widget-alert-holder .bounce-enter-active { animation: pretix-widget-bounce-in .5s }
.pretix-widget-alert-holder .bounce-leave-active { animation: pretix-widget-bounce-in .5s reverse }

.pretix-widget-alert-holder .pretix-widget-alert-box {
    padding: 44px 22px 22px 22px;
    text-align: center;
    font-size: 19px;
    line-height: 1.4;
}
.pretix-widget-alert-holder .pretix-widget-alert-box p:first-child { margin-top: 0 }
.pretix-widget-alert-holder .pretix-widget-alert-box p:last-child  { margin-bottom: 0 }

.pretix-widget-alert-holder .pretix-widget-alert-icon {
    position: absolute;
    left: 50%;
    width: 64px;
    margin-left: -32px;
    top: -20px;
    filter: brightness(0) invert(1);
}

.pretix-widget-frame-inner {
    width: 80vw;
    max-width: 1080px;
    height: 80vh;
}
.pretix-widget-frame-inner iframe {
    width: 100% !important;
    height: 100% !important;
    border-radius: 14px;
    background: transparent;
}
.pretix-widget-lightbox-inner {
    max-width: 90vw;
    max-height: 90vh;
}
.pretix-widget-lightbox-isloading .pretix-widget-lightbox-inner { visibility: hidden }
.pretix-widget-lightbox-image {
    margin: 0;
    padding: 0;
    text-align: center;
}
.pretix-widget-lightbox-image img {
    max-width: 80vw;
    max-height: 80vh;
    object-fit: scale-down;
    border-radius: 12px;
}
.pretix-widget-lightbox-image figcaption {
    margin: 0.5em 0 0;
    color: var(--ldv-text-muted);
}

.pretix-widget-primary-color { fill: var(--ldv-text) }
.pretix-widget-event-list-load-more { text-align: center; padding: 10px 0 }

/* ============================================================================
   14. Mobile-Adjustments
   ========================================================================== */
.pretix-widget.pretix-widget-mobile .pretix-widget-event-week-table { display: block }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-week-table .pretix-widget-event-week-col {
    flex: 1;
    margin: 10px 0;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-item-info-col {
    width: 100%;
    float: none;
    margin-bottom: 8px;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-item-info-col:after {
    display: block;
    content: "";
    clear: both;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-item-price-col,
.pretix-widget.pretix-widget-mobile .pretix-widget-item-availability-col {
    width: 50%;
    min-width: 140px;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-action {
    width: 100%;
    margin-left: 0;
    margin-top: 10px;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-voucher-input-wrap {
    width: 100%;
    float: none;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-voucher-button-wrap {
    width: 100%;
    float: none;
    margin-top: 10px;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-entry .pretix-widget-event-list-entry-name   { width: 100% }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-entry .pretix-widget-event-list-entry-location { width: 100% }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-entry .pretix-widget-event-list-entry-date    { width: 50% }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-list-entry .pretix-widget-event-list-entry-availability { width: 50% }

.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-calendar-events {
    display: none;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-week-table .pretix-widget-event-calendar-events {
    display: block;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar td.pretix-widget-has-events .pretix-widget-event-calendar-day {
    background: var(--status-bg-color, var(--ldv-glass-04));
    color: var(--status-text-color, var(--ldv-text));
    border: 1px solid var(--status-border-color, var(--ldv-border-medium));
    border-top-width: 10px;
    padding-bottom: 6px;
    border-radius: 10px;
    cursor: pointer;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-calendar-head { display: block }
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-calendar-head strong {
    width: 100%;
    display: block;
}
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-calendar-head .pretix-widget-event-calendar-next-month,
.pretix-widget.pretix-widget-mobile .pretix-widget-event-calendar .pretix-widget-event-calendar-head .pretix-widget-event-calendar-previous-month {
    display: block;
    width: 100%;
    text-align: center;
}

@media (max-width: 800px) {
    .pretix-widget-frame-inner {
        width: calc(100vw - 50px);
        height: calc(100vh - 50px);
    }
}

@media (max-width: 480px) {
    .pretix-widget-alert-holder,
    .pretix-widget-frame-holder:not(.pretix-widget-frame-isloading),
    .pretix-widget-lightbox-holder:not(.pretix-widget-lightbox-isloading) {
        margin: 0;
        padding: 0;
        width: 100%;
        max-width: 100vw;
    }
    .pretix-widget-frame-inner,
    .pretix-widget-lightbox-inner,
    .pretix-widget-alert-box {
        width: 100%;
        height: 100vh;
        border-radius: 0;
        box-shadow: none;
        box-sizing: border-box;
        padding: 40px 0 0;
        background: var(--ldv-bg);
        border: none;
    }
    .pretix-widget-frame-close,
    .pretix-widget-lightbox-close {
        top: 8px;
        right: 12px;
    }
    .pretix-widget-frame-close button,
    .pretix-widget-lightbox-close button {
        background-color: #ffffff;
    }
    .pretix-widget-frame-close button path,
    .pretix-widget-lightbox-close button path {
        fill: #000000 !important;
    }
    .pretix-widget-frame-close button:focus,
    .pretix-widget-lightbox-close button:focus {
        outline-color: var(--ldv-text);
    }
}
