/* =============================================================================
   Elysium Concerts – main.css
   Mobile-first, CSS @layer, Design Tokens via Custom Properties
   ============================================================================= */

/* ── Self-hosted Fonts ──────────────────────────────────────────────────────── */

@font-face {
    font-family: 'Cormorant SC';
    src: url('../fonts/CormorantSC-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Cormorant SC';
    src: url('../fonts/CormorantSC-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Cormorant SC';
    src: url('../fonts/CormorantSC-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Quicksand';
    src: url('../fonts/Quicksand-Variable.woff2') format('woff2-variations');
    font-weight: 300 700;
    font-style: normal;
    font-display: swap;
}

@layer base, typography, layout, components, templates, utilities;

/* =============================================================================
   @layer base – Reset, Box-Model, Design Tokens
   ============================================================================= */

@layer base {

    /* ── Design Tokens ────────────────────────────────────────────────────────
       CORPORATE DESIGN: Alle Farben und Schriften hier anpassen.
       Keine anderen CSS-Dateien müssen geändert werden.
       ─────────────────────────────────────────────────────────────────────── */
    :root {
        /* Farben – Corporate Design Elysium Concerts */
        --color-brand-primary:     #005567;
        --color-brand-secondary:   #986214;
        --color-brand-accent:      #c9a878;
        --color-surface-base:      #fafafa;
        --color-surface-alt:       #f1ebeb;
        --color-surface-dark:      #005567;
        --color-text-primary:      #1a1a1a;
        --color-text-secondary:    #5a5a5a;
        --color-text-inverse:      #ffffff;
        --color-text-muted:        #8a8a8a;
        --color-border:            #ddd5d5;
        --color-border-strong:     #c0b0b0;
        --color-focus:             #986214;
        --color-error:             #c0392b;
        --color-success:           #27ae60;

        /* Schriften – Corporate Design Elysium Concerts */
        --font-family-heading: 'Cormorant SC', Georgia, 'Times New Roman', serif;
        --font-family-body:    'Quicksand', system-ui, -apple-system, Helvetica, Arial, sans-serif;

        /* Schriftgrößen */
        --font-size-xs:   0.75rem;
        --font-size-sm:   0.875rem;
        --font-size-base: 1rem;
        --font-size-md:   1.125rem;
        --font-size-lg:   1.25rem;
        --font-size-xl:   1.5rem;
        --font-size-2xl:  2rem;
        --font-size-3xl:  2.5rem;
        --font-size-4xl:  3.5rem;
        --font-size-5xl:  clamp(2.5rem, 6vw, 4.5rem);

        /* Schriftgewichte */
        --font-weight-regular:  400;
        --font-weight-medium:   500;
        --font-weight-semibold: 600;
        --font-weight-bold:     700;

        /* Zeilenhöhen */
        --line-height-tight: 1.2;
        --line-height-snug:  1.35;
        --line-height-base:  1.65;
        --line-height-loose: 1.85;

        /* Buchstabenabstand */
        --letter-spacing-tight:  -0.02em;
        --letter-spacing-normal: 0;
        --letter-spacing-wide:   0.05em;
        --letter-spacing-wider:  0.12em;

        /* Abstände */
        --space-1:  0.25rem;
        --space-2:  0.5rem;
        --space-3:  0.75rem;
        --space-4:  1rem;
        --space-5:  1.25rem;
        --space-6:  1.5rem;
        --space-8:  2rem;
        --space-10: 2.5rem;
        --space-12: 3rem;
        --space-16: 4rem;
        --space-20: 5rem;
        --space-24: 6rem;
        --space-32: 8rem;

        /* Layout */
        --container-max:      1280px;
        --container-narrow:   720px;
        --container-wide:     1440px;
        --container-padding:  var(--space-5);

        /* Rahmen */
        --border-radius-sm:   4px;
        --border-radius-md:   8px;
        --border-radius-lg:   16px;
        --border-radius-full: 9999px;

        /* Schatten */
        --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
        --shadow-md: 0 4px 12px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.06);
        --shadow-lg: 0 16px 40px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.08);

        /* Übergänge */
        --transition-fast:   150ms ease;
        --transition-base:   250ms ease;
        --transition-slow:   400ms ease;

        /* Z-Index */
        --z-raised:   10;
        --z-dropdown: 100;
        --z-sticky:   200;
        --z-overlay:  300;
        --z-modal:    400;
    }

    @media (min-width: 600px) {
        :root { --container-padding: var(--space-8); }
    }

    @media (min-width: 960px) {
        :root { --container-padding: var(--space-12); }
    }

    /* ── Box-Model Reset ────────────────────────────────────────────────────── */
    *,
    *::before,
    *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }

    html {
        scroll-behavior: smooth;
        -webkit-text-size-adjust: 100%;
        text-size-adjust: 100%;
    }

    body {
        font-family: var(--font-family-body);
        font-size: var(--font-size-base);
        line-height: var(--line-height-base);
        overflow-x: clip;
        color: var(--color-text-primary);
        background-color: var(--color-surface-base);
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    img,
    picture,
    video,
    canvas,
    svg {
        display: block;
        max-width: 100%;
        height: auto;
    }

    input,
    button,
    textarea,
    select {
        font: inherit;
    }

    a {
        color: inherit;
        text-decoration-color: currentColor;
    }

    ul,
    ol {
        list-style: none;
    }

    /* Fokus-Sichtbarkeit */
    :focus-visible {
        outline: 2px solid var(--color-focus);
        outline-offset: 3px;
    }

    /* Reduced Motion */
    @media (prefers-reduced-motion: reduce) {
        *,
        *::before,
        *::after {
            animation-duration: 0.01ms !important;
            animation-iteration-count: 1 !important;
            transition-duration: 0.01ms !important;
            scroll-behavior: auto !important;
        }
    }
}

/* =============================================================================
   @layer typography
   ============================================================================= */

@layer typography {

    h1, h2, h3, h4, h5, h6 {
        font-family: var(--font-family-heading);
        font-weight: var(--font-weight-bold);
        line-height: var(--line-height-tight);
        letter-spacing: var(--letter-spacing-tight);
        color: var(--color-text-primary);
    }

    h1 { font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-4xl)); }
    h2 { font-size: clamp(var(--font-size-xl), 3.5vw, var(--font-size-3xl)); }
    h3 { font-size: clamp(var(--font-size-lg), 2.5vw, var(--font-size-2xl)); }
    h4 { font-size: var(--font-size-xl); }
    h5 { font-size: var(--font-size-lg); }
    h6 { font-size: var(--font-size-md); }

    p {
        max-width: 70ch;
        line-height: var(--line-height-base);
    }

    a:hover {
        text-decoration: underline;
    }

    strong, b { font-weight: var(--font-weight-semibold); }
    em, i     { font-style: italic; }

    /* Prose-Klasse: Lauftext-Inhalt (the_content) */
    .prose {
        max-width: 70ch;
    }

    .prose > * + * {
        margin-top: var(--space-6);
    }

    .prose h2,
    .prose h3,
    .prose h4,
    .prose h5,
    .prose h6 {
        margin-top: var(--space-10);
        color: var(--color-brand-primary);
    }

    .prose iframe,
    .prose .wp-block-embed__wrapper iframe {
        border-radius: var(--border-radius-md);
    }

    .prose .wp-block-embed {
        border-radius: var(--border-radius-md);
        overflow: hidden;
    }

    .prose ul,
    .prose ol {
        list-style: revert;
        padding-left: var(--space-6);
    }

    .prose li + li {
        margin-top: var(--space-2);
    }

    .prose a {
        color: var(--color-brand-secondary);
        text-decoration: underline;
        text-underline-offset: 3px;
    }

    .prose a:hover {
        color: var(--color-brand-primary);
    }

    .prose blockquote {
        border-left: 3px solid var(--color-brand-secondary);
        padding-left: var(--space-6);
        font-style: italic;
        color: var(--color-text-secondary);
    }

    .prose--wide {
        max-width: 85ch;
    }

    /* Seitentitel */
    .page-title {
        font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-4xl));
        margin-bottom: var(--space-4);
        color: var(--color-brand-primary);
    }
}

/* =============================================================================
   @layer layout
   ============================================================================= */

@layer layout {

    /* Container */
    .container {
        width: 100%;
        max-width: var(--container-max);
        margin-inline: auto;
        padding-inline: var(--container-padding);
    }

    .container--narrow {
        max-width: var(--container-narrow);
    }

    .container--wide {
        max-width: var(--container-wide);
    }

    /* Stack – Vertikales Spacing zwischen Kindelementen */
    .stack > * + * {
        margin-top: var(--space-6);
    }

    .stack--lg > * + * {
        margin-top: var(--space-12);
    }

    /* Grid */
    .grid-2 {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    @media (min-width: 600px) {
        .grid-2 { grid-template-columns: repeat(2, 1fr); }
    }

    /* Main */
    .main {
        min-height: 60vh;
    }

    /* Page Header */
    .page-header {
        padding-block: var(--space-6) var(--space-4);
        border-bottom: 1px solid var(--color-border);
        margin-bottom: var(--space-8);
    }

    .page-header--centered {
        text-align: center;
        border-bottom: none;
    }

    .page-description {
        max-width: 70ch;
        margin-inline: auto;
        margin-top: var(--space-4);
        font-size: var(--font-size-md);
        color: var(--color-text-secondary);
        text-align: center;
        line-height: var(--line-height-base);
    }
}

/* =============================================================================
   @layer components
   ============================================================================= */

@layer components {

    /* ── Buttons ─────────────────────────────────────────────────────────── */
    .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: var(--space-2);
        padding: var(--space-3) var(--space-6);
        font-family: var(--font-family-body);
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
        text-decoration: none;
        border: 2px solid transparent;
        border-radius: var(--border-radius-sm);
        cursor: pointer;
        transition: background-color var(--transition-fast),
                    color var(--transition-fast),
                    border-color var(--transition-fast),
                    box-shadow var(--transition-fast);
        white-space: nowrap;
    }

    .btn--primary {
        background-color: var(--color-brand-secondary);
        color: #fff;
        border-color: var(--color-brand-secondary);
    }

    .btn--primary:hover {
        background-color: var(--color-brand-primary);
        color: var(--color-text-inverse);
        border-color: var(--color-brand-primary);
        text-decoration: none;
    }

    .btn--secondary {
        background-color: var(--color-brand-primary);
        color: #fff;
        border-color: var(--color-brand-primary);
    }

    .btn--secondary:hover {
        background-color: var(--color-brand-secondary);
        color: #fff;
        border-color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .btn--on-dark {
        background-color: #fff;
        color: var(--color-brand-primary);
        border-color: #fff;
    }

    .btn--on-dark:hover {
        background-color: transparent;
        color: #fff;
        border-color: #fff;
        text-decoration: none;
    }

    .btn--small {
        padding: var(--space-2) var(--space-4);
        font-size: var(--font-size-xs);
    }

    .btn--large {
        padding: var(--space-5) var(--space-10);
        font-size: var(--font-size-md);
    }

    .btn--full {
        width: 100%;
    }

    /* ── Site Header ─────────────────────────────────────────────────────── */
    .site-header {
        position: sticky;
        top: 0;
        z-index: var(--z-sticky);
        background-color: var(--color-surface-base);
        border-bottom: 1px solid var(--color-border);
        padding-block: var(--space-4);
    }

    .site-header__inner {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-6);
    }

    .site-header__brand a,
    .site-header__name {
        font-family: var(--font-family-heading);
        font-size: var(--font-size-lg);
        font-weight: var(--font-weight-bold);
        text-decoration: none;
        letter-spacing: var(--letter-spacing-tight);
    }

    .site-header__brand img,
    .site-header__logo-link svg,
    .site-header__logo-link img {
        height: 48px;
        width: auto;
        display: block;
    }

    .site-header__logo-link {
        display: flex;
        align-items: center;
        text-decoration: none;
    }

    .site-header__logo-link svg {
        /* SVG-Farben aus dem Logo werden beibehalten */
    }

    /* ── Announcement-Banner ─────────────────────────────────────────────── */
    .announcement-banner {
        width: 100%;
        padding-block: 0.5rem;
        text-align: center;
        font-size: var(--font-size-sm);
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: var(--font-weight-normal);
        letter-spacing: 0.02em;
        line-height: var(--line-height-snug);
        position: relative;
        z-index: 101;
        background: linear-gradient(135deg, var(--color-brand-primary) 0%, var(--color-brand-secondary) 100%);
        color: #fff;
        transition: opacity 0.3s ease;
    }

    .announcement-banner.is-hidden {
        opacity: 0;
        pointer-events: none;
    }

    .announcement-banner__inner {
        flex: 1;
        max-width: var(--container-max);
        margin-inline: auto;
        padding-inline: var(--container-padding);
    }

    .announcement-banner__link {
        color: inherit;
        text-decoration: none;
        display: inline;
        transition: opacity 0.2s;
    }

    .announcement-banner__cta {
        text-decoration: underline;
        margin-left: 0.5em;
        font-weight: var(--font-weight-semibold);
    }

    .announcement-banner__link:hover { opacity: 0.8; }
    .announcement-banner__text { margin: 0; max-width: none; }

    .announcement-banner__close {
        position: absolute;
        right: var(--container-padding);
        top: 50%;
        transform: translateY(-50%);
        background: none;
        border: none;
        color: inherit;
        cursor: pointer;
        padding: 0.25rem;
        opacity: 0.7;
        transition: opacity 0.2s;
    }

    .announcement-banner__close:hover { opacity: 1; }

    /* ── Navigation ──────────────────────────────────────────────────────── */
    .site-nav {
        display: none;
    }

    @media (min-width: 1160px) {
        .site-nav {
            display: block;
        }
    }

    .nav-menu {
        display: flex;
        gap: var(--space-6);
        align-items: center;
    }

    @media (min-width: 1280px) {
        .nav-menu { gap: var(--space-8); }
    }

    .nav-menu a {
        position: relative;
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-medium);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
        color: var(--color-text-muted);
        text-decoration: none;
        padding-block: var(--space-2);
        white-space: nowrap;
        transition: color var(--transition-fast);
    }

    .nav-menu a::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 2px;
        background-color: var(--color-brand-secondary);
        transform: scaleX(0);
        transform-origin: left center;
        transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .nav-menu a:hover {
        color: var(--color-brand-primary);
    }

    .nav-menu a:hover::after {
        transform: scaleX(1);
    }

    /* ── Tickets Button in Nav ───────────────────────────────────────────── */
    .nav-tickets {
        display: none;
        flex-shrink: 0;
    }

    @media (min-width: 1160px) {
        .nav-tickets { display: inline-flex; }
    }

    /* ── Hamburger-Toggle ────────────────────────────────────────────────── */
    .nav-toggle {
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 5px;
        width: 32px;
        height: 32px;
        background: none;
        border: none;
        cursor: pointer;
        padding: 2px;
        position: relative;
        z-index: calc(var(--z-modal) + 1);
    }

    @media (min-width: 1160px) {
        .nav-toggle { display: none; }
    }

    .nav-toggle__bar {
        display: block;
        width: 100%;
        height: 2px;
        background-color: var(--color-text-primary);
        border-radius: var(--border-radius-full);
        transition: transform var(--transition-fast), opacity var(--transition-fast);
    }

    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
        opacity: 0;
    }

    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    /* Mobile Nav Open State */
    .site-nav.is-open {
        display: flex;
        flex-direction: column;
        align-items: center;
        position: fixed;
        inset: 0;
        top: 0;
        background-color: var(--color-surface-base);
        padding: calc(73px + var(--space-8)) var(--container-padding) var(--space-8);
        overflow-y: auto;
        z-index: var(--z-modal);
    }

    .site-nav.is-open .nav-menu {
        flex-direction: column;
        align-items: center;
        gap: var(--space-6);
    }

    .site-nav.is-open .nav-menu a {
        font-size: var(--font-size-xl);
    }

    /* ── Site Footer ─────────────────────────────────────────────────────── */
    .site-footer {
        background-color: var(--color-surface-dark);
        color: var(--color-text-inverse);
        padding-block: var(--space-16) var(--space-8);
    }

    .site-footer__inner {
        display: grid;
        gap: var(--space-10);
        text-align: center;
        justify-items: center;
    }

    @media (min-width: 600px) {
        .site-footer__inner {
            grid-template-columns: 1fr 1fr;
        }
    }

    @media (min-width: 960px) {
        .site-footer__inner {
            grid-template-columns: 2fr 1fr 1fr;
            align-items: start;
            text-align: left;
            justify-items: start;
        }
    }

    .site-footer__name {
        font-family: var(--font-family-heading);
        font-size: var(--font-size-xl);
        display: block;
        margin-bottom: var(--space-4);
    }

    .site-footer__address {
        font-style: normal;
        display: flex;
        flex-direction: column;
        gap: var(--space-1);
        font-size: var(--font-size-sm);
        color: rgba(255,255,255,.7);
        margin-top: var(--space-4);
    }

    .site-footer__address a {
        color: var(--color-brand-accent);
        text-decoration: none;
    }

    .site-footer__address a:hover {
        text-decoration: underline;
    }

    .footer-nav {
        display: flex;
        flex-direction: column;
        gap: var(--space-3);
    }

    .footer-nav a {
        font-size: var(--font-size-sm);
        color: rgba(255,255,255,.7);
        text-decoration: none;
        transition: color var(--transition-fast);
    }

    .footer-nav a:hover {
        color: var(--color-text-inverse);
        text-decoration: none;
    }

    .site-footer__social {
        display: flex;
        gap: var(--space-4);
    }

    .social-link {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        border: 1px solid rgba(255,255,255,.3);
        border-radius: var(--border-radius-full);
        color: rgba(255,255,255,.7);
        text-decoration: none;
        transition: border-color var(--transition-fast), color var(--transition-fast);
    }

    .social-link svg {
        width: 20px;
        height: 20px;
    }

    .social-link:hover {
        border-color: var(--color-brand-secondary);
        color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .site-footer__copy {
        grid-column: 1 / -1;
        border-top: 1px solid rgba(255,255,255,.1);
        padding-top: var(--space-6);
        font-size: var(--font-size-sm);
        color: rgba(255,255,255,.5);
    }

    .site-footer__brand img,
    .site-footer__brand svg {
        height: 40px;
        width: auto;
        display: block;
        filter: brightness(0) invert(1);
        margin-bottom: var(--space-4);
    }

    /* ── Breadcrumb ──────────────────────────────────────────────────────── */
    .breadcrumb,
    .rank-math-breadcrumb {
        font-size: var(--font-size-sm);
        color: var(--color-text-muted);
        padding-block: var(--space-4);
        margin-bottom: var(--space-6);
    }

    .breadcrumb a,
    .rank-math-breadcrumb a {
        color: var(--color-text-muted);
        text-decoration: none;
    }

    .breadcrumb a:hover,
    .rank-math-breadcrumb a:hover {
        color: var(--color-brand-secondary);
        text-decoration: underline;
    }

    /* ── Konzert-Karte ───────────────────────────────────────────────────── */
    .konzerte-grid {
        display: grid;
        gap: var(--space-6);
    }

    @media (min-width: 600px) {
        .konzerte-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (min-width: 960px) {
        .konzerte-grid { grid-template-columns: repeat(3, 1fr); }
    }

    .konzert-card {
        position: relative;
        border-radius: var(--border-radius-lg);
        overflow: hidden;
        background-color: var(--color-surface-base);
        box-shadow: var(--shadow-sm);
        transition: box-shadow var(--transition-base), transform var(--transition-base);
        display: flex;
        flex-direction: column;
    }

    .konzert-card:hover {
        box-shadow: var(--shadow-md);
        transform: translateY(-2px);
    }

    .konzert-card--past {
        opacity: 0.7;
    }

    /* "Ausverkauft" Badge */
    .konzert-card__badge {
        position: absolute;
        top: var(--space-4);
        left: var(--space-4);
        z-index: 2;
        padding: var(--space-1) var(--space-3);
        background-color: #c0392b;
        color: #fff;
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        border-radius: var(--border-radius-sm);
        pointer-events: none;
    }

    .konzert-card__image-wrap {
        flex: 1 1 auto;
        aspect-ratio: 2/3;
        overflow: hidden;
        background-color: var(--color-surface-alt);
    }

    .konzert-card__image-wrap picture {
        display: block;
        width: 100%;
        height: 100%;
    }

    .konzert-card__image,
    .konzert-card__image-placeholder {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform var(--transition-slow);
        touch-action: pan-y;
        -webkit-user-drag: none;
        pointer-events: none;
    }


    .konzert-card__image-placeholder {
        background: linear-gradient(135deg, var(--color-brand-primary) 0%, var(--color-brand-secondary) 100%);
    }

    .konzert-card__link {
        display: flex;
        flex-direction: column;
        flex: 1;
        overflow: hidden;
        position: relative;
        touch-action: pan-y;
        -webkit-user-drag: none;
    }

    .konzert-card__body {
        position: absolute;
        bottom: 0;
        left: var(--space-4);
        right: var(--space-4);
        margin-bottom: var(--space-4);
        padding: var(--space-5) var(--space-5);
        background: rgba(255, 255, 255, 0.93);
        border-radius: var(--border-radius-md);
        display: flex;
        flex-direction: column;
        gap: var(--space-1);
        z-index: 1;
    }

    @media (min-width: 768px) {
        .konzert-card__body {
            background: rgba(255, 255, 255, 0.88);
            backdrop-filter: blur(4px);
            -webkit-backdrop-filter: blur(4px);
        }
    }

    .konzert-card__date {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-medium);
        color: var(--color-brand-secondary);
        display: flex;
        gap: var(--space-2);
        align-items: baseline;
        flex-wrap: wrap;
    }

    .konzert-card__time {
        font-weight: var(--font-weight-regular);
        color: var(--color-text-muted);
    }

    .konzert-card__title {
        font-size: var(--font-size-xl);
        line-height: var(--line-height-snug);
        color: var(--color-brand-primary);
    }

    .konzert-card__title a {
        text-decoration: none;
        color: var(--color-text-primary);
    }

    .konzert-card__title a:hover {
        color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .konzert-card__venue {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-regular);
        color: var(--color-text-secondary);
        display: flex;
        align-items: center;
        gap: 0.3em;
    }

    .konzert-card__excerpt {
        font-size: var(--font-size-sm);
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
    }

    .konzert-card__footer {
        display: none;
    }

    /* ── Konzerte Slider (Infinite Loop) ────────────────────────────────── */
    .konzerte-slider {
        position: relative;
        cursor: grab;
        touch-action: pan-y;
    }

    .konzerte-slider * {
        touch-action: pan-y;
    }

    .konzerte-slider__viewport {
        overflow: hidden;
        padding-block: var(--space-4);
        margin-block: calc(-1 * var(--space-4));
    }

    .konzerte-slider__track {
        display: flex;
        gap: var(--space-6);
        touch-action: pan-y;
        cursor: grab;
    }

    /* Kartenbreite wird als --slide-width per JS gesetzt */
    .konzerte-slider .konzert-card,
    .konzerte-slider .news-card {
        flex: 0 0 var(--slide-width, 300px);
        min-width: 0;
    }

    /* Pfeil-Buttons */
    .slider-btn {
        position: absolute;
        top: var(--slider-btn-top, 50%);
        transform: translateY(-50%);
        z-index: 2;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        border-radius: 50%;
        background: var(--color-surface-base);
        border: 1.5px solid var(--color-border);
        color: var(--color-text-base);
        cursor: pointer;
        padding: 0;
        box-shadow: 0 2px 10px rgba(0, 0, 0, .12);
        transition: background-color var(--transition-fast),
                    border-color var(--transition-fast),
                    color var(--transition-fast),
                    box-shadow var(--transition-fast);
    }

    .slider-btn:hover {
        background-color: var(--color-brand-primary);
        border-color: var(--color-brand-primary);
        color: #fff;
        box-shadow: 0 4px 16px rgba(0, 85, 103, .25);
    }

    .slider-btn svg {
        width: 18px;
        height: 18px;
        flex-shrink: 0;
    }

    .slider-btn--prev { left: -22px; }
    .slider-btn--next { right: -22px; }

    @media (max-width: 599px) {
        .slider-btn { width: 36px; height: 36px; }
        .slider-btn--prev { left: -14px; }
        .slider-btn--next { right: -14px; }
    }


    /* ── Künstler-Slider ────────────────────────────────────────────────── */
    .kuenstler-slider {
        position: relative;
        cursor: grab;
        touch-action: pan-y;
    }

    .kuenstler-slider * {
        touch-action: pan-y;
    }

    .kuenstler-slider__viewport {
        overflow: hidden;
        padding-block: var(--space-4);
        margin-block: calc(-1 * var(--space-4));
    }

    .kuenstler-slider__track {
        display: flex;
        gap: var(--space-6);
        touch-action: pan-y;
        cursor: grab;
    }

    .kuenstler-slider .kuenstler-card {
        flex: 0 0 var(--slide-width, 240px);
        min-width: 0;
    }

    /* ── Künstler-Karte ──────────────────────────────────────────────────── */
    .kuenstler-year-group {
        margin-bottom: var(--space-12);
    }

    .kuenstler-year-group__title {
        font-family: var(--font-heading);
        font-size: var(--text-3xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-6);
        padding-bottom: var(--space-3);
        border-bottom: 2px solid var(--color-border);
    }

    .kuenstler-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-6);
    }

    @media (min-width: 600px) {
        .kuenstler-grid { grid-template-columns: repeat(3, 1fr); }
    }

    @media (min-width: 960px) {
        .kuenstler-grid { grid-template-columns: repeat(4, 1fr); }
    }

    .kuenstler-card {
        display: block;
        border-radius: var(--border-radius-lg);
        overflow: hidden;
    }

    .kuenstler-card__link {
        display: block;
        text-decoration: none;
        touch-action: pan-y;
        -webkit-user-drag: none;
    }

    .kuenstler-card__image-wrap {
        position: relative;
        aspect-ratio: 4/5;
        background-color: var(--color-surface-alt);
    }

    .kuenstler-card__image,
    .kuenstler-card__image-placeholder {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: var(--img-position, center center);
        transition: transform var(--transition-slow);
        pointer-events: none;
        -webkit-user-drag: none;
    }

    .kuenstler-card__image-wrap picture {
        display: block;
        width: 100%;
        height: 100%;
    }

    .kuenstler-card__link:hover .kuenstler-card__image,
    .kuenstler-card__link:hover .kuenstler-card__image-placeholder {
        transform: scale(1.04);
    }

    .kuenstler-card__image-placeholder {
        background: linear-gradient(180deg, var(--color-surface-alt) 0%, var(--color-border) 100%);
    }

    /* Text-Overlay mit Verlauf am unteren Kartenrand */
    .kuenstler-card__overlay {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        padding: var(--space-16) var(--space-8) var(--space-8);
        background: linear-gradient(
            to top,
            rgba(0, 85, 103, 0.92) 0%,
            rgba(0, 85, 103, 0.55) 55%,
            transparent 100%
        );
        transform: translateY(88px);
        transition: transform 0.32s ease;
    }

    .kuenstler-card__link:hover .kuenstler-card__overlay {
        transform: translateY(0);
    }

    .kuenstler-card__name {
        font-size: var(--font-size-lg);
        line-height: var(--line-height-snug);
        color: #fff;
        text-shadow: 0 1px 6px rgba(0, 0, 0, .5);
        margin: 0;
    }

    .kuenstler-card__instrument {
        font-size: var(--font-size-sm);
        color: rgba(255, 255, 255, .78);
        margin-top: var(--space-1);
    }

    /* Details-Button – wird durch Overlay-Translation sichtbar */
    .kuenstler-card__hover-btn {
        display: inline-block;
        margin-top: var(--space-8);
        padding: 14px 32px;
        background: #fff;
        color: var(--color-text-primary);
        border: none;
        border-radius: 100px;
        font-family: var(--font-family-body);
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        line-height: 1;
    }

    /* Featured Künstler */
    .kuenstler-featured-grid {
        display: grid;
        gap: var(--space-8);
    }

    @media (min-width: 600px) {
        .kuenstler-featured-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (min-width: 960px) {
        .kuenstler-featured-grid { grid-template-columns: repeat(3, 1fr); }
    }

    .kuenstler-card--featured .kuenstler-card__image-wrap {
        aspect-ratio: 4/5;
    }

    .kuenstler-card--featured .kuenstler-card__name {
        font-size: var(--font-size-xl);
    }

    .kuenstler-card--featured .kuenstler-card__bio {
        font-size: var(--font-size-sm);
        color: var(--color-text-secondary);
        margin-top: var(--space-2);
        line-height: var(--line-height-base);
    }

    /* ── News-Karte ──────────────────────────────────────────────────────── */
    .news-grid {
        display: grid;
        gap: var(--space-8);
    }

    @media (min-width: 600px) {
        .news-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (min-width: 960px) {
        .news-grid { grid-template-columns: repeat(3, 1fr); }
    }

    .news-card {
        display: flex;
        flex-direction: column;
        touch-action: pan-y;
    }

    .news-card__link {
        display: block;
        text-decoration: none;
        color: inherit;
        touch-action: pan-y;
        -webkit-user-drag: none;
    }

    .news-card__link *,
    .news-card__body {
        touch-action: pan-y;
    }

    .news-card__image-wrap {
        display: block;
        overflow: hidden;
        border-radius: var(--border-radius-lg);
        margin-bottom: var(--space-4);
        touch-action: pan-y;
        -webkit-user-drag: none;
        aspect-ratio: 16/9;
        position: relative;
    }

    .news-card__image {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform var(--transition-slow);
        pointer-events: none;
        -webkit-user-drag: none;
    }

    .news-card__hover-overlay {
        position: absolute;
        inset: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(0, 85, 103, 0.55);
        color: #fff;
        font-family: var(--font-heading);
        font-size: var(--text-xl);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
        opacity: 0;
        transition: opacity var(--transition-base);
    }

    .news-card:hover .news-card__image {
        transform: scale(1.03);
    }

    .news-card:hover .news-card__hover-overlay {
        opacity: 1;
    }

    .news-card__body {
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
        flex: 1;
    }

    .news-card__date {
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        color: var(--color-text-muted);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
    }

    .news-card__title {
        font-size: var(--font-size-lg);
        line-height: var(--line-height-snug);
    }

    .news-card__title {
        color: var(--color-brand-primary);
    }

    .news-card__subtitle,
    .news-card__excerpt {
        font-size: var(--font-size-sm);
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /* ── Forms ───────────────────────────────────────────────────────────── */
    .form-field {
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
        margin-bottom: var(--space-6);
    }

    .form-label {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-medium);
        color: var(--color-text-primary);
    }

    .form-input,
    .form-textarea {
        width: 100%;
        padding: var(--space-3) var(--space-4);
        border: 1px solid var(--color-border);
        border-radius: var(--border-radius-sm);
        background-color: var(--color-surface-base);
        color: var(--color-text-primary);
        font-size: var(--font-size-base);
        transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    }

    .form-input:focus,
    .form-textarea:focus {
        outline: none;
        border-color: var(--color-brand-secondary);
        box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.2);
    }

    .form-textarea {
        resize: vertical;
        min-height: 140px;
    }

    .contact-form {
        max-width: 600px;
    }

    /* ── Cookie Banner ───────────────────────────────────────────────────── */
    .cookie-banner {
        position: fixed;
        bottom: var(--space-6);
        left: var(--space-6);
        right: var(--space-6);
        max-width: 560px;
        background-color: var(--color-surface-dark);
        color: var(--color-text-inverse);
        border-radius: var(--border-radius-md);
        box-shadow: var(--shadow-lg);
        z-index: var(--z-modal);
        padding: var(--space-6);
    }

    .cookie-banner[hidden] {
        display: none;
    }

    .cookie-banner__inner {
        display: flex;
        flex-direction: column;
        gap: var(--space-4);
    }

    @media (min-width: 600px) {
        .cookie-banner__inner {
            flex-direction: row;
            align-items: center;
            justify-content: space-between;
        }
    }

    .cookie-banner__title {
        font-size: var(--font-size-md);
        font-family: var(--font-family-heading);
    }

    .cookie-banner__desc {
        font-size: var(--font-size-sm);
        color: rgba(255,255,255,.75);
        margin-top: var(--space-1);
        max-width: none;
    }

    .cookie-banner__desc a {
        color: var(--color-brand-accent);
        text-decoration: underline;
    }

    /* ── Post Navigation ─────────────────────────────────────────────────── */
    .post-navigation {
        margin-top: var(--space-16);
        padding-top: var(--space-8);
        border-top: 1px solid var(--color-border);
    }

    .nav-links {
        display: grid;
        gap: var(--space-4);
    }

    @media (min-width: 600px) {
        .nav-links { grid-template-columns: repeat(2, 1fr); }
    }

    .nav-previous a,
    .nav-next a {
        display: flex;
        flex-direction: column;
        gap: var(--space-1);
        text-decoration: none;
        padding: var(--space-4);
        border: 1px solid var(--color-border);
        border-radius: var(--border-radius-sm);
        transition: border-color var(--transition-fast);
    }

    .nav-next a {
        text-align: right;
    }

    .nav-previous a:hover,
    .nav-next a:hover {
        border-color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .nav-direction {
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
        color: var(--color-text-muted);
    }

    .nav-title {
        font-family: var(--font-family-heading);
        font-size: var(--font-size-md);
        color: var(--color-text-primary);
    }

    /* ── Pagination ──────────────────────────────────────────────────────── */
    .nav-links.pagination {
        display: flex;
        gap: var(--space-2);
        flex-wrap: wrap;
        justify-content: center;
        margin-top: var(--space-12);
    }

    .page-numbers {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 40px;
        height: 40px;
        padding-inline: var(--space-3);
        border: 1px solid var(--color-border);
        border-radius: var(--border-radius-sm);
        font-size: var(--font-size-sm);
        text-decoration: none;
        transition: border-color var(--transition-fast), background-color var(--transition-fast);
    }

    .page-numbers.current,
    .page-numbers:hover {
        background-color: var(--color-brand-secondary);
        border-color: var(--color-brand-secondary);
        color: var(--color-brand-primary);
        text-decoration: none;
    }
}

/* =============================================================================
   @layer templates – Seitenspezifische Styles
   ============================================================================= */

@layer templates {

    /* ── Promo / Aktions-Section ─────────────────────────────────────────── */
    .promo-section {
        position: relative;
        background-color: var(--color-brand-secondary);
        color: #fff;
        padding-block: var(--space-16);
    }

    .promo-section__wave {
        position: absolute;
        left: 0;
        right: 0;
        height: clamp(48px, 6vw, 90px);
        pointer-events: none;
    }

    .promo-section__wave--top { top: -1px; }
    .promo-section__wave--bottom { bottom: -1px; }

    .promo-section__wave svg {
        display: block;
        width: 100%;
        height: 100%;
    }

    .promo-section__inner {
        display: grid;
        gap: var(--space-10);
        align-items: center;
        text-align: center;
    }

    @media (min-width: 960px) {
        .promo-section__inner--has-image {
            grid-template-columns: 1fr 1fr;
            text-align: left;
        }
    }

    .promo-section__image-wrap {
        border-radius: var(--border-radius-lg);
        overflow: hidden;
    }

    .promo-section__image {
        width: 100%;
        height: auto;
        display: block;
    }

    .promo-section__headline {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        line-height: var(--line-height-tight);
        color: #fff;
        margin-bottom: var(--space-4);
    }

    .promo-section__text {
        font-size: var(--font-size-md);
        line-height: var(--line-height-base);
        opacity: 0.92;
        max-width: 60ch;
    }

    .promo-section__inner:not(.promo-section__inner--has-image) .promo-section__text {
        margin-inline: auto;
    }

    .promo-section__text p + p { margin-top: var(--space-4); }
    .promo-section__text a { color: #fff; text-decoration: underline; }
    .promo-section__text strong { color: #fff; }

    .promo-section__btn {
        margin-top: var(--space-8);
        display: inline-block;
        background-color: #fff;
        color: var(--color-brand-secondary);
        border-color: #fff;
        font-weight: var(--font-weight-semibold);
    }

    .promo-section__btn:hover {
        background-color: transparent;
        color: #fff;
        border-color: #fff;
    }

    /* ── Homepage Hero ───────────────────────────────────────────────────── */
    .home-hero {
        position: relative;
        min-height: 90vh;
        display: flex;
        align-items: center;
        overflow: hidden;
        margin-bottom: -2px;
        background-color: var(--color-brand-primary);
    }

    .home-hero__bg {
        position: absolute;
        inset: 0;
    }

    .home-hero__bg::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, .12);
        z-index: 1;
    }

    .home-hero__bg-image,
    .home-hero__bg picture {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .home-hero__bg picture img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* ── Hero Slideshow ──────────────────────────────────────────────────── */
    .home-hero__slideshow {
        position: absolute;
        inset: 0;
        touch-action: pan-y;
    }

    .home-hero__slideshow::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, .12);
        z-index: 1;
    }

    .home-hero__slide {
        position: absolute;
        inset: 0;
        opacity: 0;
        transition: opacity 1.5s ease-in-out;
    }

    .home-hero__slide.is-active {
        opacity: 1;
    }

    .home-hero__slide-image,
    .home-hero__slide picture {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: var(--slide-position-mobile, var(--slide-position, center center));
        transform: scale(var(--slide-scale-mobile, var(--slide-scale, 1)));
    }

    .home-hero__slide picture img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: var(--slide-position-mobile, var(--slide-position, center center));
        transform: scale(var(--slide-scale-mobile, var(--slide-scale, 1)));
    }

    @media (min-width: 768px) {
        .home-hero__slide-image,
        .home-hero__slide picture,
        .home-hero__slide picture img {
            object-position: var(--slide-position, center center);
            transform: scale(var(--slide-scale, 1));
        }
    }

    .home-hero__overlay {
        position: relative;
        z-index: 2;
        width: 100%;
        padding-block: var(--space-20);
    }

    .home-hero__inner {
        display: flex;
        align-items: flex-start;
        justify-content: flex-start;
    }

    /* ── Hero – Nächstes Konzert Panel ──────────────────────────────────── */
    @keyframes hero-card-appear {
        from {
            opacity: 0;
            transform: translateY(20px) scale(0.94);
        }
        to {
            opacity: 1;
            transform: translateY(0) scale(1);
        }
    }


    .home-hero__concert {
        position: relative;
        display: flex;
        flex-direction: column;
        gap: var(--space-6);
        max-width: 480px;
        background: rgba(250, 248, 245, .72);
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
        padding: var(--space-8) var(--space-10);
        border-radius: var(--border-radius-lg);
        box-shadow: 0 8px 40px rgba(0, 0, 0, .20);
        animation: hero-card-appear 0.7s cubic-bezier(0.34, 1.4, 0.64, 1) 1.2s both;
        transition: opacity 0.3s ease, transform 0.3s ease;
    }

    .home-hero__concert.is-hidden {
        opacity: 0;
        transform: translateY(-8px);
        pointer-events: none;
    }

    .home-hero__concert.is-delayed {
        animation: none;
        opacity: 0;
        transform: translateY(16px);
        pointer-events: none;
    }

    .home-hero__concert.is-delayed.is-visible {
        animation: hero-card-appear 0.7s cubic-bezier(0.34, 1.4, 0.64, 1) both;
        pointer-events: auto;
    }

    .hero-concert__close {
        position: absolute;
        top: var(--space-3);
        right: var(--space-3);
        width: 32px;
        height: 32px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        color: var(--color-text-secondary);
        border-radius: 50%;
        transition: background var(--transition-fast), color var(--transition-fast);
    }

    .hero-concert__close:hover {
        background: rgba(0, 0, 0, .08);
        color: var(--color-text-primary);
    }

    .hero-concert__close svg {
        width: 16px;
        height: 16px;
    }

    /* "— NÄCHSTES KONZERT" Label */
    .hero-concert__label {
        display: flex;
        align-items: center;
        gap: var(--space-4);
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        color: var(--color-brand-secondary);
        max-width: none;
    }

    .hero-concert__label::before {
        content: '';
        display: block;
        width: 2rem;
        height: 1px;
        background-color: var(--color-brand-secondary);
        flex-shrink: 0;
    }

    /* Konzert-Titel – sehr groß, Serife */
    .hero-concert__title {
        font-family: var(--font-family-heading);
        font-size: clamp(1.8rem, 3.5vw, 2.8rem);
        font-weight: var(--font-weight-bold);
        line-height: 1;
        letter-spacing: var(--letter-spacing-tight);
        margin-bottom: 0;
        color: var(--color-brand-primary);
    }

    .hero-concert__title a {
        color: var(--color-brand-primary);
        text-decoration: none;
        transition: opacity var(--transition-fast);
    }

    .hero-concert__title a:hover {
        opacity: 0.85;
        text-decoration: none;
    }

    /* Kurzbeschreibung */
    .hero-concert__excerpt {
        display: block;
        font-size: var(--font-size-sm);
        color: var(--color-text-secondary);
        text-decoration: none;
        line-height: var(--line-height-base);
        max-width: 50ch;
    }

    .hero-concert__excerpt:hover {
        color: var(--color-brand-primary);
    }

    /* Meta: Datum + Ort */
    .hero-concert__meta {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-5) var(--space-8);
        color: var(--color-text-secondary);
        font-size: var(--font-size-sm);
    }

    .hero-concert__meta-item {
        display: flex;
        align-items: center;
        gap: var(--space-2);
        max-width: none;
    }

    .hero-concert__meta-icon {
        width: 18px;
        height: 18px;
        flex-shrink: 0;
        opacity: 0.75;
    }

    /* Buttons */
    .hero-concert__actions {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-4);
        margin-top: var(--space-2);
    }

    /* ── Hero Wave Divider ──────────────────────────────────────────────── */
    .home-hero__wave {
        position: absolute;
        bottom: -2px;
        left: 0;
        width: 100%;
        line-height: 0;
        z-index: 2;
        pointer-events: none;
    }

    .home-hero__wave svg {
        display: block;
        width: 100%;
        height: calc(clamp(48px, 6vw, 90px) + 2px);
    }

    /* ── Newsletter Section ─────────────────────────────────────────────── */
    .newsletter-section {
        position: relative;
        background-color: var(--color-surface-dark);
        padding-block: calc(var(--space-20) + clamp(52px, 6.5vw, 85px));
        text-align: center;
        overflow-x: clip;
        margin-top: -2px;
        margin-bottom: -2px;
    }

    /* Newsletter folgt direkt auf Konzerte-Section → deren Welle entfernen */
    .newsletter-section + .home-section--ueber-uns::before {
        display: none;
    }

    .newsletter-section__wave {
        position: absolute;
        left: 0;
        width: 100%;
        line-height: 0;
        pointer-events: none;
        z-index: 1;
    }

    .newsletter-section__wave svg {
        display: block;
        width: 100%;
        height: clamp(52px, 6.5vw, 85px);
    }

    .newsletter-section__wave--top { top: -2px; }
    .newsletter-section__wave--bottom { bottom: -2px; }

    .newsletter-section__inner {
        position: relative;
        z-index: 2;
        max-width: 780px;
        margin-inline: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-6);
    }

    .newsletter-section__label {
        display: flex;
        align-items: center;
        gap: var(--space-4);
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.7);
    }

    .newsletter-section__label::before {
        content: '';
        display: block;
        width: 2rem;
        height: 1px;
        background-color: rgba(255, 255, 255, 0.4);
        flex-shrink: 0;
    }

    .newsletter-section__title {
        font-family: var(--font-family-heading);
        font-size: clamp(2.2rem, 5vw, 4rem);
        font-weight: var(--font-weight-bold);
        color: var(--color-text-inverse);
        line-height: 1.1;
        margin: 0;
    }

    .newsletter-section__subtext {
        font-size: var(--font-size-md);
        color: rgba(255, 255, 255, .75);
        line-height: var(--line-height-base);
        max-width: 58ch;
    }

    /* Formular */
    .newsletter-form {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-4);
        width: 100%;
        max-width: 680px;
    }

    .newsletter-form__row {
        display: flex;
        gap: var(--space-4);
        width: 100%;
    }

    .newsletter-form__input {
        flex: 1;
        padding: var(--space-4) var(--space-6);
        background: rgba(255, 255, 255, .12);
        border: 1.5px solid rgba(255, 255, 255, .35);
        border-radius: var(--border-radius-md);
        color: #fff;
        font-family: var(--font-family-body);
        font-size: var(--font-size-md);
        outline: none;
        transition: border-color var(--transition-fast), background var(--transition-fast);
    }

    .newsletter-form__input::placeholder {
        color: rgba(255, 255, 255, .45);
    }

    .newsletter-form__input:focus {
        background: rgba(255, 255, 255, .18);
        border-color: rgba(255, 255, 255, .7);
    }

    .newsletter-form__consent {
        display: flex;
        align-items: flex-start;
        gap: var(--space-3);
        width: 100%;
        max-width: 680px;
        cursor: pointer;
        color: rgba(255, 255, 255, .75);
        font-size: var(--font-size-sm);
        line-height: 1.5;
        text-align: left;
    }

    .newsletter-form__checkbox {
        flex-shrink: 0;
        width: 18px;
        height: 18px;
        margin-top: 2px;
        appearance: none;
        -webkit-appearance: none;
        background: rgba(255, 255, 255, .12);
        border: 1.5px solid rgba(255, 255, 255, .45);
        border-radius: 4px;
        cursor: pointer;
        transition: background var(--transition-fast), border-color var(--transition-fast);
    }

    .newsletter-form__checkbox:checked {
        background: #fff;
        border-color: #fff;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10' fill='none' stroke='%23005567' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1,5 4,9 11,1'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: 11px 9px;
    }

    .newsletter-form__checkbox:focus-visible {
        outline: 2px solid rgba(255, 255, 255, .7);
        outline-offset: 2px;
    }

    .newsletter-form__consent a {
        color: #fff;
        text-decoration: underline;
        text-underline-offset: 2px;
    }

    .newsletter-form__consent a:hover {
        opacity: .8;
    }

    .newsletter-form__btn {
        padding-inline: var(--space-12);
    }

    @media (max-width: 599px) {
        .newsletter-form__row { flex-direction: column; }
    }

    /* ── Homepage Sektionen ──────────────────────────────────────────────── */
    .home-section {
        padding-block: var(--space-20);
        margin-bottom: -1px;
    }

    .home-section--ueber-uns,
    .home-section--kuenstler {
        background-color: var(--color-surface-alt);
    }

    /* ── Wellenübergänge zwischen Sektionen ─────────────────────────────── */

    /* Sektionen mit Welle brauchen position: relative */
    .home-section--ueber-uns,
    .home-section--kuenstler,
    .home-section--ueber-uns + .home-section,
    .home-section--kuenstler + .home-section {
        position: relative;
        padding-top: calc(var(--space-16) + clamp(52px, 6.5vw, 85px));
    }

    /* Welle: #fafafa läuft in #f1ebeb (oben auf Alt-Sektionen) */
    .home-section--ueber-uns::before,
    .home-section--kuenstler::before {
        content: '';
        position: absolute;
        top: -2px;
        left: 0;
        width: 100%;
        height: calc(clamp(52px, 6.5vw, 85px) + 2px);
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 80' preserveAspectRatio='none'%3E%3Cpath d='M0,40 C250,40 500,70 750,35 C950,8 1200,55 1440,45 L1440,0 L0,0 Z' fill='%23fafafa'/%3E%3C/svg%3E") no-repeat center / 100% 100%;
        pointer-events: none;
    }

    /* Welle: #f1ebeb läuft in #fafafa (oben auf Base-Sektionen nach Alt) */
    .home-section--ueber-uns + .home-section::before,
    .home-section--kuenstler + .home-section::before {
        content: '';
        position: absolute;
        top: -2px;
        left: 0;
        width: 100%;
        height: calc(clamp(52px, 6.5vw, 85px) + 2px);
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 80' preserveAspectRatio='none'%3E%3Cpath d='M0,40 C250,40 500,70 750,35 C950,8 1200,55 1440,45 L1440,0 L0,0 Z' fill='%23f1ebeb'/%3E%3C/svg%3E") no-repeat center / 100% 100%;
        pointer-events: none;
    }

    /* ── Venue Highlight Section ─────────────────────────────────────────── */
    .venue-highlight {
        position: relative;
        background-color: var(--color-surface-base);
        padding-block: calc(var(--space-20) + clamp(52px, 6.5vw, 85px));
        overflow-x: clip;
        text-align: center;
        margin-top: -2px;
        margin-bottom: -2px;
    }

    .venue-highlight + .home-section--kuenstler::before {
        display: none;
    }

    .venue-highlight + .home-section--kuenstler {
        padding-top: var(--space-20);
    }

    .venue-highlight__wave {
        position: absolute;
        left: 0;
        width: 100%;
        z-index: 1;
        line-height: 0;
    }

    .venue-highlight__wave svg {
        display: block;
        width: 100%;
        height: clamp(52px, 6.5vw, 85px);
    }

    .venue-highlight__wave--top { top: -2px; }
    .venue-highlight__wave--bottom { bottom: -2px; }

    .venue-highlight__inner {
        position: relative;
        z-index: 2;
        max-width: 900px;
        margin-inline: auto;
    }

    .venue-highlight__title {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        color: var(--color-brand-primary);
        margin-bottom: var(--space-6);
    }

    .venue-highlight__text {
        font-size: var(--font-size-md);
        line-height: var(--line-height-relaxed);
        color: var(--color-text-secondary);
        margin-bottom: var(--space-10);
    }

    .venue-highlight__image-wrap {
        border-radius: var(--border-radius-lg);
        overflow: hidden;
        margin-bottom: var(--space-10);
    }

    .venue-highlight__image {
        width: 100%;
        height: auto;
        display: block;
    }

    .venue-highlight__cta {
        display: flex;
        justify-content: center;
    }

    /* ── Sticky Social Sidebar (Desktop only) ───────────────────────────── */
    .social-sidebar {
        position: fixed;
        right: 0;
        top: 50%;
        transform: translateY(-50%) translateX(0);
        z-index: 100;
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
        padding: var(--space-3) var(--space-2);
        background: rgba(0, 55, 67, .85);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        border-radius: var(--border-radius-md) 0 0 var(--border-radius-md);
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                    opacity 0.4s ease;
    }


    @media (max-width: 959px) {
        .social-sidebar { display: none; }
    }

    /* ── Nav Social (Mobile Hamburger Menu) ──────────────────────────────── */
    .nav-social {
        display: none;
    }

    .site-nav.is-open .nav-social {
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: var(--space-4);
        margin-top: var(--space-8);
        padding-top: var(--space-6);
        border-top: 1px solid var(--color-border);
    }

    .nav-social__link {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        border-radius: var(--border-radius-sm);
        color: var(--color-brand-primary);
        border: 1.5px solid var(--color-border);
        transition: background-color var(--transition-fast), color var(--transition-fast),
                    border-color var(--transition-fast);
    }

    .nav-social__link:hover {
        background-color: var(--color-brand-primary);
        border-color: var(--color-brand-primary);
        color: #fff;
    }

    .nav-social__link svg {
        width: 20px;
        height: 20px;
    }

    .social-sidebar__link {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        color: rgba(255, 255, 255, .65);
        border-radius: var(--border-radius-sm);
        transition: color var(--transition-fast), background var(--transition-fast);
    }

    .social-sidebar__link:hover {
        color: #fff;
        background: rgba(255, 255, 255, .12);
    }

    .social-sidebar__link svg {
        width: 18px;
        height: 18px;
    }

    /* ── Pre-Footer ──────────────────────────────────────────────────────── */
    .prefooter {
        position: relative;
        background-color: var(--color-surface-alt);
        padding-top: calc(var(--space-20) + clamp(52px, 6.5vw, 85px));
        padding-bottom: calc(var(--space-20) + clamp(52px, 6.5vw, 85px));
        overflow-x: clip;
        margin-top: -2px;
    }

    .prefooter__wave {
        position: absolute;
        left: 0;
        width: 100%;
        z-index: 1;
        line-height: 0;
    }

    .prefooter__wave svg {
        display: block;
        width: 100%;
        height: clamp(52px, 6.5vw, 85px);
    }

    .prefooter__wave--top { top: -2px; }
    .prefooter__wave--bottom { bottom: -2px; }

    .prefooter .container {
        position: relative;
        z-index: 2;
    }

    .prefooter__grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--space-16);
        align-items: start;
    }

    @media (max-width: 799px) {
        .prefooter__grid { grid-template-columns: 1fr; gap: var(--space-12); }
    }

    .prefooter__headline {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        color: var(--color-brand-primary);
        margin-bottom: var(--space-4);
    }

    .prefooter__subtext {
        color: var(--color-text-secondary);
        margin-bottom: var(--space-6);
        line-height: 1.6;
    }

    /* Pre-Footer Form (auf hellem Hintergrund) */
    .prefooter-form {
        display: flex;
        flex-direction: column;
        gap: var(--space-3);
    }

    .prefooter-form__input {
        width: 100%;
        padding: var(--space-4) var(--space-5);
        background: var(--color-surface-base);
        border: 1.5px solid var(--color-border);
        border-radius: var(--border-radius-md);
        color: var(--color-text-primary);
        font-family: var(--font-family-body);
        font-size: var(--font-size-md);
        outline: none;
        transition: border-color var(--transition-fast);
        letter-spacing: 0.06em;
    }

    .prefooter-form__input::placeholder {
        color: var(--color-text-muted);
        font-size: var(--font-size-sm);
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .prefooter-form__input:focus {
        border-color: var(--color-brand-primary);
    }

    .prefooter-form__consent {
        display: flex;
        align-items: flex-start;
        gap: var(--space-3);
        cursor: pointer;
        color: var(--color-text-secondary);
        font-size: var(--font-size-sm);
        line-height: 1.5;
    }

    .prefooter-form__checkbox {
        flex-shrink: 0;
        width: 16px;
        height: 16px;
        margin-top: 2px;
        appearance: none;
        -webkit-appearance: none;
        background: var(--color-surface-base);
        border: 1.5px solid var(--color-border);
        border-radius: 3px;
        cursor: pointer;
        transition: background var(--transition-fast), border-color var(--transition-fast);
    }

    .prefooter-form__checkbox:checked {
        background: var(--color-brand-primary);
        border-color: var(--color-brand-primary);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1,5 4,9 11,1'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: 10px 8px;
    }

    .prefooter-form__consent a {
        color: var(--color-brand-primary);
        text-decoration: underline;
        text-underline-offset: 2px;
    }

    .prefooter-form__btn {
        align-self: flex-start;
        margin-top: var(--space-2);
    }

    /* Ticketkauf-Spalte */
    .prefooter__ticket-content {
        color: var(--color-text-secondary);
        line-height: 1.7;
    }

    .prefooter__ticket-content p { margin-bottom: var(--space-4); }
    .prefooter__ticket-content strong { color: var(--color-text-primary); }
    .prefooter__ticket-content em { font-style: italic; }
    .prefooter__ticket-content a {
        color: var(--color-brand-primary);
        text-decoration: underline;
        text-underline-offset: 2px;
    }

    .home-section__header {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--space-4);
        margin-bottom: var(--space-10);
        flex-wrap: wrap;
    }

    .home-section__title {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        color: var(--color-brand-primary);
    }

    .home-section__description {
        max-width: 70ch;
        font-size: var(--font-size-md);
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
    }

    .home-section__link {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
        color: var(--color-brand-primary);
        text-decoration: none;
        white-space: nowrap;
        display: inline-block;
        transition: color 0.22s ease, transform 0.22s ease, letter-spacing 0.22s ease;
    }

    .home-section__link:hover {
        color: var(--color-brand-secondary);
        transform: scaleX(1.04);
        transform-origin: left center;
        letter-spacing: calc(var(--letter-spacing-wide) + 0.04em);
        text-decoration: none;
    }

    .home-section__cta {
        text-align: center;
        margin-top: var(--space-10);
    }

    /* Über Uns Teaser */
    .ueber-uns-teaser {
        display: grid;
        gap: var(--space-10);
        text-align: center;
    }

    @media (min-width: 960px) {
        .ueber-uns-teaser { text-align: left; }
    }

    @media (min-width: 960px) {
        .ueber-uns-teaser {
            grid-template-columns: 1fr 1fr;
            align-items: center;
        }
    }

    .ueber-uns-teaser__image-wrap {
        border-radius: var(--border-radius-lg);
        overflow: hidden;
        aspect-ratio: 4/3;
    }

    .ueber-uns-teaser__image {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .ueber-uns-teaser__title {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        margin-bottom: var(--space-4);
        color: var(--color-brand-primary);
    }

    .ueber-uns-teaser__text {
        font-size: var(--font-size-md);
        line-height: var(--line-height-base);
        color: var(--color-text-secondary);
        margin-bottom: var(--space-8);
        max-width: 55ch;
        margin-inline: auto;
    }

    @media (min-width: 960px) {
        .ueber-uns-teaser__text {
            margin-inline: 0;
        }
    }

    /* ── Konzerte-Archiv ─────────────────────────────────────────────────── */
    .konzerte-section {
        padding-top: var(--space-6);
    }

    .konzerte-section__title {
        margin-bottom: var(--space-6);
        font-size: var(--font-size-xl);
        color: var(--color-text-secondary);
        font-weight: var(--font-weight-medium);
        font-family: var(--font-family-body);
        text-transform: uppercase;
        letter-spacing: var(--letter-spacing-wider);
        font-size: var(--font-size-sm);
    }

    .konzerte-grid--past .konzert-card {
        opacity: 0.65;
    }

    /* ── Vergangene Saisons (ausklappbar) ────────────────────────────────── */
    .konzerte-season {
        margin-top: var(--space-8);
        border-top: 1px solid var(--color-border);
    }

    .konzerte-season__summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-block: var(--space-6);
        font-family: var(--font-family-heading);
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        cursor: pointer;
        list-style: none;
        user-select: none;
    }

    .konzerte-season__summary::-webkit-details-marker {
        display: none;
    }

    .konzerte-season__summary::marker {
        content: '';
    }

    .konzerte-season__summary:hover {
        color: var(--color-brand-secondary);
    }

    .konzerte-season__icon {
        transition: transform var(--transition-base);
        flex-shrink: 0;
    }

    .konzerte-season[open] .konzerte-season__icon {
        transform: rotate(180deg);
    }

    .konzerte-season > .konzerte-grid,
    .konzerte-season > .kuenstler-grid {
        padding-bottom: var(--space-8);
    }

    .konzerte-season:last-child {
        margin-bottom: var(--space-12);
    }

    /* ── Single Konzert ──────────────────────────────────────────────────── */
    .konzert-hero {
        position: relative;
        overflow: hidden;
        background-color: var(--color-brand-primary);
        border-radius: var(--border-radius-lg);
        display: grid;
        min-height: 280px;
        margin-bottom: var(--space-8);
    }

    @media (min-width: 768px) {
        .konzert-hero {
            grid-template-columns: 1fr 1fr;
            min-height: 320px;
        }

        .konzert-hero__image-wrap {
            order: unset;
        }
    }

    .konzert-hero__content {
        padding: var(--space-10);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        gap: var(--space-2);
        z-index: 1;
    }

    .konzert-hero__title {
        font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
        color: var(--color-text-inverse);
        margin-bottom: var(--space-2);
    }

    .konzert-hero__date {
        font-size: var(--font-size-md);
        color: var(--color-brand-accent);
        display: block;
        font-weight: var(--font-weight-semibold);
    }

    .konzert-hero__venue {
        color: rgba(255,255,255,.75);
        font-size: var(--font-size-md);
    }

    .konzert-hero__image-wrap {
        order: -1;
        overflow: hidden;
        aspect-ratio: 3/2;
    }

    .konzert-hero__image {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    /* Event-Details Icon-Liste */
    .konzert-details {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        gap: var(--space-6);
        padding-block: var(--space-8);
        border-bottom: 1px solid var(--color-border);
        margin-bottom: var(--space-8);
    }

    .konzert-details__list {
        list-style: none;
        display: flex;
        flex-direction: column;
        gap: var(--space-3);
    }

    .konzert-details__list li {
        display: flex;
        align-items: center;
        gap: var(--space-3);
        font-size: var(--font-size-md);
    }

    .konzert-details__list svg {
        color: var(--color-brand-secondary);
        flex-shrink: 0;
    }

    /* Google Maps (DSGVO) */
    .konzert-map {
        width: 240px;
        height: 180px;
        border-radius: var(--border-radius-md);
        overflow: hidden;
        flex-shrink: 0;
        align-self: center;
    }

    .konzert-map__placeholder {
        width: 100%;
        height: 100%;
        background: var(--color-surface-alt);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: var(--space-3);
    }

    .konzert-map__label {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-semibold);
        color: var(--color-text-muted);
        background: rgba(0,0,0,.4);
        color: #fff;
        padding: var(--space-1) var(--space-3);
        border-radius: var(--border-radius-sm);
    }

    .konzert-map__load {
        font-size: var(--font-size-sm);
        padding: var(--space-2) var(--space-5);
    }

    .konzert-map iframe {
        width: 100%;
        height: 100%;
        border: 0;
    }

    @media (max-width: 599px) {
        .konzert-map {
            width: 100%;
            height: 200px;
        }
    }

    /* Pretix Ticket-Widget */
    .konzert-tickets {
        padding-block: var(--space-6) var(--space-12);
        overflow: hidden;
    }

    @media (min-width: 768px) {
        .konzert-tickets {
            padding-block: var(--space-8) var(--space-16);
        }
    }

    /* Pretix Lade-Platzhalter */
    .pretix-widget-placeholder {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: var(--space-3);
        padding: var(--space-10);
        color: var(--color-text-secondary);
        font-size: var(--font-size-sm);
    }

    .pretix-widget-placeholder__spinner {
        width: 20px;
        height: 20px;
        border: 2px solid var(--color-border);
        border-top-color: var(--color-brand-primary);
        border-radius: 50%;
        animation: pretix-spin 0.8s linear infinite;
    }

    @keyframes pretix-spin {
        to { transform: rotate(360deg); }
    }

    /* Platzhalter ausblenden sobald Pretix geladen ist */
    .konzert-tickets:has(.pretix-widget) .pretix-widget-placeholder {
        display: none;
    }

    /* Pretix Button Branding */
    .pretix-button {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: var(--space-2) !important;
        padding: var(--space-3) var(--space-6) !important;
        font-family: var(--font-family-body) !important;
        font-size: var(--font-size-sm) !important;
        font-weight: var(--font-weight-semibold) !important;
        letter-spacing: var(--letter-spacing-wide) !important;
        text-transform: uppercase !important;
        text-decoration: none !important;
        background-color: var(--color-brand-secondary) !important;
        color: #fff !important;
        border: 2px solid var(--color-brand-secondary) !important;
        border-radius: var(--border-radius-sm) !important;
        cursor: pointer !important;
        transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast) !important;
    }

    .pretix-button:hover {
        background-color: var(--color-brand-primary) !important;
        border-color: var(--color-brand-primary) !important;
        color: var(--color-text-inverse) !important;
    }

    /* Pretix Widget Branding-Overrides */
    .pretix-widget .pretix-widget-attribution {
        display: none !important;
    }

    .pretix-widget button,
    .pretix-widget input[type="submit"] {
        background-color: var(--color-brand-secondary) !important;
        border-color: var(--color-brand-secondary) !important;
        color: #fff !important;
        font-family: var(--font-family-body) !important;
        font-weight: var(--font-weight-semibold) !important;
        letter-spacing: var(--letter-spacing-wide) !important;
        text-transform: uppercase !important;
        border-radius: var(--border-radius-sm) !important;
    }

    .pretix-widget button:hover,
    .pretix-widget input[type="submit"]:hover {
        background-color: var(--color-brand-primary) !important;
        border-color: var(--color-brand-primary) !important;
    }

    .pretix-widget {
        font-family: var(--font-family-body) !important;
    }

    .pretix-widget h3,
    .pretix-widget h4,
    .pretix-widget .pretix-widget-category-name {
        color: var(--color-brand-primary) !important;
        font-family: var(--font-family-heading) !important;
    }

    .pretix-widget .pretix-widget-item-description {
        font-size: 0.75rem !important;
    }

    .pretix-widget .pretix-widget-info-message {
        background-color: var(--color-surface-alt) !important;
        border: 1px solid var(--color-border) !important;
        border-radius: var(--border-radius-md) !important;
        padding: var(--space-4) var(--space-6) !important;
        font-size: var(--font-size-sm) !important;
        color: var(--color-text-secondary) !important;
        display: flex !important;
        align-items: center !important;
        gap: var(--space-4) !important;
    }

    .pretix-widget .pretix-widget-resume-button {
        background-color: var(--color-brand-secondary) !important;
        border: none !important;
        color: #fff !important;
        font-family: var(--font-family-body) !important;
        font-size: var(--font-size-xs) !important;
        font-weight: var(--font-weight-semibold) !important;
        letter-spacing: var(--letter-spacing-wide) !important;
        text-transform: uppercase !important;
        padding: var(--space-2) var(--space-4) !important;
        border-radius: var(--border-radius-sm) !important;
        cursor: pointer !important;
        white-space: nowrap !important;
    }

    .pretix-widget .pretix-widget-resume-button:hover {
        background-color: var(--color-brand-primary) !important;
    }

    .pretix-widget .pretix-widget-voucher-description,
    .pretix-widget .pretix-widget-voucher-text {
        font-size: 0.75rem !important;
    }

    @media (min-width: 768px) {
        .pretix-widget .pretix-widget-voucher-description,
        .pretix-widget .pretix-widget-voucher-text {
            white-space: nowrap !important;
        }
    }

    @media (max-width: 767px) {
        .pretix-widget .pretix-widget-item-row {
            display: flex !important;
            flex-wrap: wrap !important;
            align-items: flex-start !important;
        }

        .pretix-widget .pretix-widget-item-info-col {
            width: 100% !important;
            float: none !important;
        }

        .pretix-widget .pretix-widget-item-price-col {
            float: none !important;
            width: auto !important;
            display: inline-block !important;
            vertical-align: middle !important;
        }

        .pretix-widget .pretix-widget-item-availability-col {
            float: none !important;
            width: auto !important;
            display: inline-block !important;
            vertical-align: middle !important;
        }

        .pretix-widget .pretix-widget-clear {
            display: none !important;
        }
    }

    .pretix-widget .pretix-widget-voucher-form {
        margin-top: var(--space-6) !important;
    }

    .pretix-widget .pretix-widget-voucher-input-wrap {
        margin-bottom: var(--space-5) !important;
    }

    .pretix-widget .pretix-widget-voucher-button-wrap {
        margin-bottom: 11px !important;
    }

    .pretix-widget-frame-holder iframe {
        max-width: 100% !important;
    }

    /* Video + Programm Sektion */
    .konzert-media-programm {
        display: grid;
        gap: var(--space-6);
        padding-block: var(--space-4);
    }

    @media (min-width: 768px) {
        .konzert-media-programm {
            gap: var(--space-10);
            padding-block: var(--space-12);
        }
    }

    @media (min-width: 768px) {
        .konzert-media-programm {
            grid-template-columns: 1fr 1fr;
            align-items: start;
        }
    }

    .konzert-video__embed {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
        border-radius: var(--border-radius-lg);
    }

    .konzert-video__embed iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    /* Künstler-Biografien */
    .konzert-biografien {
        padding-block: var(--space-8);
        display: flex;
        flex-direction: column;
        gap: var(--space-8);
    }

    .konzert-bio {
        display: grid;
        gap: var(--space-8);
        align-items: start;
    }

    @media (min-width: 768px) {
        .konzert-bio {
            grid-template-columns: 300px 1fr;
        }
    }

    .konzert-bio__image-wrap {
        border-radius: var(--border-radius-lg);
        overflow: hidden;
    }

    .konzert-bio__image {
        width: 100%;
        aspect-ratio: 3/2;
        object-fit: cover;
        object-position: top;
        display: block;
    }

    @media (min-width: 768px) {
        .konzert-bio__image {
            aspect-ratio: 3/4;
        }
    }

    .konzert-bio__name {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-4);
    }

    .konzert-bio__text {
        max-width: none;
    }

    .konzert-layout {
        display: grid;
        gap: var(--space-6);
        padding-block: var(--space-6);
    }

    @media (min-width: 768px) {
        .konzert-layout {
            gap: var(--space-12);
            padding-block: var(--space-12);
        }
    }

    @media (min-width: 960px) {
        .konzert-layout {
            grid-template-columns: 1fr 320px;
            align-items: start;
        }
    }

    .konzert-programm__title {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-6);
    }

    .konzert-programm__content {
        max-width: none;
    }

    .konzert-programm__content.is-collapsed {
        overflow: hidden;
        position: relative;
    }

    .konzert-programm__content.is-collapsed::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 80px;
        background: linear-gradient(to top, var(--color-surface-base) 0%, transparent 100%);
        pointer-events: none;
    }

    .konzert-programm__content.is-expanded {
        max-height: none !important;
    }

    .konzert-programm__content.is-expanded::after {
        display: none;
    }

    .konzert-programm__toggle {
        display: inline-flex;
        align-items: center;
        gap: var(--space-2);
        background: none;
        border: none;
        cursor: pointer;
        font-family: var(--font-family-body);
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-semibold);
        color: var(--color-brand-secondary);
        padding: var(--space-3) 0;
        margin-top: var(--space-2);
    }

    .konzert-programm__toggle:hover {
        color: var(--color-brand-primary);
    }

    .konzert-programm__toggle svg {
        transition: transform 0.3s ease;
    }

    .konzert-programm__toggle.is-expanded svg {
        transform: rotate(180deg);
    }

    .konzert-programm__content strong {
        color: var(--color-brand-secondary);
        font-weight: var(--font-weight-semibold);
    }

    .konzert-sidebar__sticky {
        position: sticky;
        top: calc(73px + var(--space-6));
        display: flex;
        flex-direction: column;
        gap: var(--space-6);
    }

    .konzert-info-box {
        background-color: var(--color-surface-alt);
        border-radius: var(--border-radius-md);
        padding: var(--space-6);
        display: flex;
        flex-direction: column;
        gap: var(--space-4);
    }

    .konzert-details-column {
        display: flex;
        flex-direction: column;
        gap: var(--space-6);
    }

    .konzert-cta {
        text-align: center;
        padding-block: var(--space-10);
    }

    .konzert-upselling {
        padding-block: var(--space-12);
    }

    .konzert-upselling__title {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-8);
    }

    .konzert-upselling__grid {
        display: grid;
        gap: var(--space-6);
    }

    .konzert-upselling__grid .konzert-card:nth-child(n+3) {
        display: none;
    }

    @media (min-width: 600px) {
        .konzert-upselling__grid {
            grid-template-columns: repeat(2, 1fr);
        }
    }

    @media (min-width: 960px) {
        .konzert-upselling__grid {
            grid-template-columns: repeat(3, 1fr);
        }

        .konzert-upselling__grid .konzert-card:nth-child(n+3) {
            display: block;
        }
    }

    .konzert-map--bottom {
        width: 100%;
        height: 350px;
        border-radius: var(--border-radius-lg);
        margin-block: var(--space-8);
    }

    .konzert-info-box__item {
        display: flex;
        flex-direction: column;
        gap: var(--space-1);
        padding-bottom: var(--space-4);
        border-bottom: 1px solid var(--color-border);
    }

    .konzert-info-box__item:last-of-type {
        border-bottom: none;
    }

    .konzert-info-box__label {
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        color: var(--color-text-muted);
    }

    /* Mitwirkende-Sektion (Vollbreite) */
    .konzert-mitwirkende-section {
        padding-block: var(--space-2) 0;
    }

    @media (min-width: 960px) {
        .konzert-mitwirkende-section {
            padding-block: 0;
        }
    }

    .konzert-mitwirkende-section__title {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-6);
    }

    .konzert-mitwirkende-section__content p {
        padding-block: var(--space-4);
        border-bottom: 1px solid var(--color-border);
    }

    .konzert-mitwirkende-section__content p:last-child {
        border-bottom: none;
    }

    .konzert-mitwirkende-section__content strong {
        display: block;
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-semibold);
        letter-spacing: var(--letter-spacing-wider);
        text-transform: uppercase;
        color: var(--color-text-muted);
        margin-bottom: var(--space-1);
    }

    .konzert-mitwirkende-section__content p br + br {
        display: none;
    }

    /* ── Single Künstler ─────────────────────────────────────────────────── */
    .kuenstler-single {
        padding-block: var(--space-12);
    }

    .kuenstler-single__layout {
        display: grid;
        gap: var(--space-12);
    }

    @media (min-width: 960px) {
        .kuenstler-single__layout {
            grid-template-columns: 360px 1fr;
            align-items: start;
        }
    }

    .kuenstler-single__portrait {
        border-radius: var(--border-radius-md);
        overflow: hidden;
    }

    .kuenstler-single__image {
        width: 100%;
        height: auto;
        display: block;
    }

    .kuenstler-single__name {
        margin-bottom: var(--space-2);
    }

    .kuenstler-single__instrument {
        font-size: var(--font-size-lg);
        color: var(--color-brand-secondary);
        margin-bottom: var(--space-8);
        font-family: var(--font-family-heading);
        font-style: italic;
    }

    .kuenstler-single__bio {
        margin-bottom: var(--space-8);
    }

    /* ── Künstler-Archiv ─────────────────────────────────────────────────── */
    .kuenstler-section {
        padding-top: var(--space-10);
    }

    .kuenstler-section__title {
        font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-3xl));
        margin-bottom: var(--space-8);
    }

    /* ── News Single ─────────────────────────────────────────────────────── */
    .news-single {
        padding-block: var(--space-12);
        max-width: 800px;
        margin-inline: auto;
    }

    .news-single__header {
        margin-bottom: var(--space-8);
    }

    .news-single__meta {
        margin-bottom: var(--space-4);
    }

    .news-single__date {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-semibold);
        color: var(--color-text-muted);
        letter-spacing: var(--letter-spacing-wide);
        text-transform: uppercase;
    }

    .news-single__title {
        margin-bottom: var(--space-3);
        color: var(--color-brand-primary);
    }

    .news-single__subtitle {
        font-size: var(--font-size-lg);
        color: var(--color-text-secondary);
        font-style: italic;
        font-family: var(--font-family-heading);
    }

    .news-single__thumbnail {
        border-radius: var(--border-radius-md);
        overflow: hidden;
        margin-bottom: var(--space-10);
    }

    .news-single__image {
        width: 100%;
        aspect-ratio: 3/2;
        object-fit: cover;
    }

    .news-single--centered .news-single__header,
    .news-single--centered .news-single__content {
        text-align: center;
    }

    /* ── Weitere Beiträge Slider ─────────────────────────────────────────── */
    .news-weitere {
        padding-block: var(--space-12);
    }

    .news-weitere__title {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-8);
    }

    /* ── Page Hero ───────────────────────────────────────────────────────── */
    .page-hero {
        position: relative;
        min-height: 40vh;
        max-height: 500px;
        overflow: hidden;
        display: flex;
        align-items: flex-end;
        background-color: var(--color-brand-primary);
        margin-bottom: var(--space-12);
    }

    .page-hero__image {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .page-hero__overlay {
        position: relative;
        z-index: 1;
        width: 100%;
        padding-block: var(--space-12);
        background: linear-gradient(to top, rgba(0,85,103,.85) 0%, transparent 100%);
    }

    .page-hero__title {
        color: var(--color-text-inverse);
        font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-4xl));
    }

    /* ── Über Uns – About Sections ──────────────────────────────────────── */
    .about-intro {
        text-align: center;
        max-width: 75ch;
        margin-inline: auto;
        padding-block: var(--space-6) var(--space-8);
    }

    .about-intro__title {
        font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-4xl));
        color: var(--color-brand-primary);
        margin-bottom: var(--space-4);
    }

    .about-intro__subheadline {
        font-size: clamp(var(--font-size-lg), 3vw, var(--font-size-2xl));
        color: var(--color-brand-secondary);
        font-family: var(--font-family-heading);
        margin-bottom: var(--space-6);
    }

    .about-intro__text {
        color: var(--color-text-secondary);
        font-size: var(--font-size-md);
        line-height: var(--line-height-loose);
        max-width: none;
    }

    .about-section {
        display: grid;
        gap: var(--space-8);
        padding-block: var(--space-10);
        border-top: 1px solid var(--color-border);
        align-items: center;
    }

    @media (min-width: 768px) {
        .about-section {
            grid-template-columns: 1fr 1fr;
            gap: var(--space-12);
        }
    }

    .about-section--reverse .about-section__image-wrap {
        order: -1;
    }

    .about-section__block-b {
        margin-top: var(--space-8);
    }

    .about-section--full {
        display: block;
        max-width: 75ch;
    }

    .about-section__headline {
        font-size: clamp(var(--font-size-lg), 3vw, var(--font-size-2xl));
        color: var(--color-brand-primary);
        margin-bottom: var(--space-4);
    }

    .about-section__text {
        max-width: none;
    }

    .about-section__image-wrap {
        border-radius: var(--border-radius-lg);
        overflow: hidden;
    }

    .about-section__image {
        width: 100%;
        height: 100%;
        object-fit: cover;
        aspect-ratio: 4/5;
        display: block;
    }

    @media (min-width: 768px) {
        .about-section__image {
            aspect-ratio: 3/4;
        }
    }

    /* ── Kontakt Layout ──────────────────────────────────────────────────── */
    /* ── Kontakt Hero (Rosa + Welle) ──────────────────────────────────────── */
    .kontakt-hero {
        background-color: #f1ebeb;
        position: relative;
        padding-block: var(--space-4) var(--space-16);
    }

    .kontakt-hero__wave {
        position: absolute;
        bottom: -1px;
        left: 0;
        width: 100%;
        line-height: 0;
        pointer-events: none;
    }

    .kontakt-hero__wave svg {
        display: block;
        width: 100%;
        height: clamp(48px, 6vw, 80px);
    }

    /* ── Kontakt-Section (2-Spalten) ──────────────────────────────────────── */
    .kontakt-section {
        padding-block: var(--space-16);
    }

    .kontakt-grid {
        display: grid;
        gap: var(--space-12);
    }

    @media (min-width: 960px) {
        .kontakt-grid {
            grid-template-columns: 1fr 380px;
            gap: var(--space-16);
            align-items: start;
        }
    }

    .kontakt-grid__title {
        font-size: var(--font-size-2xl);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-3);
    }

    .kontakt-grid__subtitle {
        color: var(--color-text-secondary);
        margin-bottom: var(--space-8);
    }

    .form-message {
        padding: var(--space-4) var(--space-6);
        border-radius: var(--border-radius-md);
        margin-bottom: var(--space-6);
        font-size: var(--font-size-sm);
    }

    .form-message--success {
        background-color: #e8f5e9;
        border: 1px solid #a5d6a7;
        color: #2e7d32;
    }

    .form-message--error {
        background-color: #fce4ec;
        border: 1px solid #ef9a9a;
        color: #c62828;
    }

    .form-required {
        color: #c62828;
        font-size: 1.1em;
        font-weight: var(--font-weight-bold);
    }

    .form-field--checkbox .form-required {
        font-size: 1.3em;
    }

    .form-input.is-invalid,
    .form-textarea.is-invalid {
        border-color: #c62828;
    }

    .form-field--checkbox.is-invalid {
        color: #c62828;
    }

    .privacy-link {
        color: var(--color-brand-primary);
        text-decoration: underline;
    }

    .privacy-link:hover {
        color: var(--color-brand-accent);
    }

    .privacy-link--light {
        color: rgba(255,255,255,.85);
    }

    .privacy-link--light:hover {
        color: var(--color-brand-accent);
    }

    .newsletter-form__message {
        padding: var(--space-4) var(--space-6);
        border-radius: var(--border-radius-md);
        margin-bottom: var(--space-4);
        text-align: center;
        font-size: var(--font-size-sm);
    }

    .newsletter-form__message--success {
        background-color: rgba(255,255,255,.1);
        color: #fff;
        font-size: var(--font-size-md);
        font-weight: var(--font-weight-semibold);
        border: 2px solid rgba(255,255,255,.4);
        text-align: center;
    }

    .newsletter-form__message--error {
        background-color: rgba(255,255,255,.15);
        color: #ef9a9a;
    }

    .prefooter-form__message {
        padding: var(--space-3) var(--space-5);
        border-radius: var(--border-radius-md);
        margin-bottom: var(--space-4);
        font-size: var(--font-size-sm);
    }

    .prefooter-form__message--success {
        background-color: #fff;
        color: var(--color-brand-primary);
        border: 1px solid var(--color-border);
        font-size: var(--font-size-md);
        font-weight: var(--font-weight-semibold);
        text-align: center;
    }

    .prefooter-form__message--error {
        background-color: #fce4ec;
        color: #c62828;
    }

    .prefooter-form__input.is-invalid {
        border-color: #c62828;
    }

    .prefooter-form__consent.is-invalid {
        color: #c62828;
    }

    .newsletter-form__input.is-invalid,
    .newsletter-form .is-invalid {
        border-color: #ef5350 !important;
        box-shadow: 0 0 0 1px #ef5350;
    }

    .newsletter-form__consent.is-invalid,
    .newsletter-form label.is-invalid {
        color: #ef9a9a;
    }

    .kontakt-grid__form {
        background: #fff;
        padding: var(--space-10);
        border-radius: var(--border-radius-lg);
        box-shadow: var(--shadow-sm);
    }

    .form-row {
        display: grid;
        gap: var(--space-4);
    }

    @media (min-width: 600px) {
        .form-row {
            grid-template-columns: 1fr 1fr;
        }
    }

    .kontakt-grid__info {
        display: flex;
        flex-direction: column;
        gap: var(--space-8);
    }

    @media (min-width: 960px) {
        .kontakt-grid__info {
            padding-top: var(--space-6);
        }
    }

    .kontakt-info-item {
        display: flex;
        gap: var(--space-4);
        align-items: flex-start;
    }

    .kontakt-info-item__icon {
        color: var(--color-brand-secondary);
        flex-shrink: 0;
        margin-top: 2px;
    }

    .kontakt-info-item__title {
        font-size: var(--font-size-md);
        font-weight: var(--font-weight-semibold);
        color: var(--color-brand-primary);
        margin-bottom: var(--space-1);
    }

    .kontakt-info-item__text {
        font-style: normal;
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
    }

    .kontakt-info-item__text a {
        color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .kontakt-info-item__text a:hover {
        text-decoration: underline;
    }

    /* Legacy form wrapper kept for compatibility */
    .kontakt-form-wrapper {
        max-width: 560px;
        margin-inline: auto;
        padding: var(--space-10);
        background: #fff;
        border-radius: var(--border-radius-lg);
        box-shadow: var(--shadow-lg);
    }

    .kontakt-grid__form .form-input,
    .kontakt-grid__form .form-textarea,
    .kontakt-form-wrapper .form-input,
    .kontakt-form-wrapper .form-textarea {
        border: none;
        border-bottom: 1px solid var(--color-border);
        border-radius: 0;
        padding: var(--space-4) var(--space-2);
        background: transparent;
        font-size: var(--font-size-base);
    }

    .kontakt-grid__form .form-input:focus,
    .kontakt-grid__form .form-textarea:focus,
    .kontakt-form-wrapper .form-input:focus,
    .kontakt-form-wrapper .form-textarea:focus {
        border-bottom-color: var(--color-brand-secondary);
        box-shadow: none;
    }

    .kontakt-grid__form .form-input::placeholder,
    .kontakt-grid__form .form-textarea::placeholder,
    .kontakt-form-wrapper .form-input::placeholder,
    .kontakt-form-wrapper .form-textarea::placeholder {
        color: var(--color-text-muted);
        font-weight: var(--font-weight-regular);
    }

    .kontakt-grid__form .form-field,
    .kontakt-form-wrapper .form-field {
        margin-bottom: var(--space-4);
    }

    .kontakt-grid__form .form-label,
    .kontakt-form-wrapper .form-label {
        display: none;
    }

    .kontakt-grid__form .form-textarea,
    .kontakt-form-wrapper .form-textarea {
        border: 1px solid var(--color-border);
        border-radius: var(--border-radius-sm);
        padding: var(--space-4);
        min-height: 160px;
        margin-top: var(--space-2);
    }

    .kontakt-grid__form .form-textarea:focus,
    .kontakt-form-wrapper .form-textarea:focus {
        border-color: var(--color-brand-secondary);
    }

    .kontakt-grid__form .btn,
    .kontakt-form-wrapper .btn {
        margin-top: var(--space-4);
    }

    .kontakt-cards {
        display: grid;
        gap: var(--space-8);
        padding-block: var(--space-16);
        max-width: 560px;
        margin-inline: auto;
    }

    @media (min-width: 600px) {
        .kontakt-cards {
            grid-template-columns: repeat(2, 1fr);
        }
    }

    .kontakt-card {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-2);
        text-align: center;
    }

    .kontakt-card__icon {
        color: var(--color-brand-primary);
        margin-bottom: var(--space-3);
    }

    .kontakt-card__title {
        font-size: var(--font-size-xl);
        color: var(--color-brand-primary);
    }

    .kontakt-card__text {
        font-style: normal;
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
    }

    .kontakt-card__text a {
        color: var(--color-brand-secondary);
        text-decoration: none;
    }

    .kontakt-card__text a:hover {
        text-decoration: underline;
    }

    .form-field--checkbox {
        font-size: var(--font-size-sm);
        color: var(--color-text-secondary);
        line-height: var(--line-height-base);
        margin-top: var(--space-4);
    }

    .form-field--checkbox label {
        display: block;
        padding-left: var(--space-8);
        text-indent: calc(-1 * var(--space-8));
        cursor: pointer;
    }

    .form-field--checkbox input[type="checkbox"] {
        margin-right: var(--space-3);
        vertical-align: middle;
        accent-color: var(--color-brand-secondary);
    }

    .form-field--checkbox a {
        color: var(--color-brand-secondary);
    }

    /* ── Rechtliche Seiten ───────────────────────────────────────────────── */
    .legal-page {
        padding-block: var(--space-8);
    }

    .legal-page__updated {
        font-size: var(--font-size-sm);
        color: var(--color-text-muted);
        margin-top: var(--space-2);
    }

    /* ── No Results ──────────────────────────────────────────────────────── */
    .no-results {
        padding-block: var(--space-12);
        color: var(--color-text-muted);
        font-style: italic;
    }
}

/* =============================================================================
   @layer utilities
   ============================================================================= */

@layer utilities {

    /* Screen-reader-only */
    .sr-only {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border-width: 0;
    }

    /* Skip Link */
    .skip-link {
        position: absolute;
        top: -100%;
        left: var(--space-4);
        z-index: 9999;
        background: var(--color-brand-primary);
        color: var(--color-text-inverse);
        padding: var(--space-2) var(--space-4);
        border-radius: var(--border-radius-sm);
        text-decoration: none;
        font-size: var(--font-size-sm);
    }

    .skip-link:focus {
        top: var(--space-4);
    }

    /* Visually hidden */
    .visually-hidden {
        clip: rect(0 0 0 0);
        clip-path: inset(50%);
        height: 1px;
        overflow: hidden;
        position: absolute;
        white-space: nowrap;
        width: 1px;
    }

    /* Icon */
    .icon {
        display: inline-block;
        width: 1.25em;
        height: 1.25em;
        fill: currentColor;
        vertical-align: middle;
    }

    /* Print Styles */
    @media print {
        .site-header,
        .site-footer,
        .cookie-banner,
        .nav-toggle,
        .btn--primary,
        .btn--secondary,
        .btn--on-dark {
            display: none !important;
        }

        body {
            font-size: 12pt;
            color: #000;
        }

        a[href]::after {
            content: " (" attr(href) ")";
            font-size: 0.75em;
            color: #666;
        }
    }
}
