:root {
    --color-bg: #f0f2f5;
    --color-green: #4CAF50;
    --dm-card: #1e1e3a;
    --dm-text: #e0e0e0;
    --dm-text2: #b0b0c8;
    --dm-bg: #13132a;
    --dm-bg2: #1a1a3a;
    --dm-border: #3a3a5a;
    --dm-input-bg: #0f0f2a;
    --dm-input-border: #3a3a5a;
}
body.checkout-page, body.storno-page { font-family: Arial, sans-serif; background-color: #f4f4f4; padding: 0 !important; margin: 0; padding-top: 0 !important; }
body.checkout-page input, body.storno-page input, body.checkout-page select, body.storno-page textarea { min-height: 44px; }
.checkout-container { background: white; max-width: 600px; margin: 20px auto; padding: 30px; border-radius: 10px; box-shadow: 0 4px 8px rgba(0,0,0,0.1); text-align: center; }
.success-text { color: #4CAF50; font-size: 1.5em; margin-bottom: 10px; font-weight: bold; }
.pity-text { color: #d9534f; font-size: 1.5em; font-weight: bold; margin-bottom: 20px; }
.checkout-info-box { background-color: #e9ecef; padding: 15px; border-radius: 5px; margin: 20px 0; text-align: left; }
.bank-details { font-family: monospace; font-size: 1.1em; background: #f8f9fa; padding: 15px; border: 1px solid #ddd; text-align: left; word-break: break-all; overflow-wrap: break-word; }
.qr-code { margin: 20px 0; padding: 10px; border: 2px dashed #4CAF50; display: inline-block; }
.checkout-warning { color: #d9534f; font-weight: bold; font-size: 0.9em; margin-top: 15px; }

.storno-page { font-family: 'Segoe UI', Arial, sans-serif; background-color: #f0f2f5; margin: 0; padding: 0; text-align: center; color: #333; }
.storno-page .container { background: white; max-width: 600px; margin: 40px auto; padding: 30px; border-radius: 15px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); border-top: 6px solid #2e7d32; text-align: left; }
.storno-header { text-align: center; margin-bottom: 30px; }
.storno-header h2 { color: #1b5e20; margin-bottom: 15px; }
.storno-header p { font-size: 0.95em; color: #666; line-height: 1.5; background: #f9f9f9; padding: 15px; border-radius: 10px; }
.storno-page label { font-weight: bold; display: block; margin-top: 15px; color: #333; }
.storno-page input[type="email"], .storno-page input[type="text"], .storno-page select { width: 100%; padding: 12px; margin-top: 8px; border: 1px solid #ddd; border-radius: 6px; box-sizing: border-box; font-size: 1.1em; }
.storno-input { text-align: center; letter-spacing: 2px; }
.storno-page .btn { display: block; width: 100%; text-align: center; padding: 14px; border: none; border-radius: 8px; font-size: 1.1em; font-weight: bold; cursor: pointer; text-decoration: none; transition: background 0.3s; margin-top: 20px; box-sizing: border-box; }
.storno-page .btn-green { background: #4CAF50; color: white; }
.storno-page .btn-green:hover { background: #388E3C; }
.storno-page .btn-red { background: #d9534f; color: white; }
.storno-page .btn-red:hover { background: #c9302c; }
.btn-green-storno { background: #2e7d32; color: white; }
.btn-green-storno:hover { background: #1b5e20; }
.btn-red-storno { background: #d32f2f; color: white; border: none; padding: 14px; width: 100%; border-radius: 8px; font-weight: bold; cursor: pointer; transition: background 0.3s; }
.btn-red-storno:hover { background: #b71c1c; }
.btn-gray-storno { background: transparent; color: #666; border: 1px solid #ccc; width: auto; display: inline-block; padding: 10px 20px; font-size: 0.95em; margin-top: 0; }
.ticket-info { background: #f4f7f4; border: 1px solid #d0d8d0; padding: 20px; border-radius: 10px; margin-top: 20px; display: flex; justify-content: space-between; align-items: flex-start; gap: 15px; flex-wrap: wrap; }
.info-left { flex: 1; min-width: 250px; }
.storno-badge { padding: 4px 10px; border-radius: 12px; font-size: 0.85em; font-weight: bold; color: white; margin-top: 5px; display: inline-block; }
.bg-s-offen { background: #f0ad4e; }
.bg-s-bezahlt { background: #2e7d32; }
.bg-s-storniert { background: #d32f2f; }
.bg-s-guthaben { background: #0275d8; }
.ticket-row { padding: 12px; border-bottom: 1px solid #eee; display: flex; align-items: center; gap: 12px; }
.ticket-row:last-child { border-bottom: none; }
.ticket-row input[type="checkbox"] { width: 24px; height: 24px; cursor: pointer; margin: 10px; flex-shrink: 0; }
.code-locked { color: #888; font-style: italic; font-size: 0.9em; background: #f0f0f0; padding: 2px 6px; border-radius: 4px; }
.payment-box { background: white; border: 1px dashed #2e7d32; padding: 12px; border-radius: 8px; width: 190px; text-align: center; font-size: 0.8em; box-shadow: 0 4px 10px rgba(0,0,0,0.05); flex-shrink: 0; }
.qr-trigger { width: 70px; height: 70px; margin: 8px auto; cursor: pointer; border: 1px solid #eee; display: block; transition: transform 0.2s; border-radius: 5px; }
.qr-trigger:hover { transform: scale(1.1); }
.qr-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); align-items: center; justify-content: center; }
.qr-modal-content { background: white; padding: 20px; border-radius: 15px; text-align: center; max-width: 320px; box-shadow: 0 10px 40px rgba(0,0,0,0.5); }
.qr-modal-content img { width: 100%; height: auto; margin-bottom: 10px; border-radius: 10px; }
.btn-close-qr { background: #2e7d32; color: white; border: none; padding: 10px 20px; border-radius: 6px; cursor: pointer; font-weight: bold; width: 100%; margin-top: 10px; }
@media (max-width: 550px) { .ticket-info { flex-direction: column; } .payment-box { width: 100%; margin-top: 10px; } }
#purposeCode { cursor: pointer; transition: background 0.2s; }
#purposeCode:active { background: #d0d0d0; }

.verkauf-gestoppt { background: #fff3cd; border: 2px solid #ffc107; padding: 20px; border-radius: 10px; margin: 20px 0; text-align: center; }

/* === FE-NAV (Frontend Navbar) === */
.fe-nav { display: flex; align-items: center; height: 52px; padding: 0 16px; background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.07); overflow: visible; -webkit-overflow-scrolling: touch; position: sticky; top: 0; z-index: 1000; text-align: left; }
.fe-nav-toggle { display: none; background: none; border: none; font-size: 1.5em; cursor: pointer; padding: 4px 8px; color: #333; flex-shrink: 0; }
.fe-nav-links { display: flex; align-items: center; gap: 2px; flex: 1; min-width: 0; overflow: hidden; text-align: left; }
.fe-nav-home { display: inline-flex; align-items: center; justify-content: center; font-size: 1.2em; text-decoration: none; flex-shrink: 0; margin-right: 8px; color: #333; transition: opacity 0.15s; }
.fe-nav-home--brand { width: 34px; height: 34px; border-radius: 50%; background: var(--brand); color: #fff; font-size: 1.05em; position: relative; }
.fe-nav-home:hover { opacity: 0.7; }
.fe-nav-home--brand[data-tip]:hover::after { content: attr(data-tip); position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%); background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; padding: 5px 10px; font-size: 11px; font-weight: 500; color: #444; white-space: nowrap; box-shadow: 0 4px 12px rgba(0,0,0,0.12); z-index: 2000; pointer-events: none; }
.fe-nav-brand { font-weight: 700; font-size: 0.92em; color: #333; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 150px; flex-shrink: 0; }
@media(min-width:768px){.fe-nav-brand{max-width:260px}}
@media(max-width:600px){.fe-nav{gap:0;padding:0 8px}.fe-nav-toggle{display:block}.fe-nav-links{display:none;flex-direction:column;position:absolute;top:52px;left:0;right:0;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,0.15);z-index:999;padding:6px 0;max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.fe-nav-links.open{display:flex}.fe-nav-brand{max-width:80px;font-size:0.82em}.fe-nav-sep{margin:0 2px}.fe-nav-link{padding:5px 6px;font-size:0.75em}.fe-nav-btn{padding:6px 10px;font-size:0.82em;min-height:34px}.fe-nav-home--brand{width:30px;height:30px;font-size:0.95em;margin-right:4px}}
@media(max-width:400px){.fe-nav-brand{display:none}}
.fe-nav-sep { color: #ccc; margin: 0 4px; flex-shrink: 0; user-select: none; }
.fe-nav-link { display: inline-flex; align-items: center; padding: 5px 10px; border-radius: 16px; font-size: 0.82em; color: #555; text-decoration: none; white-space: nowrap; transition: all 0.15s; flex-shrink: 0; }
.fe-nav-link:hover { background: color-mix(in srgb, var(--brand) 12%, white); color: var(--brand); }
.fe-nav-link.active { background: var(--brand); color: #fff; font-weight: 600; }
.fe-nav-dd { position: relative; }
.fe-nav-dd-menu { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); min-width: 180px; max-width: 280px; max-height: 50vh; overflow-y: auto; -webkit-overflow-scrolling: touch; background: #fff; border: 1px solid #e0e0e0; border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.13); z-index: 2000; padding: 6px 0; }
.fe-nav-dd:hover .fe-nav-dd-menu, .fe-nav-dd:focus-within .fe-nav-dd-menu, .fe-nav-dd-menu:hover { display: block; }
.fe-nav-dd-item { display: block; padding: 10px 14px; color: #444; text-decoration: none; font-size: 0.82em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background 0.1s; min-height: 34px; }
.fe-nav-dd-item:hover { background: color-mix(in srgb, var(--brand) 10%, white); color: var(--brand); }
.fe-nav-spacer { flex: 1; min-width: 8px; }
.fe-nav-right { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.fe-nav-btn { background: none; border: 1px solid #e8e8e8; border-radius: 16px; padding: 4px 10px; cursor: pointer; font-size: 0.8em; display: inline-flex; align-items: center; gap: 3px; text-decoration: none; color: #666; transition: all 0.15s; position: relative; font-family: inherit; white-space: nowrap; flex-shrink: 0; }
.fe-nav-btn:hover { background: var(--brand); color: #fff; border-color: var(--brand); }
.fe-nav-btn .cart-badge { position: absolute; top: -5px; right: -5px; background: #dc3545; color: #fff; border-radius: 50%; min-width: 15px; height: 15px; font-size: 9px; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; }
.fe-nav-btn[data-tip]:hover::after { content: attr(data-tip); position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%); background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; padding: 5px 10px; font-size: 11px; font-weight: 500; color: #444; white-space: nowrap; box-shadow: 0 4px 12px rgba(0,0,0,0.12); z-index: 2000; pointer-events: none; }
/* Dark Mode fe-nav */
[data-theme="dark"] .fe-nav { background: #1a1a2e !important; box-shadow: 0 1px 4px rgba(0,0,0,0.4) !important; }
[data-theme="dark"] .fe-nav-toggle { color: #e0e0e0 !important; }
[data-theme="dark"] .fe-nav-brand { color: #e0e0e0 !important; }
[data-theme="dark"] .fe-nav-home { color: #e0e0e0; }
[data-theme="dark"] .fe-nav-home--brand { opacity: 0.9; }
[data-theme="dark"] .fe-nav-sep { color: #3a3a5a !important; }
[data-theme="dark"] .fe-nav-link { color: #a0a0c0 !important; }
[data-theme="dark"] .fe-nav-link:hover { background: color-mix(in srgb, var(--brand) 20%, #2a2a4a) !important; }
[data-theme="dark"] .fe-nav-link.active { background: var(--brand) !important; color: #fff !important; }
[data-theme="dark"] .fe-nav-dd-menu { background: #1e1e3a !important; border-color: #3a3a5a !important; box-shadow: 0 8px 24px rgba(0,0,0,0.4) !important; }
[data-theme="dark"] .fe-nav-dd-item { color: #c0c0e0 !important; }
[data-theme="dark"] .fe-nav-dd-item:hover { background: color-mix(in srgb, var(--brand) 15%, #2a2a4a) !important; color: var(--brand) !important; }
[data-theme="dark"] .fe-nav-btn { background: #2a2a4a !important; border-color: #3a3a5a !important; color: #a0a0c0 !important; }
[data-theme="dark"] .fe-nav-btn:hover { background: var(--brand) !important; color: #fff !important; border-color: var(--brand) !important; }
[data-theme="dark"] .fe-nav-btn[data-tip]:hover::after { background: #1e1e3a !important; border-color: #3a3a5a !important; color: #c0c0e0 !important; }

[data-theme="dark"] body.checkout-page, [data-theme="dark"] body.storno-page { background-color: #0d0d1a !important; color: #e0e0e0 !important; }
[data-theme="dark"] .checkout-container, [data-theme="dark"] .shop-container { background: var(--dm-card) !important; color: var(--dm-text) !important; }
[data-theme="dark"] .checkout-info-box { background: var(--dm-bg) !important; border-color: var(--dm-border) !important; }
[data-theme="dark"] .bank-details { background: var(--dm-bg) !important; border-color: var(--dm-border) !important; }
[data-theme="dark"] .success-text { color: #4caf50 !important; }
[data-theme="dark"] .pity-text { color: #f8d7da !important; }
[data-theme="dark"] .qr-code { border-color: #4caf50 !important; }
[data-theme="dark"] body.checkout-page a, [data-theme="dark"] body.storno-page a { color: #5dade2 !important; }
[data-theme="dark"] .verkauf-gestoppt { background: #3a3210 !important; border-color: #ffc107 !important; color: #ffc107 !important; }
[data-theme="dark"] .storno-page .container { background: var(--dm-card) !important; color: var(--dm-text) !important; }
[data-theme="dark"] .storno-page input, [data-theme="dark"] .storno-page select { background: var(--dm-input-bg) !important; color: var(--dm-text) !important; border-color: var(--dm-input-border) !important; }
[data-theme="dark"] .storno-header h2 { color: #6fcf6f !important; }
[data-theme="dark"] .storno-header p { background: var(--dm-bg) !important; color: var(--dm-text2) !important; }
[data-theme="dark"] .ticket-info { background: var(--dm-bg) !important; }
[data-theme="dark"] .payment-box { background: var(--dm-bg) !important; }
[data-theme="dark"] .qr-modal-content { background: var(--dm-card) !important; }
[data-theme="dark"] .code-locked { background: var(--dm-bg) !important; color: var(--dm-text2) !important; }
[data-theme="dark"] .checkout-warning { color: #ef5350 !important; }
[data-theme="dark"] .storno-page input, [data-theme="dark"] .storno-page select { background: var(--dm-input-bg) !important; color: var(--dm-text) !important; border-color: var(--dm-input-border) !important; }