/* ===== GLOBAL STYLES - Single source of truth ===== */
/* CSS Variables are defined in layout.php from dashboard settings */
/* Default spacing variables only */

/* Barlow Condensed - local */
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-400.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-500.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-600.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-700.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-800.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Barlow Condensed';
    src: url('../fonts/barlow-condensed/BarlowCondensed-900.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

:root {
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 2rem;
    --spacing-lg: 4rem;
    --spacing-xl: 6rem;
    --line-weight: 1px;
    /* Zitat/Body/Mono: Defaults — überschrieben in layout.php aus settings.json */
    --font-quote: 'Pacifico', cursive;
    --type-quote-weight: 300;
    --font-faq-q: 'Lora', Georgia, 'Times New Roman', serif;
    --font-quote-size: clamp(1.28rem, 2.35vw, 1.75rem);
    --font-quote-line-height: 1.45;
    --font-quote-stroke: 0;
    --font-h1: 'League Gothic', 'Arial Narrow', sans-serif;
    --font-body: 'Inter', system-ui, sans-serif;

    /* Typografie — Design System (siehe /design-system) */
    --type-h1-size: clamp(2rem, 4.5vw, 3rem);
    --type-h1-line: 1.1;
    --type-subline-size: 1.15rem;
    --type-subline-line: 1.5;
    --type-headline-subline-gap: 0.1rem;
    /* Abstand Seitentitel → Intro (Zitat/Lead); Referenz: /termine */
    --page-title-intro-gap: var(--spacing-sm);
    --type-section-body-gap: var(--spacing-sm);
    --type-quote-caption-gap: 0.75rem;
    --type-section-size: clamp(1.35rem, 2.4vw, 1.85rem);
    --type-section-line: 1.15;
    --type-body-size: 17px;
    /* Block-Headline + Inline-Bold (.text-mark) — gleiche Größe */
    --type-text-mark-size: clamp(1.35rem, 2.2vw, 1.75rem);
    --type-text-mark-line: 1.15;
    --modular-quill-body-size: 13px;
    --modular-quill-body-line: 1.55;
    --type-body-line: 1.65;
    --type-body-weight: 300;
    --type-label-size: 0.72rem;
    --type-label-line: 1.4;

    /* Mono-Typo — Referenz: Facts-Box (.facts-grid) */
    --mono-font: var(--font-mono-custom, 'JetBrains Mono', monospace);
    --mono-label-size: 0.65rem;
    --mono-label-line: 1.4;
    --mono-label-spacing: 0.05em;
    --mono-value-size: 0.85rem;
    --mono-value-line: 1.45;
    --mono-value-weight: 400;
    --mono-value-strong-weight: 500;
    --mono-secondary-size: 0.78rem;
    --mono-secondary-line: 1.35;
    --type-caption-size: 0.68rem;
    --type-faq-q-size: 1.02rem;
    --type-faq-a-size: 0.96rem;

    /* Inhaltsbreite Event-Detail + Design-System-Elementspalte */
    --layout-content-max: 800px;

    /* Seitenweites Fade-in (sequential-page-reveal.js + Event-Renderer) */
    --page-reveal-duration: 0.9s;
    --page-reveal-stagger: 0.12s;
    --page-reveal-offset: 0.65rem;

    /* Buttons — Design System (siehe /design-system#ds-buttons) */
    --btn-font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    --btn-font-size: 0.75rem;
    --btn-font-weight: 500;
    --btn-letter-spacing: 0.1em;
    --btn-padding-y: 0.8rem;
    --btn-padding-x: 1.35rem;
    --btn-radius: 4px;
    --btn-transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease, outline 0.2s ease, transform 0.2s ease;
    /* Akkordeon — Design System (siehe /design-system#ds-accordion) */
    --accordion-radius: 16px;
    --accordion-border: color-mix(in srgb, var(--color-accent) 28%, var(--color-border));
    --accordion-border-open: var(--color-accent);
    --accordion-surface: transparent;
    --accordion-surface-hover: transparent;
    --accordion-surface-open: transparent;
    --accordion-shadow: none;
    --accordion-shadow-hover: none;
    --accordion-title-size: 0.78rem;
    --accordion-gap: 1rem;
    --accordion-summary-pad-x: 1.5rem;
    --accordion-summary-pad-y: 0.85rem;
    --accordion-summary-pad: var(--accordion-summary-pad-y) var(--accordion-summary-pad-x);
    --accordion-panel-fade-duration: 0.75s;
    --accordion-panel-fade-delay: 0.12s;
    --accordion-fill-duration: 0.825s;
    --accordion-fill-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --accordion-color-duration: 0.45s;
    --accordion-color-delay: 0.14s;
    --accordion-content-duration: 0.55s;
    --accordion-content-delay: 0.22s;
    --accordion-content-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --accordion-ease: 0.3s ease-out;
    --accordion-panel-duration: 0.825s;
    --accordion-panel-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --accordion-toggle-size: 1.5rem;
    --accordion-toggle-hit: 2.25rem;
    --accordion-toggle-stroke: 2px;
    --label-radius: 2px;
    --color-btn-deactive: color-mix(in srgb, var(--color-accent) 52%, var(--color-text-light));
    --listing-title-font: var(--font-body);
    --listing-title-size: var(--type-body-size);
    --listing-title-line: var(--type-body-line);
    --listing-title-weight: var(--type-body-weight);
    --listing-title-subline-size: 1.05rem;
    --listing-title-subline-line: 1.4;
    --listing-title-offset-top: 0.2rem;
    --listing-title-max-height: calc(var(--listing-title-subline-size) * var(--listing-title-subline-line) * 2);
    --listing-stack-line: calc(var(--listing-title-subline-size) * var(--listing-title-subline-line));
    --listing-label-size: 0.58rem;
    --listing-label-line: 1.3;
    --listing-label-pad-y: 0.14rem;
    --listing-label-pad-x: 0.4rem;
    --listing-label-gap: 0.32rem;
    --listing-baseline-row-gap: 0.32rem;
    --listing-thumb-w: 120px;
    --listing-thumb-h: 80px;
    /* Abstand Titel↔Tags: knapp (nicht Zeilenabstand — der wäre zu groß) */
    --listing-stack-gap: 0.15rem;
    --listing-head-gap: var(--spacing-sm);
    --listing-foot-location-max: 11rem;
    --termine-block-gap: var(--spacing-sm);
}

/* Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Body */
body {
    font-family: var(--font-body);
    font-size: var(--type-body-size);
    font-weight: var(--type-body-weight);
    line-height: var(--type-body-line);
    color: var(--color-text);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
}

/* ===== HEADINGS ===== */
h1 {
    font-family: var(--font-h1);
    font-weight: 400;
    font-size: 3.35rem;
    line-height: 1.2;
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

h2 {
    font-family: var(--font-h1);
    font-weight: 400;
    font-size: clamp(2.1rem, 3.2vw, 2.85rem);
    line-height: 1.15;
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

h3 {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: 1.5rem;
    line-height: 1.2;
    margin-top: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
}

/* Event-Titel (Title-Block): globales h1 + Akzentfarbe */
.event-title-h1 {
    font-size: 2.85rem;
    line-height: 1.06;
    margin: 0 0 0.5rem 0;
    color: var(--color-accent);
}

/* ===== TEXT ===== */
body:not(.admin-page) main p,
body:not(.admin-page) main li {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    hyphenate-limit-chars: 6 3 3;
    hyphenate-limit-lines: 2;
}

p {
    margin-bottom: var(--spacing-sm);
    max-width: 65ch;
}

a {
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-border);
    text-underline-offset: 0.2em;
    transition: all 0.2s ease;
}

a:hover {
    text-decoration-color: var(--color-accent);
}

/* ===== LAYOUT ===== */
header {
    padding: var(--spacing-md) 0;
}

.header-content {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    font-family: var(--font-display);
    font-size: 3.5rem;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.logo a {
    color: var(--color-text);
    text-decoration: none;
}

.logo a:hover {
    color: var(--color-accent);
}

.logo-img {
    display: block;
    max-height: 60px;
    width: auto;
}

/* Navigation */
nav ul {
    display: flex;
    list-style: none;
    gap: var(--spacing-md);
    justify-content: flex-end;
}

nav a {
    font-family: var(--mono-font);
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-text);
    text-decoration: none;
    padding: 0.5rem 0;
    position: relative;
}

nav a:hover {
    color: var(--color-accent);
}

nav a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 3px;
    background: var(--color-accent);
    transition: width 0.3s ease;
}

nav a:hover::after,
nav a.active::after {
    width: 100%;
}

.menu-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 2rem;
    height: 2rem;
    padding: 0.25rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text);
    -webkit-appearance: none;
    appearance: none;
    -webkit-tap-highlight-color: transparent;
}

.menu-toggle__bar {
    display: block;
    width: 100%;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
}

.menu-toggle:hover,
.menu-toggle:focus,
.menu-toggle:active {
    color: var(--color-text);
    background: none;
}

.menu-toggle:focus-visible {
    outline: 2px solid var(--color-border);
    outline-offset: 3px;
}

main {
    max-width: 1100px;
    margin: 0 auto;
    padding: 1.5rem var(--spacing-md);
    min-height: 60vh;
}

/* Öffentliche Seiten: Footer am unteren Viewport-Rand halten (wie Admin-Login) */
body:not(.admin-page) {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    min-height: 100svh;
}

body:not(.admin-page) main {
    flex: 1 1 auto;
}

footer {
    background: #f5f5f5;
    padding: var(--spacing-md) 0;
    margin-top: var(--spacing-xl);
}

.footer-content {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer-links {
    display: flex;
    gap: var(--spacing-md);
}

.footer-links a {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-light);
    text-decoration: none;
}

.footer-links a:hover {
    color: var(--color-accent);
}

.footer-admin-link {
    flex-shrink: 0;
    align-self: center;
    font-size: 0.65rem;
    padding: 0.35rem 0.7rem;
    letter-spacing: 0.08em;
    opacity: 0.88;
}

.footer-admin-link:hover {
    opacity: 1;
}

.footer-admin-hint {
    flex-shrink: 0;
    align-self: center;
    position: relative;
    display: inline-flex;
    align-items: center;
    color: var(--color-accent);
    min-width: 0.78rem;
    min-height: 1.1rem;
}

.footer-admin-hint__heart {
    position: relative;
    flex-shrink: 0;
    width: 0.78rem;
    height: 0.78rem;
    cursor: default;
    touch-action: manipulation;
    user-select: none;
}

.footer-admin-hint__icon svg {
    width: 0.78rem;
    height: 0.78rem;
    display: block;
    pointer-events: none;
}

.footer-admin-hint__icon--solid {
    position: absolute;
    inset: 0;
}

.footer-admin-hint__type {
    position: absolute;
    right: calc(100% + 0.38rem);
    top: 50%;
    transform: translateY(-50%);
    display: inline-block;
    min-width: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
    pointer-events: none;
}

.footer-admin-hint.is-typing .footer-admin-hint__type::after {
    content: '';
    display: inline-block;
    width: 1.5px;
    height: 0.92em;
    margin-left: 0.1em;
    vertical-align: -0.08em;
    border-radius: 1px;
    background: var(--color-accent);
    animation: footer-admin-hint-cursor-blink 0.85s step-end infinite;
}

@keyframes footer-admin-hint-cursor-blink {
    0%,
    45% {
        opacity: 1;
    }

    50%,
    100% {
        opacity: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .footer-admin-hint.is-typing .footer-admin-hint__type::after {
        animation: none;
        opacity: 1;
    }
}

/* ===== EVENT BLOCKS ===== */
.block-meta,
.block-image,
.block-facts,
.block-title,
.block-content,
.block-text,
.block-modular-image,
.block-video {
    position: relative;
    margin: 0;
}

/* Edit mode */
.preview-block {
    position: relative;
    cursor: pointer;
    box-shadow: inset 3px 0 0 transparent;
    transition: box-shadow 0.2s ease, background 0.2s ease;
}

.preview-block:hover:not(.active) {
    box-shadow: inset 3px 0 0 var(--color-accent, #c9a959);
}

.preview-block.active {
    box-shadow: inset 3px 0 0 var(--color-accent, #c9a959);
    background: rgba(201, 169, 89, 0.06);
}

.preview-block.active:hover {
    box-shadow: inset 3px 0 0 var(--color-accent, #c9a959);
    background: rgba(201, 169, 89, 0.06);
}

/* Hero: inset bar clashes with rounded image — subtle ring only */
.admin-edit-wrapper .block-image.preview-block:hover:not(.active) {
    box-shadow: none;
}

.admin-edit-wrapper .block-image.preview-block:hover:not(.active)::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 12px;
    pointer-events: none;
    box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--color-accent) 55%, transparent);
}

/* Meta block — Pager links, Tags rechts bündig mit Hero-Bild */
.block-meta {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
    max-width: 100%;
    padding: 0;
    box-sizing: border-box;
}

.block-meta__bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    width: 100%;
    max-width: 100%;
}

.block-meta__lead {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-shrink: 0;
    margin: 0;
}

.event-meta-lead__group {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.event-meta-bar-btn,
.event-meta-context-link,
.event-meta-stats-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    margin: 0;
    height: 1.65rem;
    min-height: 1.65rem;
    padding: 0 0.65rem;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    line-height: 1.2;
    border: 1px solid color-mix(in srgb, var(--color-text, #1a1a1a) 18%, transparent);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.72);
    color: color-mix(in srgb, var(--color-text, #1a1a1a) 58%, transparent);
    cursor: pointer;
    transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.event-meta-context-link {
    text-decoration: none;
}

.event-meta-stats-toggle {
    appearance: none;
    -webkit-appearance: none;
}

a.event-meta-context-link:hover,
a.event-meta-context-link:focus-visible,
.event-meta-stats-toggle:hover,
.event-meta-stats-toggle:focus-visible {
    color: var(--color-text, #1a1a1a);
    border-color: color-mix(in srgb, var(--color-accent, #c9a959) 55%, var(--color-border, #e5e5e5));
    background: rgba(255, 255, 255, 0.92);
    outline: none;
}

.event-meta-stats-toggle.is-active,
.event-meta-stats-toggle[aria-expanded="true"] {
    background: var(--color-accent, #c9a959);
    border-color: var(--color-accent, #c9a959);
    color: #fff;
}

.event-meta-pager {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.event-meta-pager__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    height: auto;
    padding: 0.18rem 0.4rem;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent);
    text-decoration: none;
    border: none;
    border-radius: 4px;
    background: transparent;
    opacity: 0.88;
    transition: color 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

a.event-meta-pager__btn:hover,
a.event-meta-pager__btn:focus-visible {
    color: var(--color-accent);
    opacity: 1;
    background: color-mix(in srgb, var(--color-accent) 12%, transparent);
    outline: none;
}

.event-meta-pager__btn--disabled {
    opacity: 0.2;
    pointer-events: none;
    color: color-mix(in srgb, var(--color-text, #1a1a1a) 30%, transparent);
}

.event-visibility-badge,
.event-meta-lead__badge {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    font-family: var(--font-mono);
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.2;
    border-radius: 3px;
    padding: 0.12rem 0.35rem;
}

.event-visibility-badge[data-visibility="draft"] {
    color: var(--color-text-light);
    border: 1px solid var(--color-border);
}

.event-visibility-badge[data-visibility="public"] {
    color: color-mix(in srgb, var(--color-text) 72%, transparent);
    border: 1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.block-meta__tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    /* Container only — not a label chip (see unified label wildcard below) */
    font-family: inherit;
    font-size: inherit;
    text-transform: none;
    letter-spacing: normal;
    line-height: normal;
    border-radius: 0;
    background: transparent;
}

.event-detail > .block-meta,
.event-detail > .block-image {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.event-detail > .block-image img {
    box-sizing: border-box;
}

.event-detail :is(
    .event-gallery__img,
    .event-modular-image,
    .event-mixed__img,
    .event-mixed__gallery-img,
    .event-mixed-trainer__photo img,
    .text-block-content img,
    .text-note-content img,
    .event-mixed__text img
) {
    cursor: zoom-in;
}

/* ===== UNIFIED LABEL COMPONENT ===== */
.label,
.meta-tag,
.meta-type,
.tag,
.highlight,
.event-type,
.location-tag,
.category-tag,
.admin-filter-btn,
.filter-btn,
.event-meta-tag,
.multiday-badge,
.date-info,
.location-info,
.stats-number,
.stat-value,
.views-count,
.unique-count,
*[class*="tag"]:not(.btn):not(button):not([class*="__tags"]):not([class*="__tagline"]):not(.event-row-tags):not(.page-ika-journey-d-tags):not([class*="form-stage"]):not([class*="__tagging"]):not([class*="audience-"]):not([class*="yoga-im-alltag"]),
*[class*="badge"] {
    font-family: var(--mono-font) !important;
    font-size: var(--mono-label-size);
    text-transform: uppercase;
    letter-spacing: var(--mono-label-spacing);
    padding: 0.25rem 0.6rem;
    border-radius: var(--label-radius);
    display: inline-flex;
    align-items: center;
    border: none;
    cursor: default;
    line-height: var(--mono-label-line);
}

/* Label variants */
.label-default,
.meta-tag,
.tag {
    background: #f5f5f5;
    color: var(--color-text);
}

.label-inverse {
    background: var(--color-text);
    color: var(--color-bg);
}

.meta-type,
.event-type {
    background: color-mix(in srgb, var(--color-text-light) 18%, var(--color-border));
    color: var(--color-text);
}

.label-accent {
    background: var(--color-accent);
    color: white;
}

/* Category colors — volle Pastellfläche (Design System, Admin, …) */
.label-yoga,
.tag.yoga,
.highlight.yoga {
    background: var(--color-highlight-yoga);
    color: color-mix(in srgb, var(--color-highlight-yoga) 42%, var(--color-text));
}

.label-tanz,
.tag.tanz,
.highlight.tanz {
    background: var(--color-highlight-tanz);
    color: color-mix(in srgb, var(--color-highlight-tanz) 42%, var(--color-text));
}

.label-koerperarbeit,
.label-korperarbeit,
.tag.koerperarbeit,
.tag.korperarbeit,
.highlight.koerperarbeit,
.highlight.korperarbeit {
    background: var(--color-highlight-koerperarbeit);
    color: color-mix(in srgb, var(--color-highlight-koerperarbeit) 42%, var(--color-text));
}

.label-coaching,
.tag.coaching,
.highlight.coaching {
    background: var(--color-highlight-coaching);
    color: color-mix(in srgb, var(--color-highlight-coaching) 42%, var(--color-text));
}

/* Filter buttons (clickable labels) */
.filter-btn {
    background: #f5f5f5;
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.2s ease;
}

.filter-btn:hover {
    background: var(--color-accent);
    color: white;
}

.filter-btn.active {
    background: var(--color-text);
    color: var(--color-bg);
}

/* Admin filter buttons — gleiche Rundung wie Tags/Labels */
.admin-filter-btn,
button.admin-filter-btn {
    border-radius: var(--label-radius);
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    cursor: pointer;
    transition:
        background-color 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease;
}

@media (hover: hover) {
    .admin-filter-btn:hover:not(.active) {
        background: var(--color-accent);
        border-color: var(--color-accent);
        color: #fff;
    }

    .admin-filter-btn.category-filter:hover:not(.active) {
        background: color-mix(in srgb, var(--filter-cat-color) 55%, #fff);
        border-color: var(--filter-cat-color);
        color: var(--color-text);
    }
}

.admin-filter-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 65%, transparent);
    outline-offset: 2px;
}

.admin-filter-btn.active {
    background: var(--color-text);
    color: var(--color-bg);
}

.admin-filter-btn[data-value="all"].active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.admin-filter-bar .admin-filter-btn.category-filter.active {
    background: var(--filter-cat-color);
    border-color: var(--filter-cat-color);
    color: var(--color-text);
}

/* Image block */
.block-image img {
    width: 100%;
    max-height: 400px;
    object-fit: cover;
    display: block;
    background: var(--color-border);
}

/* Facts block */
.block-facts {
    background: #f5f5f5;
    padding: 1rem 1.25rem;
    border-radius: 12px;
    margin: 0;
    font-family: var(--mono-font);
}

.block-facts .facts-grid,
.block-facts .facts-grid dt,
.block-facts .facts-grid dd,
.block-facts .facts-grid a,
.block-facts .facts-grid span {
    font-family: var(--mono-font);
}

.facts-grid {
    display: grid;
    grid-template-columns: repeat(4, max-content);
    justify-content: space-between;
    column-gap: 1.25rem;
    row-gap: 1rem;
    width: 100%;
    margin: 0;
    padding: 0;
    align-items: start;
    justify-items: start;
}

.facts-row {
    display: contents;
}

.facts-cell {
    min-width: 0;
    box-sizing: border-box;
    text-align: left;
}

.facts-grid dt {
    font-size: var(--mono-label-size);
    line-height: var(--mono-label-line);
    text-transform: uppercase;
    letter-spacing: var(--mono-label-spacing);
    color: var(--color-text-light);
    margin: 0 0 0.25rem;
    padding: 0;
}

.facts-grid dd {
    margin: 0;
    padding: 0;
    font-size: var(--mono-value-size);
    line-height: var(--mono-value-line);
    font-weight: var(--mono-value-weight);
    color: var(--color-text);
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.facts-location-name {
    display: block;
    font-weight: var(--mono-value-strong-weight);
}

.facts-location-line {
    display: block;
    font-size: var(--mono-secondary-size);
    line-height: var(--mono-secondary-line);
    opacity: 0.85;
}

.facts-sessions-count {
    display: block;
    font-size: var(--mono-secondary-size);
    line-height: var(--mono-secondary-line);
    font-weight: 400;
    opacity: 0.85;
}

.facts-info-lines {
    display: flex;
    flex-direction: column;
    gap: 0.1em;
    line-height: 1.35;
}

.facts-info-line {
    display: block;
    line-height: inherit;
}

.facts-info-line--empty {
    opacity: 0.45;
}

.facts-info-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-border);
    text-underline-offset: 0.15em;
}

.facts-info-link:hover {
    text-decoration-color: var(--color-accent);
    color: var(--color-text);
}

.facts-info-icon {
    flex-shrink: 0;
    color: var(--color-accent);
}

.facts-info-sep {
    opacity: 0.5;
}

.facts-price-earlybird,
.facts-deadline-earlybird {
    color: var(--color-accent);
}

.facts-deadline-past {
    text-decoration: line-through;
    opacity: 0.6;
}

.facts-price-note {
    font-size: 0.78em;
    opacity: 0.85;
}

/* Title block */
.block-title {
    padding: 0;
}

.block-title.preview-block {
    position: relative;
}

.event-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.2rem;
}

.event-title-row .event-title-h1 {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
}

.event-title-row .btn-register {
    flex-shrink: 0;
    align-self: flex-start;
    margin: 0;
    white-space: nowrap;
}

.block-title.preview-block .event-title-row a.btn-register:not(.btn-register--sold-out):not(.btn-register--closed),
.block-title.preview-block .event-title-row button.btn-register:not(.btn-register--sold-out):not(.btn-register--closed) {
    position: relative;
    z-index: 2;
    pointer-events: auto;
    cursor: pointer;
}

.btn-register--placeholder,
.btn-register--closed,
.btn-register--sold-out {
    cursor: not-allowed;
    pointer-events: none;
}

.btn-register--placeholder {
    opacity: 0.45;
}

.btn-register--closed {
    background: transparent;
    border: 1px solid var(--color-btn-deactive);
    color: color-mix(in srgb, var(--color-text) 82%, var(--color-btn-deactive));
    opacity: 1;
    filter: none;
}

/* Ausgebucht — Outlined wie .btn-inline (Design-System), nicht klickbar */
.btn-register--sold-out {
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    opacity: 1;
    filter: none;
}

/* Zeile unter Titel (Event: Datum/Ort, Seiten-Tagline, FAQ-Fragen, …) */
.title-subline,
.event-subtitle,
.type-subline,
.type-faq-q,
.page-ika-faq-heading,
.page-ika-faq-q h2,
.text-accordion .text-accordion-heading {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-weight: 400;
    font-size: var(--type-subline-size);
    line-height: var(--type-subline-line);
    color: var(--color-accent);
    letter-spacing: 0.04em;
    margin: 0;
}

/* Headline + Subline — immer gemeinsam (Abstand: --type-headline-subline-gap) */
.type-headline-group {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--type-headline-subline-gap);
}

.type-headline-group .type-h1,
.type-headline-group .page-ika-title,
.type-headline-group .title-subline,
.type-headline-group .type-subline,
.type-headline-group .event-subtitle {
    margin: 0;
}

/* Abschnitt + Fließtext — immer gemeinsam (Abstand: --type-section-body-gap) */
.type-section-group {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--type-section-body-gap);
}

.type-section-group .type-section,
.type-section-group .page-ika-section-title {
    margin: 0;
}

.type-section-group--center {
    align-items: center;
}

.type-section-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--spacing-md);
    width: 100%;
}

.type-section-body .type-body,
.type-section-group > .type-body {
    margin: 0;
    max-width: none;
}

/* Zitat + Caption (Attribution) — immer gemeinsam (Abstand: --type-quote-caption-gap) */
.type-quote-group {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--type-quote-caption-gap);
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    box-shadow: none;
}

.type-quote-group .lead-text,
.type-quote-group .type-quote {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
}

.type-quote-group .lead-text p {
    margin: 0;
}

.type-quote-group .type-caption,
.type-quote-group .site-quote__attrib {
    margin: 0;
}

.type-quote-group--center {
    align-items: center;
    align-self: center;
    width: min(100%, 36rem);
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
}

.site-quote.type-quote-group.type-quote-group--center {
    margin-top: 1.5rem;
    margin-bottom: 1.75rem;
    margin-left: auto;
    margin-right: auto;
}

.type-quote-group--center .lead-text,
.type-quote-group--center .type-quote,
.type-quote-group--center .site-quote__attrib,
.type-quote-group--center .type-caption,
.site-quote.type-quote-group.type-quote-group--center .lead-text,
.site-quote.type-quote-group.type-quote-group--center .lead-text p,
.site-quote.type-quote-group.type-quote-group--center .site-quote__attrib {
    width: 100%;
    text-align: center;
}

/* ===== DESIGN SYSTEM — semantische Typo-Klassen (Referenz: /design-system) ===== */
.type-h1,
.page-ika-title {
    margin: 0 0 var(--type-headline-subline-gap);
    font-family: var(--font-h1);
    font-size: var(--type-h1-size);
    font-weight: 400;
    line-height: var(--type-h1-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-accent);
    max-width: none;
}

.type-section,
.page-ika-section-title,
.page-ika-block-title {
    font-family: var(--font-h1);
    font-size: var(--type-section-size);
    font-weight: 400;
    line-height: var(--type-section-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin: 0 0 var(--type-section-body-gap);
    color: var(--color-accent);
}

/* Fließtext — Design-System-Tokens global (Dashboard-Vorschau, Seiten, Event-Text „Absatz“) */
:is(
    .type-body,
    .type-section-group > .type-body,
    .text-block-content,
    .event-detail .event-content,
    #modularPanel .editor-field--quill .ql-container,
    #modularPanel .editor-field--quill .ql-editor
) {
    font-family: var(--font-body);
    font-size: var(--type-body-size);
    font-weight: var(--type-body-weight);
    line-height: var(--type-body-line);
    color: var(--color-text);
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphenate-limit-chars: 6 3 3;
    hyphenate-limit-lines: 2;
}

.type-body {
    max-width: 65ch;
}

.type-label,
.page-ika-foundations-label {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-label-size);
    font-weight: 500;
    line-height: var(--type-label-line);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.type-caption,
.page-ika-video-caption {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.type-quote,
.lead-text,
.lead-text p,
.site-quote .lead-text p,
.text-block-content blockquote:not(.lead-text),
.text-block-content blockquote:not(.lead-text) p,
.text-block-content .text-quote,
.text-block-content .text-quote p,
.block-text--quote .text-quote,
.block-text--quote .text-quote p {
    -webkit-text-stroke: var(--font-quote-stroke) currentColor;
    paint-order: stroke fill;
}

.type-quote {
    font-family: var(--font-quote);
    font-size: var(--font-quote-size);
    font-weight: var(--type-quote-weight, 300);
    font-style: normal;
    line-height: var(--font-quote-line-height);
    letter-spacing: 0.01em;
    color: var(--color-text);
    max-width: none;
    hyphens: none;
    -webkit-hyphens: none;
}

.type-faq-a,
.page-ika-faq-a,
.page-ika-faq-a p {
    font-family: var(--font-body);
    font-size: var(--type-faq-a-size);
    line-height: 1.65;
    color: var(--color-text);
}

/* Content block (legacy) */
.block-content {
    padding: 0;
}

.event-content {
    font-size: 1rem;
    line-height: 1.7;
    text-align: left;
}

.event-content h2 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    margin: 1.5rem 0 0.75rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--color-border);
}

.event-content h3 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 1.25rem 0 0.5rem 0;
}

.event-content p {
    margin-bottom: 1rem;
    max-width: 65ch;
}

.event-content ul,
.event-content ol {
    margin-left: 1.5rem;
    margin-bottom: 1rem;
}

.event-content li {
    margin-bottom: 0.5rem;
}

/* ===== BUTTONS — immer Mono, Versalien (Referenz: /design-system#ds-buttons) ===== */
.btn,
.btn-inline,
.btn-outline,
.btn-register,
.btn-solid,
.btn-primary,
.btn-secondary,
a.btn,
a.btn-inline,
a.btn-outline,
a.btn-register,
a.btn-solid,
a.btn-primary,
a.btn-secondary,
span.btn-register,
button.btn-register,
button.btn-inline,
button.btn-outline,
button.btn-solid,
button.btn-primary,
button.btn-secondary,
input[type="submit"],
input[type="button"] {
    font-family: var(--btn-font-family) !important;
    font-size: var(--btn-font-size);
    font-weight: var(--btn-font-weight);
    text-transform: uppercase;
    letter-spacing: var(--btn-letter-spacing);
    padding: var(--btn-padding-y) var(--btn-padding-x);
    border-radius: var(--btn-radius);
    text-decoration: none;
    cursor: pointer;
    transition: var(--btn-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    line-height: 1;
    box-sizing: border-box;
}

/* CTA Outline — Standard auf Inhaltsseiten (Kontakt, Footer, Home) */
.btn-outline,
.btn-inline,
a.btn-inline,
button.btn-inline {
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    appearance: none;
}

button.btn-inline {
    width: auto;
}

.btn-outline:hover,
.btn-inline:hover,
a.btn-inline:hover,
button.btn-inline:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
    text-decoration: none;
}

.btn-outline:focus-visible,
.btn-inline:focus-visible,
a.btn-inline:focus-visible,
button.btn-inline:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 28%, transparent);
    outline-offset: 2px;
}

.btn-inline.is-disabled,
span.btn-inline.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

/* Solid button - filled background */
.btn-solid,
.btn-primary {
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    color: white;
}

.btn-solid:hover,
.btn-primary:hover {
    background: var(--color-text);
    border-color: var(--color-text);
}

/* Secondary button - gray background */
.btn-secondary {
    background: var(--color-border);
    border: 1px solid var(--color-border);
    color: var(--color-text);
}

.btn-secondary:hover {
    background: var(--color-text);
    border-color: var(--color-text);
    color: var(--color-bg);
}

/* Register button — solid Akzent (offene Anmeldung) */
.btn-register {
    padding: 0.75rem 1.5rem;
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    color: #fff;
}

.btn-register:hover {
    background: var(--color-text);
    border-color: var(--color-text);
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
}

.btn-register:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 28%, transparent);
    outline-offset: 2px;
}

/* Inaktiv: Anmeldeschluss — outlined, gedämpft */
.btn-register.btn-register--closed {
    background: transparent;
    border: 1px solid var(--color-btn-deactive);
    color: color-mix(in srgb, var(--color-text) 82%, var(--color-btn-deactive));
    cursor: not-allowed;
    pointer-events: none;
    opacity: 1;
    filter: none;
    transform: none;
}

/* Ausgebucht — Outlined (Design-System .btn-inline) */
.btn-register.btn-register--sold-out {
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    cursor: not-allowed;
    pointer-events: none;
    opacity: 1;
    filter: none;
    transform: none;
}

.btn-register.btn-register--placeholder {
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.45;
    background: transparent;
    border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
}

.btn-register.btn-register--closed:hover,
.btn-register.btn-register--placeholder:hover {
    transform: none;
}

.btn-register.btn-register--closed:hover {
    background: transparent;
    border-color: var(--color-btn-deactive);
    color: color-mix(in srgb, var(--color-text) 82%, var(--color-btn-deactive));
}

.btn-register.btn-register--placeholder:hover {
    background: transparent;
    border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    opacity: 0.45;
}

.btn-register.btn-register--sold-out:hover {
    background: transparent;
    border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    transform: none;
}

.event-title-row .btn-register.btn-register--closed,
.block-title.preview-block .event-title-row .btn-register.btn-register--closed {
    background: transparent;
    border-color: var(--color-btn-deactive);
    color: color-mix(in srgb, var(--color-text) 82%, var(--color-btn-deactive));
    cursor: not-allowed;
    pointer-events: none;
    opacity: 1;
    filter: none;
    transform: none;
}

.event-title-row .btn-register.btn-register--sold-out,
.block-title.preview-block .event-title-row .btn-register.btn-register--sold-out {
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
    cursor: not-allowed;
    pointer-events: none;
    opacity: 1;
    filter: none;
    transform: none;
}

button.btn-register {
    appearance: none;
    font-family: var(--btn-font-family);
    font-size: var(--btn-font-size);
    font-weight: var(--btn-font-weight);
    letter-spacing: var(--btn-letter-spacing);
    text-transform: uppercase;
    line-height: 1;
}

button.btn-register--cognito:disabled {
    opacity: 0.7;
    cursor: wait;
}

/* Cognito Anmelde-Popup */
.event-registration-modal {
    position: fixed;
    inset: 0;
    z-index: 5000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(0.75rem, 3vw, 1.5rem);
    box-sizing: border-box;
}

.event-registration-modal[hidden] {
    display: none !important;
}

body.admin-edit-page .event-registration-modal {
    z-index: 10050;
}

body.event-registration-modal-open {
    overflow: hidden;
}

.event-registration-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
}

.event-registration-modal__panel {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    width: min(860px, calc(100vw - 1.5rem));
    height: min(96vh, calc(100vh - 1rem));
    max-height: calc(100vh - 1rem);
    background: var(--color-bg, #fff);
    border: 1px solid var(--color-border, #ddd);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22);
    overflow: hidden;
}

.event-registration-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--color-border, #ddd);
}

.event-registration-modal__header-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.event-registration-modal__external {
    white-space: nowrap;
    font-size: 0.58rem;
    padding: 0.45rem 0.75rem;
}

.event-registration-modal__external[hidden] {
    display: none !important;
}

.event-registration-modal__title {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text);
}

.event-registration-modal__close {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    border: 1px solid var(--color-border, #ddd);
    border-radius: 4px;
    background: transparent;
    color: var(--color-text);
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
}

.event-registration-modal__close:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.event-registration-modal__status {
    margin: 0;
    padding: 0.65rem 1rem 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    color: var(--color-text-light, #666);
}

.event-registration-modal__status[hidden] {
    display: none !important;
}

.event-registration-modal__frame-wrap {
    flex: 1 1 auto;
    min-height: 0;
    padding: 0 1rem 1rem;
    overflow-x: hidden;
    overflow-y: scroll;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-gutter: stable;
}

.event-registration-modal__iframe {
    display: block;
    width: 100%;
    min-height: 480px;
    border: 0;
    background: #fff;
}

/* ===== ACCORDION — Design System (Referenz: /design-system#ds-accordion) ===== */
.text-accordion {
    display: flex;
    flex-direction: column;
    gap: var(--accordion-gap);
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}

.text-accordion[data-columns="1"] {
    display: flex;
    flex-direction: column;
    column-count: unset;
    column-gap: unset;
    columns: auto;
}

/* Toggle/FAQ: nur einspaltig (Legacy data-columns="2" ignorieren) */
.text-accordion[data-columns="2"] {
    display: flex;
    flex-direction: column;
    column-count: unset;
    column-gap: unset;
    columns: auto;
}

.text-accordion[data-columns="2"] :is(.page-ika-faq-item, .text-accordion-item) {
    break-inside: auto;
    -webkit-column-break-inside: auto;
    page-break-inside: auto;
    margin-bottom: var(--accordion-gap);
}

/* Akkordeon = FAQ-Kacheln (page-ika-faq-item) */
.text-accordion > :is(.page-ika-faq-item, .text-accordion-item),
.page-ika-faq-item {
    position: relative;
    isolation: isolate;
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item)::before,
.page-ika-faq-item::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: var(--color-accent);
    transform: scaleY(0);
    transform-origin: top center;
    transition: transform var(--accordion-fill-duration) var(--accordion-fill-ease);
    z-index: 0;
    pointer-events: none;
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open::before,
.page-ika-faq-item.is-accordion-open::before {
    transform: scaleY(1);
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item) > *,
.page-ika-faq-item > * {
    position: relative;
    z-index: 1;
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item) {
    border: var(--line-weight) solid var(--accordion-border);
    border-radius: var(--accordion-radius);
    background: var(--accordion-surface);
    box-shadow: var(--accordion-shadow);
    overflow: hidden;
    transition: border-color var(--accordion-ease);
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item):hover:not(.is-accordion-open) {
    border-color: var(--accordion-border-open);
}

.text-accordion > :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open {
    border-color: var(--color-accent);
}

/* Summary-Zeile: Titel + Toggle (deAPI-Referenz: zentriert, großzügiges Padding) */
:is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: var(--accordion-summary-pad);
    cursor: pointer;
    list-style: none;
    color: var(--color-accent);
    transition:
        padding var(--accordion-ease),
        color var(--accordion-color-duration) ease;
}

.text-accordion .text-accordion-heading,
.page-ika-faq-heading,
.page-ika-faq-q h2,
.type-faq-q {
    padding: 0;
    border: none;
    flex: 1;
    min-width: 0;
    text-transform: none;
    transition: color var(--accordion-color-duration) ease;
}

.page-ika-faq-item:not(.is-accordion-open) .page-ika-faq-q h2,
.text-accordion :is(.page-ika-faq-item, .text-accordion-item):not(.is-accordion-open) .text-accordion-heading {
    display: flex;
    align-items: center;
    min-height: var(--accordion-toggle-hit);
}

.event-detail .text-accordion .text-accordion-heading {
    margin-top: 0;
    margin-bottom: 0;
}

:is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::-webkit-details-marker {
    display: none;
}

:is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::after {
    content: '';
    flex-shrink: 0;
    width: var(--accordion-toggle-hit);
    height: var(--accordion-toggle-hit);
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    background-color: transparent;
    background-image:
        linear-gradient(currentColor, currentColor),
        linear-gradient(currentColor, currentColor);
    background-size:
        var(--accordion-toggle-stroke) var(--accordion-toggle-size),
        var(--accordion-toggle-size) var(--accordion-toggle-stroke);
    background-position: center, center;
    background-repeat: no-repeat;
    transition: transform var(--accordion-panel-duration) var(--accordion-panel-ease);
}

:is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title):focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 35%, transparent);
    outline-offset: -2px;
}

.page-ika-faq-item.is-accordion-open :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::after,
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open
    :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::after {
    transform: rotate(45deg);
}

.page-ika-faq-item.is-accordion-open :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title),
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open
    :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title) {
    padding-bottom: 0.3rem;
    color: #fff;
    transition:
        padding var(--accordion-ease),
        color var(--accordion-color-duration) ease var(--accordion-color-delay);
}

.page-ika-faq-item.is-accordion-open .page-ika-faq-heading,
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open .text-accordion-heading {
    color: #fff;
    transition: color var(--accordion-color-duration) ease var(--accordion-color-delay);
}

.page-ika-faq-panel {
    display: grid;
    grid-template-rows: 0fr;
    overflow: hidden;
    transition: grid-template-rows var(--accordion-panel-duration) var(--accordion-panel-ease);
    interpolate-size: allow-keywords;
}

.page-ika-faq-item:not(.is-accordion-open) > .page-ika-faq-panel {
    grid-template-rows: 0fr;
}

.page-ika-faq-item.is-accordion-open > .page-ika-faq-panel,
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open > .page-ika-faq-panel {
    grid-template-rows: 1fr;
}

.page-ika-faq-panel > :is(.page-ika-faq-a, .text-accordion-item-body) {
    min-height: 0;
    overflow: hidden;
    padding: 0 var(--accordion-summary-pad-x);
    color: color-mix(in srgb, var(--color-text) 90%, transparent);
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
    opacity: 0;
    transform: translateY(-0.35rem);
    transition:
        opacity var(--accordion-content-duration) ease,
        transform var(--accordion-content-duration) var(--accordion-content-ease),
        color var(--accordion-color-duration) ease,
        padding var(--accordion-panel-duration) var(--accordion-panel-ease);
}

.page-ika-faq-item.is-accordion-open > .page-ika-faq-panel > :is(.page-ika-faq-a, .text-accordion-item-body),
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open
    > .page-ika-faq-panel > :is(.page-ika-faq-a, .text-accordion-item-body) {
    padding-bottom: 0.95rem;
    opacity: 1;
    transform: translateY(0);
    color: color-mix(in srgb, #fff 92%, transparent);
    transition:
        opacity var(--accordion-content-duration) ease var(--accordion-content-delay),
        transform var(--accordion-content-duration) var(--accordion-content-ease) var(--accordion-content-delay),
        color var(--accordion-color-duration) ease var(--accordion-color-delay);
}

/* Event-Editor: Toggle-Vorschau ohne Flackern beim Tippen (Live-Sync patcht DOM) */
body.admin-edit-page .text-accordion.is-accordion-live-edit > :is(.page-ika-faq-item, .text-accordion-item)::before,
body.admin-edit-page .text-accordion.is-accordion-live-edit .page-ika-faq-panel,
body.admin-edit-page .text-accordion.is-accordion-live-edit .page-ika-faq-panel > :is(.page-ika-faq-a, .text-accordion-item-body),
body.admin-edit-page .text-accordion.is-accordion-live-edit :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::after,
body.admin-edit-page .text-accordion.is-accordion-live-edit :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title),
body.admin-edit-page .text-accordion.is-accordion-live-edit .text-accordion-heading {
    transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
    .page-ika-faq-panel {
        transition: none;
    }

    .page-ika-faq-panel > :is(.page-ika-faq-a, .text-accordion-item-body) {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .text-accordion > :is(.page-ika-faq-item, .text-accordion-item)::before,
    .page-ika-faq-item::before {
        transition: none;
    }

    :is(.text-accordion-summary, .page-ika-faq-q, .text-accordion-item-title)::after {
        transition: none;
    }
}

.text-accordion :is(.page-ika-faq-a, .text-accordion-item-body) {
    color: color-mix(in srgb, var(--color-text) 90%, transparent);
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
}

.page-ika-faq-item.is-accordion-open :is(.page-ika-faq-a, .text-accordion-item-body),
.page-ika-faq-item.is-accordion-open :is(.page-ika-faq-a, .text-accordion-item-body) p,
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open
    :is(.page-ika-faq-a, .text-accordion-item-body),
.text-accordion :is(.page-ika-faq-item, .text-accordion-item).is-accordion-open
    :is(.page-ika-faq-a, .text-accordion-item-body) p {
    color: color-mix(in srgb, #fff 92%, transparent);
}

.text-accordion :is(.page-ika-faq-a, .text-accordion-item-body) p {
    margin: 0 0 0.5em;
    max-width: none;
}

.text-accordion :is(.page-ika-faq-a, .text-accordion-item-body) p:last-child {
    margin-bottom: 0;
}

.text-accordion :is(.page-ika-faq-a, .text-accordion-item-body) .text-link {
    color: var(--color-accent);
    text-decoration: none;
}

.text-accordion :is(.page-ika-faq-a, .text-accordion-item-body) .text-link:hover {
    color: var(--color-accent);
    opacity: 0.85;
}

.text-accordion-control.active,
.text-accordion-control[aria-pressed="true"] {
    border-bottom: var(--line-weight) solid var(--accordion-border);
    color: var(--color-accent);
}

/* Editor: Schalter mit gleicher Oberfläche wie Akkordeon-Titel */
.text-accordion-controls {
    display: inline-flex;
    align-items: stretch;
    gap: var(--accordion-gap);
    flex-wrap: wrap;
}

.text-accordion-controls--stretch {
    display: flex;
    width: 100%;
}

.text-accordion-controls--stretch .text-accordion-control {
    flex: 1 1 50%;
}

/* Editor: Spalten 1/2 — kompakt, nicht volle Panelbreite */
.text-accordion-controls--cols {
    display: inline-flex;
    width: auto;
    max-width: 100%;
}

.text-accordion-controls--cols .text-accordion-control--cols {
    flex: 0 0 auto;
    min-width: 0;
    padding: 0.04rem 0.22rem;
    font-size: 0.62rem;
    line-height: 1;
}

#modularPanelTextAccordion .editor-field--accordion-cols {
    display: none !important;
}

#modularAccordionCols .text-accordion-control--cols.active,
#modularAccordionCols .text-accordion-control--cols[aria-pressed="true"] {
    color: var(--color-accent);
    border-bottom: var(--line-weight) solid var(--accordion-border);
    background: var(--accordion-surface);
}

.text-accordion-controls--icons {
    gap: 0.35rem;
    flex-shrink: 0;
}

button.text-accordion-control {
    flex: 0 0 auto;
    min-width: 2.25rem;
    margin: 0;
    padding: 0.65rem 0.85rem;
    font-family: var(--mono-font);
    font-size: var(--accordion-title-size);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: var(--mono-label-spacing);
    line-height: 1;
    border: var(--line-weight) solid var(--accordion-border);
    border-radius: var(--accordion-radius);
    background: var(--accordion-surface);
    color: var(--color-text);
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    transition: var(--btn-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

button.text-accordion-control--compact {
    min-width: 2.25rem;
    padding: 0.65rem 0.55rem;
}

button.text-accordion-control--icon {
    width: 2.25rem;
    height: 2.25rem;
    min-width: 0;
    padding: 0;
    font-size: 0.85rem;
}

#modularPanel button.text-accordion-control--panel-access {
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 5px;
}

#modularPanel .text-accordion-control--panel-access .panel-access-icon {
    display: block;
    width: 0.88rem;
    height: 0.88rem;
    color: var(--color-text-light);
    transition: color 0.2s ease;
}

#modularPanel .text-accordion-control--panel-access .panel-access-icon .icon-stroke {
    fill: none;
    stroke: currentColor;
    stroke-width: 1.75;
    stroke-linecap: round;
    stroke-linejoin: round;
}

#modularPanel .text-accordion-control--panel-access .panel-access-icon .icon-pupil {
    fill: none;
}

#modularPanel .text-accordion-control--panel-access .panel-access-icon--eye .icon-slash {
    opacity: 0;
    transition: opacity 0.15s ease;
}

#modularPanel .text-accordion-control--panel-access .panel-access-icon .icon-body {
    fill: none;
    stroke: currentColor;
    stroke-width: 1.75;
    transition: fill 0.2s ease;
}

#modularPanel .text-accordion-control--panel-access:hover .panel-access-icon {
    color: var(--color-accent);
}

#modularPanel .text-accordion-control--panel-access.active,
#modularPanel .text-accordion-control--panel-access[aria-pressed='true'] {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
    border-bottom-color: var(--color-accent);
}

#modularPanel .text-accordion-control--panel-access.active .panel-access-icon,
#modularPanel .text-accordion-control--panel-access[aria-pressed='true'] .panel-access-icon {
    color: #fff;
}

#modularPanel .text-accordion-control--panel-access#modularToggleHidden[aria-pressed='true'] .icon-slash {
    opacity: 1;
}

#modularPanel .text-accordion-control--panel-access#modularToggleLocked[aria-pressed='true'] .icon-body {
    fill: currentColor;
}

#modularPanel .text-accordion-control--panel-access.active:hover,
#modularPanel .text-accordion-control--panel-access[aria-pressed='true']:hover {
    background: var(--color-text);
    border-color: var(--color-text);
    border-bottom-color: var(--color-text);
}

button.text-accordion-control:hover {
    color: var(--color-accent);
}

button.text-accordion-control:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 1px;
}

button.text-accordion-control.active[data-visibility="draft"] {
    color: var(--color-text);
    border-color: #b8b8b8;
    background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg));
    border-bottom-color: #b8b8b8;
}

button.text-accordion-control.active[data-visibility="draft"]:hover {
    border-color: #a3a3a3;
    color: var(--color-text);
}

button.text-accordion-control.active[data-visibility="public"],
button.text-accordion-control[aria-pressed="true"][data-visibility="public"] {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
    border-bottom-color: var(--color-accent);
}

button.text-accordion-control.active[data-visibility="public"]:hover,
button.text-accordion-control[aria-pressed="true"][data-visibility="public"]:hover {
    background: var(--color-text);
    border-color: var(--color-text);
    color: #fff;
    border-bottom-color: var(--color-text);
}

/* ===== SEQUENTIAL PAGE REVEAL (Frontend) ===== */
.page-reveal-item,
.event-detail--reveal > .event-block-reveal {
    opacity: 0;
    transform: translateY(var(--page-reveal-offset));
    animation: page-reveal-in var(--page-reveal-duration) cubic-bezier(0.22, 1, 0.36, 1) forwards;
    animation-delay: calc(var(--page-reveal-i, var(--event-block-reveal-i, 0)) * var(--page-reveal-stagger));
    will-change: opacity, transform;
}

@keyframes page-reveal-in {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .page-reveal-item,
    .event-detail--reveal > .event-block-reveal {
        opacity: 1;
        transform: none;
        animation: none;
        will-change: auto;
    }
}

/* Termine: Filter-FLIP darf nicht mit page-reveal-in kollidieren */
.page-reveal-ready .events-list--filter-animated > .event-row {
    animation: none;
    will-change: auto;
}

.events-list--filter-animated > .event-row.event-row--filter-leave,
.events-list--filter-animated > .event-row.event-row--filter-move {
    animation: none;
}

/* ===== EVENT DETAIL ===== */
.event-detail {
    max-width: var(--layout-content-max);
    text-align: left;
    --event-block-gap: clamp(1.1rem, 2.25vw, 1.625rem);
    --modular-block-padding-y: clamp(0.9rem, 1.85vw, 1.35rem);
    --modular-block-padding-y-emphasis: clamp(1.15rem, 2.4vw, 1.6rem);
}

/* Einheitlicher Abstand zwischen allen direkten Event-Blöcken */
.event-detail > .block-meta,
.event-detail > .block-image,
.event-detail > .block-facts,
.event-detail > .block-title,
.event-detail > .block-content,
.event-detail > .block-text,
.event-detail > .block-combo,
.event-detail > .block-mixed,
.event-detail > .block-modular-image,
.event-detail > .block-gallery,
.event-detail > .block-video,
.event-detail > .private-block-container,
.event-detail > .event-modular-picker,
.event-detail > .event-protected-unlock {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
}

.event-detail > * + * {
    margin-top: var(--event-block-gap);
}

/* Pflichtblöcke 1–3 (Meta, Bild, Facts): halber Abstand zueinander */
.event-detail > .block-meta + .block-image,
.event-detail > .block-image + .block-facts {
    margin-top: calc(var(--event-block-gap) * 0.5);
}

/* Modulblöcke (Text, Bild, Galerie, Video): Innenabstand + Abstand zueinander */
.event-detail > .block-text,
.event-detail > .block-combo,
.event-detail > .block-mixed,
.event-detail > .block-modular-image,
.event-detail > .block-gallery,
.event-detail > .block-video {
    padding-top: var(--modular-block-padding-y);
    padding-bottom: var(--modular-block-padding-y);
    box-sizing: border-box;
}

.event-detail > .block-text--quote,
.event-detail > .block-gallery {
    padding-top: var(--modular-block-padding-y-emphasis);
    padding-bottom: var(--modular-block-padding-y-emphasis);
}

.event-detail > .block-title + :is(.block-text, .block-combo, .block-mixed, .block-modular-image, .block-gallery, .block-video) {
    padding-top: calc(var(--modular-block-padding-y) * 0.85);
}

.event-detail > .block-text--quote.block-text,
.event-detail > .block-title + .block-gallery {
    padding-top: calc(var(--modular-block-padding-y-emphasis) * 0.85);
}

.event-detail > :is(.block-text, .block-combo, .block-mixed, .block-modular-image, .block-gallery, .block-video) + :is(.block-text, .block-combo, .block-mixed, .block-modular-image, .block-gallery, .block-video) {
    margin-top: 0;
}

/* Combo-Profile untereinander: kompakter als Standard, aber mit Luft */
.event-detail > :is(.block-combo, .block-mixed) + :is(.block-combo, .block-mixed) {
    padding-top: calc(var(--modular-block-padding-y) * 0.75);
}

/* Gesperrte Modulblöcke: Hinweis rechts auf Headline-Höhe */
.event-modular-block--access-gated {
    position: relative;
    --access-hint-top: var(--modular-block-padding-y);
}

.event-detail > .block-title + .event-modular-block--access-gated {
    --access-hint-top: calc(var(--modular-block-padding-y) * 0.85);
}

.event-detail > .block-text--quote.event-modular-block--access-gated,
.event-detail > .block-gallery.event-modular-block--access-gated {
    --access-hint-top: var(--modular-block-padding-y-emphasis);
}

.event-detail > .block-title + .block-text--quote.event-modular-block--access-gated,
.event-detail > .block-title + .block-gallery.event-modular-block--access-gated {
    --access-hint-top: calc(var(--modular-block-padding-y-emphasis) * 0.85);
}

.event-block-access-hint {
    position: absolute;
    top: var(--access-hint-top);
    right: 0;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    min-height: calc(var(--type-text-mark-size) * var(--type-text-mark-line));
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
    cursor: help;
    outline: none;
}

.event-block-access-hint__label {
    display: block;
    padding: 0.18rem 0.48rem;
    border-radius: 4px;
    background: var(--color-bg);
    border: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
    color: color-mix(in srgb, var(--color-accent) 78%, var(--color-text));
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: clamp(0.58rem, 0.98vw, 0.66rem);
    font-weight: 500;
    line-height: var(--type-label-line);
    letter-spacing: 0.11em;
    text-transform: uppercase;
    transition:
        transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
        box-shadow 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
        border-color 0.35s ease;
}

.event-modular-block--access-gated.block-gallery:has(.event-gallery__head h2) .event-block-access-hint {
    top: calc(var(--access-hint-top) + 0.15rem);
}

.event-modular-block--access-gated:has(> .event-block-access-hint) .text-block-headline,
.event-modular-block--access-gated:has(> .event-block-access-hint) .event-gallery__head h2.text-subtitle {
    padding-right: clamp(6rem, 19vw, 8rem);
}

.event-block-access-hint:focus-visible .event-block-access-hint__label {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 55%, transparent);
}

.event-block-access-hint__tooltip {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    z-index: 4;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
    width: max-content;
    max-width: min(16.5rem, 78vw);
    padding: 0.7rem 0.9rem 0.75rem;
    border-radius: 6px;
    background: var(--color-bg);
    color: var(--color-text);
    border: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
    box-shadow:
        0 14px 40px color-mix(in srgb, var(--color-text) 14%, transparent),
        inset 3px 0 0 color-mix(in srgb, var(--color-accent) 72%, transparent);
    box-sizing: border-box;
    text-align: left;
    transform-origin: top right;
    opacity: 0;
    visibility: hidden;
    transform: translate3d(0, -4px, 0) scale(0.98);
    pointer-events: none;
}

.event-block-access-hint__tooltip::before {
    content: '';
    position: absolute;
    top: -5px;
    right: 0.72rem;
    width: 8px;
    height: 8px;
    background: var(--color-bg);
    border-top: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
    border-left: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
    transform: rotate(45deg) scale(0.85);
    opacity: 0;
    transform-origin: center;
}

.event-block-access-hint__tooltip-kicker,
.event-block-access-hint__tooltip-text {
    opacity: 0;
    transform: translate3d(0, 3px, 0);
}

.event-block-access-hint__tooltip-kicker {
    display: block;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text));
}

.event-block-access-hint__tooltip-text {
    display: block;
    font-family: var(--font-body, inherit);
    font-size: var(--modular-quill-body-size);
    font-weight: var(--type-body-weight, 300);
    line-height: var(--modular-quill-body-line);
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--color-text);
    max-width: 28ch;
}

.event-block-access-hint:hover .event-block-access-hint__label,
.event-block-access-hint:focus .event-block-access-hint__label,
.event-block-access-hint:focus-visible .event-block-access-hint__label {
    border-color: color-mix(in srgb, var(--color-accent) 52%, var(--color-border));
    box-shadow: 0 4px 14px color-mix(in srgb, var(--color-accent) 10%, transparent);
}

.event-block-access-hint:hover .event-block-access-hint__tooltip,
.event-block-access-hint:focus .event-block-access-hint__tooltip,
.event-block-access-hint:focus-visible .event-block-access-hint__tooltip {
    visibility: visible;
    pointer-events: auto;
    animation: event-access-hint-tooltip-pop 0.62s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.event-block-access-hint:hover .event-block-access-hint__tooltip::before,
.event-block-access-hint:focus .event-block-access-hint__tooltip::before,
.event-block-access-hint:focus-visible .event-block-access-hint__tooltip::before {
    animation: event-access-hint-tooltip-arrow 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.06s forwards;
}

.event-block-access-hint:hover .event-block-access-hint__tooltip-kicker,
.event-block-access-hint:focus .event-block-access-hint__tooltip-kicker,
.event-block-access-hint:focus-visible .event-block-access-hint__tooltip-kicker {
    animation: event-access-hint-tooltip-line 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.1s forwards;
}

.event-block-access-hint:hover .event-block-access-hint__tooltip-text,
.event-block-access-hint:focus .event-block-access-hint__tooltip-text,
.event-block-access-hint:focus-visible .event-block-access-hint__tooltip-text {
    animation: event-access-hint-tooltip-line 0.58s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.16s forwards;
}

.event-block-access-hint:not(:hover):not(:focus):not(:focus-visible) .event-block-access-hint__tooltip {
    animation: none;
    opacity: 0;
    visibility: hidden;
    transform: translate3d(0, -3px, 0) scale(0.99);
    transition:
        opacity 0.24s ease-out,
        transform 0.24s ease-out,
        visibility 0.24s ease-out;
}

.event-block-access-hint:not(:hover):not(:focus):not(:focus-visible) .event-block-access-hint__tooltip::before,
.event-block-access-hint:not(:hover):not(:focus):not(:focus-visible) .event-block-access-hint__tooltip-kicker,
.event-block-access-hint:not(:hover):not(:focus):not(:focus-visible) .event-block-access-hint__tooltip-text {
    animation: none;
    opacity: 0;
    transform: translate3d(0, 2px, 0);
    transition: opacity 0.2s ease-out, transform 0.2s ease-out;
}

@keyframes event-access-hint-tooltip-pop {
    0% {
        opacity: 0;
        transform: translate3d(0, -4px, 0) scale(0.98);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
    }
}

@keyframes event-access-hint-tooltip-arrow {
    0% {
        opacity: 0;
        transform: rotate(45deg) scale(0.85) translateY(2px);
    }

    100% {
        opacity: 1;
        transform: rotate(45deg) scale(1) translateY(0);
    }
}

@keyframes event-access-hint-tooltip-line {
    0% {
        opacity: 0;
        transform: translate3d(0, 3px, 0);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .event-block-access-hint__label,
    .event-block-access-hint__tooltip,
    .event-block-access-hint__tooltip::before,
    .event-block-access-hint__tooltip-kicker,
    .event-block-access-hint__tooltip-text {
        animation: none !important;
        transition-duration: 0.01ms !important;
    }

    .event-block-access-hint:hover .event-block-access-hint__tooltip,
    .event-block-access-hint:focus .event-block-access-hint__tooltip,
    .event-block-access-hint:focus-visible .event-block-access-hint__tooltip {
        opacity: 1;
        transform: none;
    }

    .event-block-access-hint:hover .event-block-access-hint__tooltip::before,
    .event-block-access-hint:focus .event-block-access-hint__tooltip::before,
    .event-block-access-hint:focus-visible .event-block-access-hint__tooltip::before,
    .event-block-access-hint:hover .event-block-access-hint__tooltip-kicker,
    .event-block-access-hint:focus .event-block-access-hint__tooltip-kicker,
    .event-block-access-hint:focus-visible .event-block-access-hint__tooltip-kicker,
    .event-block-access-hint:hover .event-block-access-hint__tooltip-text,
    .event-block-access-hint:focus .event-block-access-hint__tooltip-text,
    .event-block-access-hint:focus-visible .event-block-access-hint__tooltip-text {
        opacity: 1;
        transform: none;
    }
}

.event-detail > :is(.block-combo, .block-mixed):has(+ :is(.block-combo, .block-mixed)) {
    padding-bottom: calc(var(--modular-block-padding-y) * 0.75);
}

@media (max-width: 768px) {
    .event-detail {
        --event-block-gap: 1rem;
        --modular-block-padding-y: clamp(0.75rem, 3vw, 1.1rem);
        --modular-block-padding-y-emphasis: clamp(0.95rem, 3.5vw, 1.35rem);
    }

    /* Textblock Modus „Absatz“: auf Mobile immer einspaltig (überschreibt inline column-count) */
    .event-detail .text-block-content {
        column-count: 1 !important;
        column-gap: 0 !important;
        columns: auto !important;
    }

}

.event-protected-unlock {
    margin-top: var(--event-block-gap);
    padding: 0.75rem 1rem;
    background: #f7f7f7;
    border: 1px solid var(--color-border);
    border-radius: 8px;
}

.event-protected-unlock-form {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0;
    text-align: center;
}

.event-protected-unlock-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
    gap: 0.5rem 0.65rem;
}

.event-protected-unlock-label {
    display: inline-block;
    margin: 0;
    flex-shrink: 0;
    white-space: nowrap;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-light);
}

.event-protected-unlock-row input[type="password"] {
    width: 10.8rem;
    flex: 0 0 auto;
    min-width: 0;
    padding: 0.45rem 0.55rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.82rem;
    background: #fff;
    box-sizing: border-box;
}

.event-protected-unlock-row input[type="password"]:focus {
    outline: none;
    border-color: var(--color-accent);
}

.event-protected-unlock-btn {
    flex-shrink: 0;
    padding: 0.45rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
}

.event-protected-unlock-btn:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.event-protected-unlock-error {
    display: none;
    width: 100%;
    margin: 0.35rem 0 0;
    padding: 0;
    text-align: center;
    font-size: 0.78rem;
    color: #c0392b;
    font-family: 'JetBrains Mono', monospace;
}

.event-protected-unlock-error:not([hidden]) {
    display: block;
}

.private-block-container--unlocked .private-content-blurred {
    filter: none;
    opacity: 1;
    pointer-events: auto;
    user-select: auto;
}

.event-detail .block-image img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 16 / 9;
}

.event-actions {
    margin-top: var(--spacing-md);
    display: flex;
    justify-content: flex-end;
}

.event-detail > .event-meta-pager {
    margin-top: 0.5rem;
    margin-bottom: 0;
}

.event-detail > .event-meta-pager .event-meta-pager__btn {
    padding-top: 0.08rem;
    padding-bottom: 0.08rem;
}

/* ===== EVENT LISTINGS (Termine Page) ===== */
.termine-page {
    --termine-intro-width: min(26.5rem, 36%);
    display: grid;
    grid-template-columns: minmax(0, var(--termine-intro-width)) minmax(0, 1fr);
    column-gap: var(--spacing-md);
    row-gap: var(--spacing-lg);
    width: 100%;
    max-width: 100%;
}

.termine-page > .two-column {
    display: contents;
}

.termine-page > .past-events {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.two-column {
    display: grid;
    grid-template-columns: minmax(0, 40%) minmax(0, 60%);
    gap: var(--spacing-lg);
    margin-top: 0;
    width: 100%;
    max-width: 100%;
}

.two-column > * {
    min-width: 0;
}

/* ===== HOME PAGE ===== */
.home-page {
    --termine-intro-width: min(26.5rem, 36%);
    display: grid;
    grid-template-columns: minmax(0, var(--termine-intro-width)) minmax(0, 1fr);
    column-gap: var(--spacing-md);
    row-gap: 0;
    align-items: start;
}

.home-hero.two-column,
.home-promo-band,
.home-promo-band__grid {
    display: contents;
}

.home-intro {
    grid-column: 1;
    grid-row: 1;
}

.home-upcoming {
    grid-column: 2;
    grid-row: 1;
}

.home-bibliothek-promo {
    grid-column: 1;
    grid-row: 2;
}

.home-yoga-im-alltag-promo {
    grid-column: 2;
    grid-row: 2;
}

.home-bibliothek-promo,
.home-yoga-im-alltag-promo {
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.home-upcoming__title-link {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s ease;
}

.home-upcoming__title-link:hover {
    color: var(--color-text);
}

.home-intro {
    padding-right: var(--spacing-md);
}

.home-intro .site-quote {
    margin: 0 0 1.25rem;
    text-align: left;
}

.home-intro .lead-text,
.home-intro .lead-text p {
    margin: 0;
    text-align: left;
}

.home-intro-body {
    margin: 0 0 var(--spacing-sm);
    max-width: 38ch;
    text-align: left;
    text-justify: auto;
    hyphens: none;
}

.home-offering-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin: 0 0 var(--spacing-sm);
}

.home-offering-links a.highlight {
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.15s ease, filter 0.15s ease;
}

.home-offering-links a.highlight:hover {
    transform: translateY(-1px);
    filter: brightness(0.97);
}

.home-offering-links a.highlight.termine {
    background: color-mix(in srgb, var(--color-accent) 14%, var(--color-border));
    color: var(--color-text);
}

.home-upcoming {
    min-width: 0;
    padding-bottom: var(--spacing-sm);
}

.home-upcoming__title.page-ika-section-title {
    margin: 0;
    padding-bottom: var(--spacing-sm);
}

.home-upcoming__more {
    margin: var(--spacing-md) 0 0;
}

.home-upcoming__empty {
    margin: 0;
    color: var(--color-text-light);
    max-width: 32ch;
    text-align: left;
    text-justify: auto;
    hyphens: none;
}

.events-list--home > .event-row:first-child {
    padding-top: 0;
}

.event-multiday-hint {
    color: var(--color-accent);
    font-size: 0.75rem;
}

@media (max-width: 768px) {
    .home-intro {
        padding-right: 0;
    }

    .home-intro-body {
        max-width: none;
    }
}

/* Startseite — Hinweis Yoga Online-Modul */
.home-hero {
    margin-bottom: var(--spacing-sm);
}

.home-promo-band__col {
    min-width: 0;
}

.home-bibliothek-promo__link {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    text-decoration: none;
    color: inherit;
    padding: 0 var(--spacing-md) 0 0;
    border-right: 1px solid var(--color-border);
    border-radius: 8px;
    transition: background 0.2s ease;
}

.home-bibliothek-promo__link:hover {
    background: rgba(0, 0, 0, 0.02);
}

.home-bibliothek-promo__copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
    min-width: 0;
}

.home-bibliothek-promo__eyebrow {
    margin: 0;
    font-family: var(--mono-font);
    font-size: var(--mono-label-size);
    line-height: var(--mono-label-line);
    letter-spacing: var(--mono-label-spacing);
    text-transform: uppercase;
    color: var(--color-text-light);
}

.home-bibliothek-promo__title {
    margin: 0;
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.home-bibliothek-promo__lead {
    margin: 0;
    max-width: 42ch;
}

.home-bibliothek-promo__cta {
    margin-top: 0.25rem;
}

.home-yoga-im-alltag-promo {
    max-width: 100%;
}

.home-yoga-im-alltag-promo__link {
    display: grid;
    grid-template-columns: var(--listing-thumb-w) minmax(0, 1fr);
    column-gap: var(--spacing-sm);
    align-items: start;
    text-decoration: none;
    color: inherit;
    padding: 0;
    border-radius: 8px;
    transition: background 0.2s ease;
}

.home-yoga-im-alltag-promo__link:hover {
    background: rgba(0, 0, 0, 0.02);
}

.home-yoga-im-alltag-promo {
    --home-yoga-promo-thumb: 6.5rem;
}

.home-yoga-im-alltag-promo__media {
    width: var(--listing-thumb-w);
    max-width: var(--listing-thumb-w);
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    background-color: var(--color-yoga, #e8f5e9);
    background-size: cover;
    background-position: center;
    filter: grayscale(1) brightness(1.15) contrast(0.68);
    transition: filter 0.25s ease;
    align-self: start;
    justify-self: start;
}

.home-yoga-im-alltag-promo__link:hover .home-yoga-im-alltag-promo__media {
    filter: none;
}

.home-yoga-im-alltag-promo__copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
    min-width: 0;
}

.home-yoga-im-alltag-promo__eyebrow {
    margin: 0;
    font-family: var(--mono-font);
    font-size: var(--mono-label-size);
    line-height: var(--mono-label-line);
    letter-spacing: var(--mono-label-spacing);
    text-transform: uppercase;
    color: var(--color-text-light);
}

.home-yoga-im-alltag-promo__head {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    width: 100%;
}

.home-yoga-im-alltag-promo__head-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--spacing-sm);
    width: 100%;
}

.home-yoga-im-alltag-promo__eyebrow--end,
.home-yoga-im-alltag-promo__price {
    margin: 0;
    text-align: right;
    flex-shrink: 0;
}

.home-yoga-im-alltag-promo__head-row--titles .home-yoga-im-alltag-promo__title,
.home-yoga-im-alltag-promo__head-row--titles .home-yoga-im-alltag-promo__price {
    margin: 0;
    padding: 0;
    line-height: var(--type-section-line);
    font-size: var(--type-section-size);
    font-family: var(--font-h1);
    font-weight: 400;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.home-yoga-im-alltag-promo__title {
    flex: 1;
    min-width: 0;
}

.home-yoga-im-alltag-promo__action-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-sm);
    width: 100%;
}

.home-yoga-im-alltag-promo__lead {
    margin: 0;
    width: 100%;
    max-width: 42ch;
}

.home-yoga-im-alltag-promo__cta {
    flex-shrink: 0;
    margin: 0;
    align-self: flex-start;
}

.termine-list-panel {
    min-width: 0;
    width: 100%;
    max-width: 100%;
}

/* Skeleton und echte Liste überlagern sich — nicht stapeln (sonst doppelte Höhe) */
.termine-list-panel:has(#upcoming-events),
.past-events:has(#past-events) {
    position: relative;
}

/* Termine: Skeleton beim ersten Laden & beim Filtern */
.termine-list-skeleton {
    display: none;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.termine-skeleton-row {
    display: grid;
    grid-template-columns: var(--listing-thumb-w) minmax(0, 1fr);
    column-gap: var(--spacing-sm);
    align-items: start;
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--color-border);
}

.termine-list-skeleton .termine-skeleton-row:last-child {
    border-bottom: none;
}

.termine-skeleton-thumb {
    width: var(--listing-thumb-w);
    height: var(--listing-thumb-h);
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-border) 55%, var(--color-bg));
}

.termine-skeleton-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.45rem;
    min-height: var(--listing-thumb-h);
    min-width: 0;
}

.termine-skeleton-line {
    display: block;
    height: 0.72rem;
    border-radius: 4px;
    background: linear-gradient(
        90deg,
        color-mix(in srgb, var(--color-border) 70%, var(--color-bg)) 0%,
        color-mix(in srgb, var(--color-border) 35%, var(--color-bg)) 45%,
        color-mix(in srgb, var(--color-border) 70%, var(--color-bg)) 90%
    );
    background-size: 200% 100%;
    animation: termine-skeleton-shimmer 1.15s ease-in-out infinite;
}

.termine-skeleton-line--title {
    width: min(100%, 14rem);
    height: 0.85rem;
}

.termine-skeleton-line--meta {
    width: min(100%, 9.5rem);
    opacity: 0.85;
}

@keyframes termine-skeleton-shimmer {
    0% {
        background-position: 100% 0;
    }
    100% {
        background-position: -100% 0;
    }
}

html:not(.page-reveal-ready) .termine-list-panel:not(.termine-list-loaded):has(#upcoming-events) .termine-list-skeleton:not(.termine-list-skeleton--past),
html:not(.page-reveal-ready) .past-events:not(.termine-list-loaded):has(#past-events) .termine-list-skeleton--past {
    display: flex;
}

.termine-list-panel:not(.termine-list-loaded):has(#upcoming-events) #upcoming-events,
.past-events:not(.termine-list-loaded):has(#past-events) #past-events {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    visibility: hidden;
    pointer-events: none;
}

.termine-list-panel.termine-list-loaded .termine-list-skeleton:not(.termine-list-skeleton--past),
.past-events.termine-list-loaded .termine-list-skeleton--past {
    display: none !important;
}

.termine-list-panel.termine-list-loaded #upcoming-events,
.past-events.termine-list-loaded #past-events {
    position: static;
    visibility: visible;
    pointer-events: auto;
}

.termine-list-panel.is-filtering:has(#upcoming-events) .termine-list-skeleton:not(.termine-list-skeleton--past),
.past-events.is-filtering:has(#past-events) .termine-list-skeleton--past {
    display: flex;
}

.termine-list-panel.termine-list-loaded.is-filtering #upcoming-events,
.past-events.termine-list-loaded.is-filtering #past-events {
    position: absolute;
    visibility: hidden;
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .termine-list-skeleton {
        display: none !important;
    }

    .termine-list-panel:not(.termine-list-loaded) #upcoming-events,
    .past-events:not(.termine-list-loaded) #past-events {
        position: static;
        visibility: visible;
        pointer-events: auto;
    }

    .termine-skeleton-line {
        animation: none;
    }
}

.termine-empty {
    margin: 0;
    color: var(--color-text-light);
}

.events-intro {
    padding-right: var(--spacing-md);
    text-align: left;
}

.events-intro > .page-ika-title:first-child {
    margin-bottom: var(--page-title-intro-gap);
}

.events-intro .site-quote {
    margin: 0 0 var(--spacing-md);
    text-align: left;
}

.events-intro .lead-text,
.events-intro .lead-text p {
    margin: 0;
    text-align: left;
}

.events-list {
    display: flex;
    flex-direction: column;
    min-width: 0;
    max-width: 100%;
}

@media (max-width: 768px) {
    .termine-page {
        grid-template-columns: 1fr;
        column-gap: 0;
    }

    .termine-page > .past-events {
        grid-column: 1;
    }

    .two-column {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .home-page {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-md);
    }

    .home-hero.two-column {
        display: grid;
        grid-template-columns: 1fr;
    }

    .home-promo-band {
        display: block;
        border-top: 1px solid var(--color-border);
        padding-top: var(--spacing-md);
    }

    .home-promo-band__grid {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-md);
    }

    .home-intro,
    .home-upcoming,
    .home-bibliothek-promo,
    .home-yoga-im-alltag-promo {
        grid-column: auto;
        grid-row: auto;
        padding-top: 0;
        border-top: none;
    }

    .home-bibliothek-promo__link {
        padding-right: 0;
        border-right: none;
    }

    .home-yoga-im-alltag-promo__link {
        grid-template-columns: 1fr;
        padding-top: var(--spacing-md);
        border-top: 1px solid var(--color-border);
    }

    .home-yoga-im-alltag-promo {
        --home-yoga-promo-thumb: 5.75rem;
    }

    .home-yoga-im-alltag-promo__head-row--labels,
    .home-yoga-im-alltag-promo__head-row--titles {
        flex-wrap: wrap;
    }

    .home-yoga-im-alltag-promo__eyebrow--end,
    .home-yoga-im-alltag-promo__price {
        text-align: left;
    }

    .home-yoga-im-alltag-promo__lead {
        max-width: none;
    }


    .events-intro {
        padding-right: 0;
    }
}

.termine-list-panel .admin-filter-bar {
    margin-bottom: var(--termine-block-gap);
    padding: 0;
    border-bottom: none;
}

.two-column .admin-filter-row {
    margin-bottom: 0.35rem;
}

.termine-list-panel .events-list > .event-row:first-child {
    padding-top: 0;
}

/* Vergangene Termine 2-spaltig: kein Einzel-Padding — Abstand nur über row-gap */
.events-list--past-two-col > .past-event-row {
    padding-block: 0;
}

/* ===== NEWSLETTER PAGE ===== */
.page-newsletter-signup {
    display: grid;
    grid-template-columns: minmax(0, 40%) minmax(0, 60%);
    column-gap: var(--spacing-lg);
    row-gap: var(--page-title-intro-gap);
    align-items: start;
    width: 100%;
    max-width: 100%;
}

.page-newsletter-signup > * {
    min-width: 0;
}

.page-newsletter-page-title {
    margin: 0;
    grid-column: 1;
    grid-row: 1;
}

.page-newsletter-intro {
    grid-column: 1;
    grid-row: 2;
    padding-right: var(--spacing-md);
    align-self: start;
}

.page-newsletter-form-col {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
}

.page-newsletter-legal {
    margin: var(--spacing-md) 0 0;
    text-align: left;
}

.page-newsletter-legal a {
    color: var(--color-text-light);
    text-decoration-color: color-mix(in srgb, var(--color-accent) 40%, transparent);
}

.page-newsletter-form-wrap {
    margin: 0;
}

.page-newsletter-fields {
    display: grid;
    gap: var(--kontakt-text-gap);
}

.page-newsletter-fields .page-kontakt-form-row--2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--kontakt-text-gap);
}

@media (max-width: 768px) {
    .page-newsletter-fields .page-kontakt-form-row--2 {
        grid-template-columns: 1fr;
    }
}

.page-newsletter-form-footer {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.page-newsletter-form-footer-consent {
    flex: 1 1 auto;
    min-width: 0;
}

.page-newsletter-form-footer-consent .page-kontakt-form-field {
    margin: 0;
}

.page-newsletter-form-footer-submit {
    flex: 0 0 auto;
    margin-left: auto;
}

.page-newsletter-form-footer-submit .btn-inline {
    width: auto;
    justify-content: center;
    white-space: nowrap;
}

@media (max-width: 768px) {
    .page-newsletter-signup {
        grid-template-columns: 1fr;
        row-gap: var(--spacing-md);
    }

    .page-newsletter-page-title,
    .page-newsletter-intro,
    .page-newsletter-form-col {
        grid-column: 1;
    }

    .page-newsletter-page-title {
        grid-row: 1;
    }

    .page-newsletter-intro {
        grid-row: 2;
        padding-right: 0;
    }

    .page-newsletter-form-col {
        grid-row: 3;
    }

    .page-newsletter-form-footer {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-sm);
    }

    .page-newsletter-form-footer-submit {
        margin-left: 0;
        align-self: flex-end;
    }
}

.event-row.filtered-out,
.past-event-row.filtered-out,
.events-list--filter-animated > .event-row[hidden] {
    display: none !important;
}

/* Filter-Animation (Termine) */
.events-list--filter-animated > .event-row.event-row--filter-leave {
    opacity: 0;
    transform: translateY(-6px);
    transition:
        opacity 0.22s ease-out,
        transform 0.22s ease-out;
    pointer-events: none;
}

.events-list--filter-animated > .event-row.event-row--filter-move {
    transition:
        transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.28s ease-out;
    will-change: transform, opacity;
}

@media (prefers-reduced-motion: reduce) {
    .events-list--filter-animated > .event-row.event-row--filter-leave,
    .events-list--filter-animated > .event-row.event-row--filter-move {
        transition: none;
        transform: none;
        opacity: 1;
    }
}

.event-row.filtered-in,
.past-event-row.filtered-in {
    display: flex !important;
}

.events-list .event-row.filtered-in,
.events-list .past-event-row.filtered-in {
    display: grid !important;
}

a.event-row,
a.past-event-row,
.event-row,
.past-event-row {
    display: flex;
    align-items: flex-start;
    min-height: 80px;
    min-width: 0;
    max-width: 100%;
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--color-border);
    transition: background 0.2s ease, opacity 0.25s ease;
}

a.event-row,
a.past-event-row {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

/* Terminliste: Textblock max. so hoch wie Thumbnail */
.events-list .event-row,
.events-list .past-event-row {
    display: grid;
    grid-template-columns: var(--listing-thumb-w) minmax(0, 1fr);
    column-gap: var(--spacing-sm);
    align-items: start;
    min-height: 0;
    border-bottom: none;
}

.events-list .event-image {
    grid-column: 1;
    grid-row: 1;
    align-self: start;
    width: var(--listing-thumb-w);
    height: var(--listing-thumb-h);
}

.events-list .event-row-copy {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    align-self: start;
    width: 100%;
}

/* Terminliste: links Titel→Datum, rechts Tags→Ort (jeweils Zeilenabstand) */
.events-list .event-row-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto;
    align-items: start;
    column-gap: var(--spacing-sm);
    width: 100%;
    min-width: 0;
}

.events-list .event-row-primary,
.events-list .event-row-aside {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    min-width: 0;
}

.events-list .event-row-primary {
    grid-column: 1;
}

.events-list .event-row-aside {
    grid-column: 2;
    align-items: flex-end;
    max-width: min(100%, 14rem);
}

.events-list .event-row-primary > .event-title,
.events-list .event-row-primary > .past-event-title {
    max-height: var(--listing-title-max-height);
    width: 100%;
}

.events-list .event-row-aside > .event-location {
    margin-top: var(--listing-baseline-row-gap);
    width: max-content;
    max-width: 100%;
    text-align: right;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.events-list .event-title.type-subline,
.events-list .past-event-title.type-subline {
    font-size: var(--listing-title-subline-size);
    line-height: var(--listing-title-subline-line);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    width: 100%;
    margin: 0;
    padding: var(--listing-title-offset-top) 0 0;
    text-box-trim: trim-start;
    text-box-edge: cap alphabetic;
    transition: color 0.2s ease;
}

a.event-row:hover .event-title.type-subline,
a.past-event-row:hover .past-event-title.type-subline {
    color: var(--color-text);
}

.events-list .event-date {
    margin: 0;
    white-space: nowrap;
    font-weight: var(--mono-value-weight);
}

@media (max-width: 768px) {
    .events-list .event-row-main {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }

    .events-list .event-row-primary,
    .events-list .event-row-aside {
        grid-column: 1;
        align-items: flex-start;
        max-width: 100%;
    }

    .events-list .event-row-aside {
        margin-top: var(--listing-stack-line);
    }

    .events-list .event-row-aside > .event-location {
        margin-top: var(--listing-baseline-row-gap);
        text-align: left;
    }

    .events-list .event-meta,
    .events-list .past-event-meta {
        justify-content: flex-start;
        margin: 0;
        width: auto;
    }

    .events-list .event-date {
        white-space: normal;
    }
}

a.event-row:hover,
a.past-event-row:hover,
.event-row:hover,
.past-event-row:hover {
    background: rgba(0, 0, 0, 0.02);
}

.event-image {
    background-size: cover;
    background-position: center;
    border-radius: 8px;
    display: block;
    width: 120px;
    height: 80px;
    flex-shrink: 0;
    filter: grayscale(1) brightness(1.2) contrast(0.65);
    transition: filter 0.4s ease;
}

a.event-row:hover .event-image,
a.past-event-row:hover .event-image,
.event-row:hover .event-image,
.past-event-row:hover .event-image {
    filter: none;
}

.event-image--dummy {
    background-color: #e5e5e5;
    background-size: cover;
    background-position: center;
    filter: none;
}

a.event-row:hover .event-image--dummy,
a.past-event-row:hover .event-image--dummy,
.event-row:hover .event-image--dummy,
.past-event-row:hover .event-image--dummy {
    filter: none;
}

.event-content,
.past-event-info {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: var(--listing-stack-gap);
    margin-left: var(--spacing-sm);
    flex: 1;
    min-width: 0;
    box-sizing: border-box;
}

.event-details,
.past-event-details {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-end;
    gap: var(--listing-details-gap);
    flex: 0 1 auto;
    min-width: 0;
    max-width: 38%;
    margin-left: var(--spacing-sm);
    text-align: right;
    box-sizing: border-box;
}

.event-details .event-date,
.past-event-details .event-date {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.1rem;
    margin: 0;
    text-align: right;
}

.events-list .event-details .event-date,
.events-list .past-event-details .event-date {
    display: block;
}

.event-details .event-date-primary,
.past-event-details .event-date-primary {
    display: block;
}

.event-details .event-date-primary,
.past-event-details .event-date-primary {
    overflow-wrap: anywhere;
}

/* Wiederkehrend: bei Hover auf Zeile Datum ↔ „wöchentlich“ tauschen */
.event-date--swap .event-date-swap {
    display: grid;
    grid-template-areas: 'stack';
    justify-items: start;
    text-align: left;
    max-width: 100%;
}

.event-date--swap .event-date-primary,
.event-date--swap .event-date-alt {
    grid-area: stack;
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-value-line);
    color: var(--color-text);
    transition: opacity 0.28s ease, transform 0.28s ease;
}

.event-date--swap .event-date-alt {
    color: var(--color-accent);
    letter-spacing: 0.04em;
    opacity: 0;
    transform: translateY(0.35em);
    pointer-events: none;
}

/* Mehrtägig: bei Hover auf Zeile Ort ↔ „mehrtägig“ tauschen */
.event-location--swap .event-location-swap {
    display: grid;
    grid-template-areas: 'stack';
    justify-items: end;
    text-align: right;
    max-width: 100%;
}

.event-location--swap .event-location-primary,
.event-location--swap .event-location-alt {
    grid-area: stack;
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-secondary-line);
    color: var(--color-text-light);
    transition: opacity 0.28s ease, transform 0.28s ease;
}

.event-location--swap .event-location-alt,
.event-location-multiday {
    color: var(--color-accent);
    letter-spacing: 0.04em;
    text-transform: lowercase;
}

.event-location--swap .event-location-alt {
    opacity: 0;
    transform: translateY(0.35em);
    pointer-events: none;
}

.event-location-multiday {
    display: block;
    text-align: right;
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-secondary-line);
}

@media (hover: hover) {
    a.event-row:hover .event-date--swap .event-date-primary,
    a.past-event-row:hover .event-date--swap .event-date-primary {
        opacity: 0;
        transform: translateY(-0.35em);
    }

    a.event-row:hover .event-date--swap .event-date-alt,
    a.past-event-row:hover .event-date--swap .event-date-alt {
        opacity: 1;
        transform: translateY(0);
    }

    a.event-row:hover .event-location--swap .event-location-primary,
    a.past-event-row:hover .event-location--swap .event-location-primary {
        opacity: 0;
        transform: translateY(-0.35em);
    }

    a.event-row:hover .event-location--swap .event-location-alt,
    a.past-event-row:hover .event-location--swap .event-location-alt {
        opacity: 1;
        transform: translateY(0);
    }

    a.event-row:hover .event-title:not(.type-subline),
    a.past-event-row:hover .past-event-title:not(.type-subline) {
        color: var(--color-accent);
    }
}

@media (prefers-reduced-motion: reduce) {
    .event-date--swap .event-date-primary,
    .event-date--swap .event-date-alt,
    .event-location--swap .event-location-primary,
    .event-location--swap .event-location-alt {
        transition: none;
    }
}

.location-tag {
    background: transparent;
    color: var(--color-text);
    padding: 0;
    font-family: var(--font-body);
    font-weight: 400;
    text-transform: none;
    letter-spacing: normal;
}

.event-location {
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-secondary-line);
    color: var(--color-text-light);
    text-align: right;
    margin-top: 0;
    overflow-wrap: anywhere;
}

.event-title,
.past-event-title {
    min-width: 0;
    margin: 0;
    line-height: var(--listing-title-line);
}

.event-row .event-title a,
.past-event-row .past-event-title a {
    font-family: var(--listing-title-font);
    font-size: var(--listing-title-size);
    font-weight: var(--listing-title-weight);
    line-height: var(--listing-title-line);
    letter-spacing: normal;
    text-transform: none;
    color: var(--color-text);
    text-decoration: none;
    overflow-wrap: anywhere;
}

.event-row .event-title a:hover,
.past-event-row .past-event-title a:hover {
    color: var(--color-accent);
}

a.event-row .event-title:not(.type-subline),
a.past-event-row .past-event-title:not(.type-subline),
.events-list .event-title:not(.type-subline),
.events-list .past-event-title:not(.type-subline) {
    font-family: var(--listing-title-font);
    font-size: var(--listing-title-size);
    font-weight: var(--listing-title-weight);
    line-height: var(--listing-title-line);
    letter-spacing: normal;
    text-transform: none;
    color: var(--color-text);
    overflow-wrap: anywhere;
    transition: color 0.2s ease;
}

.event-date {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    font-weight: var(--mono-value-strong-weight);
    line-height: var(--mono-value-line);
    color: var(--color-text);
}

.events-list .event-meta,
.events-list .past-event-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: flex-end;
    gap: var(--listing-label-gap);
    line-height: 1;
    width: max-content;
    max-width: 100%;
    margin: 0;
}

.events-list .event-meta .label,
.events-list .past-event-meta .label {
    font-size: var(--listing-label-size) !important;
    line-height: var(--listing-label-line) !important;
    padding: var(--listing-label-pad-y) var(--listing-label-pad-x) !important;
}

.past-events {
    margin-top: 0;
    max-width: 100%;
    min-width: 0;
}

.past-events .page-ika-section-title {
    margin-bottom: var(--termine-block-gap);
}

.events-list.events-list--past-two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: var(--spacing-md);
    row-gap: var(--spacing-sm);
    align-items: start;
}

.events-list--past-two-col > .past-event-row {
    border-bottom: none;
    align-self: start;
}

@media (max-width: 768px) {
    .events-list.events-list--past-two-col {
        grid-template-columns: 1fr;
    }
}

.past-event-row {
    opacity: 0.7;
}

.past-event-row:hover {
    opacity: 1;
}

.past-event-details {
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    line-height: var(--mono-secondary-line);
    color: var(--color-text-light);
}

/* ===== ADMIN DASHBOARD ===== */
.admin-dashboard .media-section__header .type-section {
    margin: 0;
}

.admin-dashboard h3.type-label {
    margin: 0 0 0.75rem;
}

.admin-dashboard h3.type-label--spaced {
    margin: 1rem 0 0.75rem;
}

.admin-dashboard .item-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--color-text);
}

.admin-dashboard .item-meta {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-dashboard .event-date,
.admin-dashboard .stats-number,
.admin-dashboard .stats-value,
.admin-dashboard .stat-number {
    font-family: 'JetBrains Mono', monospace !important;
}

.admin-dashboard .event-color-bar {
    border-radius: 0 3px 3px 0;
}

.admin-dashboard .hidden-item {
    opacity: 0.5;
    background: #f9f9f9;
}

.admin-dashboard .hidden-item .item-title {
    color: var(--color-text-light);
}

.admin-dashboard .past-event {
    opacity: 0.7;
}

.admin-dashboard .item-actions {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
}

.admin-dashboard .item-actions a {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.admin-dashboard .item-actions a[title="Löschen"] {
    font-size: 1.2rem;
    line-height: 1;
    color: #c62828;
    text-decoration: none;
}

.admin-dashboard .item-title a {
    text-decoration: none;
    color: inherit;
}

.admin-filter-bar {
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--color-border);
}

.admin-dashboard .admin-filter-bar {
    margin-bottom: var(--spacing-sm);
    padding: 0;
    border-bottom: none;
}

.admin-filter-row {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xs);
}

.admin-filter-row:last-child {
    margin-bottom: 0;
}

.admin-filter-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-light);
    min-width: 70px;
    flex-shrink: 0;
}

.admin-filter-buttons {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.admin-event-row {
    transition: all 0.3s ease;
}

.admin-event-row.hidden {
    opacity: 0;
    transform: translateX(-10px);
    pointer-events: none;
    height: 0;
    padding: 0;
    margin: 0;
    overflow: hidden;
}

.admin-event-row.filtered-in {
    opacity: 1;
    transform: translateX(0);
}

/* Stats Period Buttons */
.stats-period-btn {
    border: 1px solid var(--color-border);
    background: transparent;
    color: var(--color-text-light);
    cursor: pointer;
}

.stats-period-btn:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.stats-period-btn.active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: white;
}

/* Page Management */
.page-section {
    margin-bottom: var(--spacing-sm);
}

.page-list {
    border: none;
    border-radius: 0;
    overflow: visible;
}

.page-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-bg);
    border-bottom: none;
    transition: background 0.2s ease;
}

.page-item:hover {
    background: #f9f9f9;
}

.page-info {
    flex: 1;
    min-width: 0;
}

.page-info .item-title {
    display: block;
    font-family: var(--font-serif);
    font-size: 0.95rem;
}

/* ===== ADMIN EDIT ===== */
.admin-edit-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    max-width: var(--layout-content-max);
    margin: 0 0 0.65rem;
    padding: 0.35rem 0;
    border-bottom: 1px solid var(--color-border);
}

.admin-edit-toolbar__start,
.admin-edit-toolbar__end {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.admin-edit-toolbar__link {
    font-family: var(--font-mono);
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text);
    text-decoration: none;
}

.admin-edit-toolbar__link:hover {
    color: var(--color-accent);
}

.admin-draft-badge,
.admin-edit-toolbar__badge {
    display: inline-block;
    flex-shrink: 0;
    font-family: var(--font-mono);
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.2;
    color: var(--color-text-light);
    border: 1px solid var(--color-border);
    border-radius: 3px;
    padding: 0.12rem 0.35rem;
}

.admin-event-row .item-actions .admin-draft-badge {
    flex-shrink: 0;
}

.admin-edit-toolbar__status {
    font-family: var(--font-mono);
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-light);
    min-height: 1em;
}

.admin-edit-toolbar__status[data-state="pending"] {
    color: var(--color-accent);
}

.admin-edit-toolbar__status[data-state="error"] {
    color: #b3261e;
}

.admin-edit-wrapper {
    position: relative;
    max-width: 800px;
    margin: 0;
    overflow: visible;
}

.admin-edit-container {
    display: flex;
    flex-direction: column;
    overflow: visible;
}

.preview-area {
    position: relative;
    background: transparent;
    padding: 0;
    max-width: 800px;
    overflow: visible;
}

.preview-area .event-detail {
    max-width: var(--layout-content-max);
    margin: 0;
    overflow: visible;
}

.event-stats-overlay {
    position: absolute;
    inset: 0;
    z-index: 80;
    box-sizing: border-box;
    pointer-events: none;
}

.block-image:has(.event-stats-overlay:not([hidden])) {
    overflow: hidden;
    border-radius: 12px;
}

.event-stats-overlay:not([hidden]) {
    pointer-events: auto;
}

.event-stats-overlay__inner {
    position: relative;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    padding: 0;
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
}

.event-stats-overlay__close {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    z-index: 3;
    flex-shrink: 0;
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.38);
    color: #fff;
    font-size: 1rem;
    line-height: 1.5rem;
    text-align: center;
    cursor: pointer;
    opacity: 0.85;
    transition: opacity 0.2s ease, background 0.2s ease;
}

.event-stats-overlay__close:hover,
.event-stats-overlay__close:focus-visible {
    opacity: 1;
    background: rgba(0, 0, 0, 0.55);
    outline: none;
}

.event-stats-overlay__body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
    overflow: hidden;
    padding: 0;
}

.admin-stats-widget--overlay {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
}

.admin-stats-widget--overlay .admin-stats-widget__chart {
    flex: 1 1 auto;
    min-height: 5rem;
    height: auto;
    margin: 0;
    padding: 0 0.65rem;
    align-items: flex-end;
    background: #fff;
}

.admin-stats-widget--overlay .admin-stats-widget__bar-fill {
    background: rgba(0, 0, 0, 0.12);
}

.admin-stats-widget--overlay .admin-stats-widget__bar-fill.is-today {
    background: var(--color-accent, #c9a959);
}

.admin-stats-widget--overlay .admin-stats-widget__bar.is-active .admin-stats-widget__bar-fill {
    background: var(--color-accent, #c9a959);
}

.admin-stats-widget--overlay .admin-stats-widget__summary {
    flex: 0 0 auto;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem 0.75rem;
    margin: 0;
    padding: 0.5rem 0.65rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    font-size: 0.72rem;
}

.admin-stats-widget--overlay .admin-stats-widget__summary.is-bar-selected .admin-stats-widget__metric--token .admin-stats-widget__value {
    color: var(--color-accent, #c9a959);
}

.admin-stats-widget--overlay .admin-stats-widget__metric {
    justify-content: flex-start;
    gap: 0.3rem;
}

.admin-stats-widget--overlay .admin-stats-widget__label {
    font-size: 0.6rem;
    color: rgba(0, 0, 0, 0.45);
}

.admin-stats-widget--overlay .admin-stats-widget__value {
    font-size: 1rem;
    font-weight: 600;
}

.admin-stats-widget--overlay .admin-stats-widget__unique {
    font-size: 0.62rem;
}

.admin-stats-widget--overlay .admin-stats-widget__periods {
    flex: 0 0 auto;
    display: flex;
    margin: 0;
    padding: 0;
    gap: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.admin-stats-widget--overlay .admin-stats-widget__period-btn {
    flex: 1 1 0;
    min-width: 0;
    margin: 0;
    padding: 0.45rem 0.25rem;
    border: none;
    border-radius: 0;
    background: transparent;
    color: rgba(0, 0, 0, 0.55);
    font-size: 0.62rem;
    text-align: center;
    transition: background 0.15s ease, color 0.15s ease;
}

.admin-stats-widget--overlay .admin-stats-widget__period-btn + .admin-stats-widget__period-btn {
    border-left: 1px solid rgba(0, 0, 0, 0.08);
}

.admin-stats-widget--overlay .admin-stats-widget__period-btn:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--color-text, #1a1a1a);
}

.admin-stats-widget--overlay .admin-stats-widget__period-btn.is-active {
    background: var(--color-accent, #c9a959);
    color: #fff;
}

.editor-panel,
.image-panel,
#modularPanel {
    position: fixed;
    top: max(0.75rem, env(safe-area-inset-top, 0px));
    right: 1.25rem;
    width: 320px;
    max-height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
    overflow: hidden;
    background: #fff;
    opacity: 1;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.85rem 1rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    isolation: isolate;
    display: flex;
    flex-direction: column;
}

.editor-panel {
    z-index: 1000;
}

.image-panel,
#modularPanel {
    z-index: 1001;
    display: none;
}

.image-panel.active,
#modularPanel.active {
    display: flex;
}

/* Panels: keep header visible, scroll only inner editor */
.editor-panel .panel-header,
.image-panel .panel-header,
#modularPanel .panel-header {
    flex: 0 0 auto;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

#modularPanel #modularPanelText {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* Toggle (FAQ) / Zeitplan / Termine / Terminliste: Panel volle Viewport-Höhe, Liste scrollt innen */
#modularPanel.active[data-panel-text-mode='accordion'],
#modularPanel.active[data-panel-text-mode='timetable'],
#modularPanel.active[data-block-type='dates'],
#modularPanel.active[data-block-type='event-list'] {
    height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
    max-height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
}

#modularPanel.active[data-panel-text-mode='accordion'] #modularPanelTextAccordion,
#modularPanel.active[data-panel-text-mode='timetable'] #modularPanelTextTimetable,
#modularPanel.active[data-block-type='dates'] #modularPanelDates,
#modularPanel.active[data-block-type='event-list'] #modularPanelEventList {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#modularPanel.active[data-panel-text-mode='accordion'] #modularPanelTextAccordion > .editor-field:last-child,
#modularPanel.active[data-panel-text-mode='timetable'] #modularPanelTextTimetable > .editor-field:last-child,
#modularPanel.active[data-block-type='dates'] #modularPanelDates > .editor-field:last-child,
#modularPanel.active[data-block-type='event-list'] #modularPanelEventList > .editor-field {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    margin-bottom: 0;
    overflow: hidden;
}

/* Toggle: Liste + „+ Eintrag“ gemeinsam scrollen, Button direkt unter letztem Abschnitt */
#modularPanel.active[data-panel-text-mode='accordion'] #modularPanelTextAccordion > .editor-field:last-child {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-panel-text-mode='accordion'] #modularPanelTextAccordion > .editor-field:last-child > label {
    flex: 0 0 auto;
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--color-bg-panel, #fff);
    padding-bottom: 0.35rem;
}

#modularPanel.active[data-panel-text-mode='accordion'] .modular-accordion-editor.text-accordion {
    flex: 0 0 auto;
    min-height: 0;
    max-height: none;
    overflow: visible;
}

#modularPanel.active[data-panel-text-mode='timetable'] .modular-timetable-editor,
#modularPanel.active[data-block-type='dates'] .modular-dates-editor,
#modularPanel.active[data-block-type='event-list'] .modular-event-list-picker {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-block-type='dates'] #modularPanelDates,
#modularPanel.active[data-block-type='event-list'] #modularPanelEventList {
    display: flex;
    flex-direction: column;
}

#modularPanel.active[data-block-type='event-list'] #modularPanelEventList > .type-caption {
    flex: 0 0 auto;
}

#modularPanel.active[data-panel-text-mode='accordion'] .modular-structure-add-btn,
#modularPanel.active[data-panel-text-mode='timetable'] .modular-structure-add-btn,
#modularPanel.active[data-block-type='dates'] .modular-structure-add-btn {
    flex: 0 0 auto;
    margin-top: 0.45rem;
}

.modular-event-list-picker {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.modular-event-list-picker__group {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.modular-event-list-picker__group-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #888;
    padding: 0.15rem 0 0.1rem;
}

.modular-event-list-picker__item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.4rem;
    padding: 0.22rem 0.38rem;
    border: 1px solid var(--color-border, #e5e5e5);
    border-radius: 5px;
    background: #fafafa;
    cursor: pointer;
    font-family: inherit;
    text-transform: none;
    letter-spacing: normal;
    color: inherit;
    margin: 0;
}

.modular-event-list-picker__item input[type='checkbox'] {
    margin: 0;
    flex: 0 0 14px;
    width: 14px;
    height: 14px;
    min-width: 14px;
    padding: 0;
    border: none;
    border-radius: 0;
    box-sizing: border-box;
}

.modular-event-list-picker__item-copy {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    column-gap: 0.45rem;
    row-gap: 0.05rem;
}

.modular-event-list-picker__title {
    display: inline;
    font-size: 0.78rem;
    line-height: 1.25;
    color: #222;
}

.modular-event-list-picker__date {
    display: inline;
    font-family: Courier, 'Courier New', monospace;
    font-size: 0.68rem;
    line-height: 1.2;
    color: #666;
    white-space: nowrap;
}

.modular-event-list-picker__item:has(input:checked) {
    border-color: var(--color-accent, #b8860b);
    background: #fffaf0;
}

.modular-event-list-picker__empty,
.modular-event-list-picker__loading {
    margin: 0;
    font-size: 0.75rem;
}

#modularPanel.active[data-block-type='event-list'] #modularPanelEventList > .editor-field > .modular-event-list-search {
    flex: 0 0 auto;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 0.35rem;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 0.75rem;
    padding: 0.35rem 0.5rem;
    border: 1px solid var(--color-border, #e5e5e5);
    background: var(--color-bg, #fff);
    color: var(--color-text, #222);
    border-radius: 2px;
}

#modularPanel.active[data-block-type='event-list'] #modularPanelEventList > .editor-field > label:first-child {
    flex: 0 0 auto;
    font-size: 0.72rem;
    margin-bottom: 0.25rem;
}

#modularPanel.active[data-block-type='event-list'] #modularPanelEventList > .type-caption {
    font-size: 0.68rem;
    line-height: 1.35;
    margin-top: 0.35rem;
}

.modular-dates-editor {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.modular-dates-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0.55rem;
    border: 1px solid var(--color-border, #e5e5e5);
    border-radius: 8px;
    background: #fafafa;
}

.modular-dates-input {
    flex: 1 1 auto;
    min-width: 0;
    font: inherit;
    padding: 0.35rem 0.5rem;
    border: 1px solid #ccc;
    border-radius: 6px;
}

.modular-dates-weekday-hint {
    flex: 0 0 auto;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-muted, #666);
    min-width: 1.75rem;
}

#modularPanel .modular-dates-item .modular-structure-remove {
    flex: 0 0 auto;
    margin-left: auto;
}

#modularPanel .editor-field--quill {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#modularPanel.active[data-panel-text-mode='normal'] #modularPanelTextNormal,
#modularPanel.active[data-panel-text-mode='note'] #modularPanelTextNormal,
#modularPanel.active[data-panel-text-mode='box'] #modularPanelTextNormal,
#modularPanel.active[data-panel-text-mode='sticker-duo'] #modularPanelTextNormal,
#modularPanel.active[data-panel-text-mode='footnote'] #modularPanelTextNormal,
#modularPanel.active[data-block-type='combo'] #modularPanelTextNormal,
#modularPanel.active[data-block-type='trainer'] #modularPanelTextNormal {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Combo 50/50 — Tabs + Typ oben, darunter Spalten-Editor */
#modularPanel.active[data-combo-layout='50-50'] #modularPanelComboColumns {
    order: 0;
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 0.5rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
}

#modularPanel.active[data-combo-layout='50-50'] .editor-field--combo-column-tabs {
    margin-bottom: 0.35rem;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem;
    width: 100%;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-tabs .combo-column-tab {
    width: 100%;
    margin: 0;
    padding: 0.1rem 0.3rem;
    min-height: 0;
    height: auto;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    background: #fff;
    font-family: var(--mono-font);
    font-size: 0.62rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: var(--mono-label-spacing);
    color: var(--color-text);
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-tabs .combo-column-tab:hover:not(.active):not([aria-pressed='true']) {
    border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    color: var(--color-accent);
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-tabs .combo-column-tab.active,
#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-tabs .combo-column-tab[aria-pressed='true'] {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-switch-btn {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 0.35rem;
    align-items: center;
    width: 100%;
    margin-top: 0.35rem;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    min-height: 0;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-switch-btn__line {
    height: 1px;
    background: color-mix(in srgb, var(--color-border) 85%, transparent);
    transition: background 0.15s ease;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-switch-btn__label {
    font-family: var(--mono-font);
    font-size: 0.55rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    line-height: 1;
    color: var(--color-text-light);
    transition: color 0.15s ease;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-switch-btn:hover .modular-combo-column-switch-btn__label {
    color: var(--color-accent);
}

#modularPanel.active[data-combo-layout='50-50'] .modular-combo-column-switch-btn:hover .modular-combo-column-switch-btn__line {
    background: var(--color-accent);
}

#modularPanel.active[data-block-type='trainer'] .editor-field--text-mode,
#modularPanel.active[data-block-type='trainer'] .editor-field--combo-type,
#modularPanel.active[data-block-type='trainer'] #modularComboTypeField {
    display: none !important;
}

#modularPanel.active[data-block-type='trainer'] #modularMixedImageShape {
    display: none !important;
}

#modularPanel.active[data-block-type='trainer'] .ql-formats--columns {
    display: none !important;
}

#modularPanel.active[data-block-type='trainer'] {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelText {
    flex: 0 0 auto;
    min-height: 0;
    overflow: visible;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelTextNormal {
    flex: 0 0 auto;
}

#modularPanel.active[data-block-type='combo'] .editor-field--normal-headline,
#modularPanel.active[data-combo-layout='50-50'] .editor-field--normal-headline {
    display: none !important;
}

#modularPanel[data-panel-text-mode='normal'] .editor-field--normal-headline {
    flex: 0 0 auto;
    width: 100%;
}

#modularPanel[data-panel-text-mode='normal'] .modular-normal-headline-input {
    width: 100%;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerName,
#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerSpecialty,
#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerWebsite {
    display: grid;
    grid-template-columns: minmax(2.75rem, max-content) minmax(0, 1fr);
    align-items: center;
    column-gap: 0.45rem;
    flex: 0 0 auto;
    width: 100%;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerName label,
#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerSpecialty label,
#modularPanel.active[data-block-type='trainer'] #modularPanelTrainerWebsite label {
    margin-bottom: 0;
    white-space: nowrap;
}

#modularPanel.active[data-block-type='trainer'] .modular-trainer-name-input,
#modularPanel.active[data-block-type='trainer'] .modular-trainer-specialty-input,
#modularPanel.active[data-block-type='trainer'] .modular-trainer-website-input {
    width: 100%;
    min-width: 0;
}

#modularPanel.active[data-block-type='trainer'] .editor-field--quill {
    flex: 0 0 auto;
    min-height: 0;
}

#modularPanel.active[data-block-type='trainer'] .editor-field--quill .modular-quill-wrap {
    flex: 0 0 auto;
    min-height: calc(7.5rem + 1.75rem);
    max-height: min(calc(10.5rem + 1.75rem), 36vh);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-block-type='trainer'] .editor-field--quill .ql-container,
#modularPanel.active[data-block-type='trainer'] .editor-field--quill .ql-editor {
    min-height: 7.5rem !important;
    max-height: 10.5rem;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelMixed {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    width: 100%;
    min-height: 0;
    order: 2;
    gap: 0;
}

#modularPanel.active[data-block-type='trainer'] #modularPanelMixedImageText,
#modularPanel.active[data-block-type='trainer'] .editor-field--mixed-image,
#modularPanel.active[data-block-type='trainer'] .editor-field--mixed-swap {
    width: 100%;
}

#modularPanel.active[data-block-type='trainer'] .modular-mixed-image-preview {
    width: 100%;
    max-width: 100%;
    min-height: 9rem;
}

#modularPanel.active[data-block-type='trainer'] .modular-mixed-image-preview--shape-circle {
    width: min(100%, 9.5rem);
    margin-inline: auto;
}

#modularPanel.active[data-block-type='trainer'] .modular-mixed-image-preview:not(.modular-mixed-image-preview--has-image) {
    min-height: 9.5rem;
}

#modularPanel.active[data-block-type='trainer'] .editor-field:has(#modularMixedImageCaption) {
    display: none !important;
}

.block-trainer .event-trainer__headline {
    width: 100%;
    margin: 0 0 0.2rem;
}

.block-trainer .event-trainer__name {
    --trainer-mono-baseline-adjust: -0.18em;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    margin: 0;
    text-align: left;
    hyphens: none;
}

.block-trainer .event-trainer__name-group {
    flex: 1 1 auto;
    min-width: 0;
}

.block-trainer .event-trainer__name .text-mark {
    font-family: var(--font-h1);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 400;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-accent);
    text-box-trim: trim-both;
    text-box-edge: cap alphabetic;
}

.block-trainer .event-trainer__name .event-trainer__specialty {
    display: inline;
    margin-left: 0.45rem;
    line-height: 1;
    vertical-align: var(--trainer-mono-baseline-adjust);
    text-transform: uppercase;
}

.block-trainer .event-trainer__name .event-trainer__website-link {
    display: inline;
    line-height: 1;
    vertical-align: var(--trainer-mono-baseline-adjust);
    text-transform: uppercase;
}

.event-trainer__specialty {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    line-height: var(--mono-value-line);
    font-weight: var(--mono-value-weight);
    letter-spacing: var(--mono-label-spacing);
    text-transform: uppercase;
}

.block-trainer .event-trainer__name .event-trainer__website,
.block-trainer .event-trainer__website {
    flex: 0 0 auto;
    margin: 0;
    text-align: right;
    white-space: nowrap;
}

.block-trainer .event-trainer__name:not(:has(.text-mark)) {
    justify-content: flex-end;
}

.event-trainer__website-link {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    line-height: var(--mono-value-line);
    font-weight: var(--mono-value-weight);
    letter-spacing: 0.02em;
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-accent);
    text-underline-offset: 0.15em;
}

.event-trainer__website-link:hover,
.event-trainer__website-link:focus-visible {
    color: var(--color-accent);
    text-decoration-color: var(--color-accent);
}

#modularPanel.active[data-combo-layout='50-50'] .editor-field--combo-column-type {
    margin-bottom: 0;
}

#modularPanel.active[data-combo-layout='50-50'] #modularMixedImageShape [data-mixed-image-shape='circle'] {
    display: none !important;
}

#modularPanel.active[data-combo-layout='50-50'] .editor-field--text-mode,
#modularPanel.active[data-combo-layout='50-50'] .editor-field--mixed-swap,
#modularPanel.active[data-combo-layout='50-50'] #modularComboTypeField {
    display: none !important;
}

#modularPanel.active[data-combo-layout='50-50'] #modularPanelText,
#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixed {
    order: 2;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixed {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
}

#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixedImageText,
#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixedVideoText,
#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixedGalleryText {
    width: 100%;
    min-width: 0;
}

#modularPanel.active[data-combo-layout='50-50'] .editor-field--mixed-image,
#modularPanel.active[data-combo-layout='50-50'] .editor-field--combo-video,
#modularPanel.active[data-combo-layout='50-50'] .editor-field--combo-gallery {
    width: 100%;
}

#modularPanel.active[data-combo-layout='50-50'] .modular-mixed-image-preview {
    width: 100%;
    max-width: none;
}

#modularPanel.active[data-combo-layout='50-50'] #modularPanelText[hidden],
#modularPanel.active[data-combo-layout='50-50'] #modularPanelMixed[hidden],
#modularPanel.active[data-combo-layout='50-50'][data-combo-column-editor='text'] #modularPanelMixed,
#modularPanel.active[data-combo-layout='50-50'][data-combo-column-editor='sticker'] #modularPanelMixed {
    display: none !important;
}

#modularPanel.active[data-combo-layout='50-50'][data-combo-column-editor='image'] #modularPanelText,
#modularPanel.active[data-combo-layout='50-50'][data-combo-column-editor='video'] #modularPanelText,
#modularPanel.active[data-combo-layout='50-50'][data-combo-column-editor='gallery'] #modularPanelText {
    display: none !important;
}

#modularPanel.active[data-block-type='combo']:not([data-combo-layout='50-50']) #modularPanelText {
    order: 1;
    flex: 0 1 auto;
    min-height: 0;
    max-height: min(36rem, 68vh);
    overflow: hidden;
    padding-bottom: 0.4rem;
    margin-bottom: 0.35rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
}

#modularPanel.active[data-block-type='combo']:not([data-combo-layout='50-50']) #modularPanelMixed {
    order: 2;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-block-type='combo'] .editor-field--mixed-swap,
#modularPanel.active[data-block-type='combo'] .editor-field--combo-type {
    margin-bottom: 0.15rem;
}

#modularPanel.active[data-block-type='combo'] .editor-field--mixed-swap label {
    margin-bottom: 0.1rem;
}

#modularPanel.active[data-block-type='combo'] .editor-field--quill {
    flex: 0 0 auto;
    min-height: 0;
}

#modularPanel.active[data-block-type='combo'] .editor-field--quill .modular-quill-wrap {
    flex: 0 0 auto;
    min-height: calc(300px + 1.75rem);
    max-height: min(calc(300px + 2.5rem), 62vh);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

#modularPanel.active[data-block-type='combo'] .editor-field--quill .ql-container,
#modularPanel.active[data-block-type='combo'] .editor-field--quill .ql-editor {
    min-height: 300px !important;
}

#modularPanel.active[data-block-type='combo'] .editor-field--quill .ql-toolbar {
    position: sticky;
    top: 0;
    z-index: 5;
    box-shadow: 0 1px 0 var(--color-border);
}

#modularPanel.active:is(
        [data-panel-text-mode='normal'],
        [data-panel-text-mode='note'],
        [data-panel-text-mode='box'],
        [data-panel-text-mode='sticker-duo'],
        [data-block-type='combo']
    ) {
    height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
    max-height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
}

.event-editor-panel-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 999;
    background: rgba(18, 18, 18, 0.38);
    border: none;
    padding: 0;
    margin: 0;
    cursor: pointer;
}

.event-editor-panel-backdrop:not([hidden]) {
    display: block;
}

body.event-editor-panel-open {
    overflow: hidden;
}

@media (min-width: 769px) {
    body.event-editor-panel-open {
        overflow: auto;
    }

    .event-editor-panel-backdrop:not([hidden]) {
        display: none;
    }
}

.editor-panel .editor-field,
.image-panel .editor-field {
    margin-bottom: 0.45rem;
}

.editor-panel .editor-field:last-child,
.image-panel .editor-field:last-child {
    margin-bottom: 0;
}

.editor-panel .editor-field label:not(.modular-event-list-picker__item),
.image-panel .editor-field label:not(.modular-event-list-picker__item) {
    display: block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-light);
    margin-bottom: 0.15rem;
}

.editor-panel .editor-sublabel,
.image-panel .editor-sublabel {
    font-size: 0.58rem;
    margin-bottom: 0.1rem;
}

.editor-panel .editor-field input:not([type='checkbox']),
.editor-panel .editor-field select,
.editor-panel .editor-field textarea,
.image-panel .editor-field input:not([type='checkbox']),
.image-panel .editor-field select,
.image-panel .editor-field textarea {
    width: 100%;
    padding: 0.35rem 0.45rem;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    font-size: 0.82rem;
    font-family: 'Inter', sans-serif;
    line-height: 1.35;
}

.editor-panel .editor-field input:focus,
.editor-panel .editor-field select:focus,
.editor-panel .editor-field textarea:focus,
.image-panel .editor-field input:focus,
.image-panel .editor-field select:focus,
.image-panel .editor-field textarea:focus {
    outline: none;
    border-color: var(--color-accent);
}

.editor-panel .editor-field-group,
.image-panel .editor-field-group {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
    margin-bottom: 0.45rem;
}

.editor-panel .editor-field-group .editor-field,
.image-panel .editor-field-group .editor-field {
    margin-bottom: 0;
}

.editor-field--personen-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.35rem;
}

.editor-field--personen-row label {
    display: block;
    flex: 0 0 auto;
    margin-bottom: 0;
    white-space: nowrap;
}

.editor-field--personen-row input[type="number"] {
    flex: 1 1 0;
    min-width: 0;
    width: auto;
}

.editor-field--ort .editor-field-ort-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.15rem;
}

.editor-field--ort .editor-field-ort-head label {
    margin-bottom: 0;
}

.editor-field--ort input[name="location"] {
    margin-bottom: 0;
}

.editor-field--ort input[name="location_address_street"],
.editor-field--ort input[name="location_address_city"] {
    margin-top: 0.35rem;
}

.editor-ort-maps-link {
    display: inline-block;
    flex-shrink: 0;
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.58rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-align: right;
    color: var(--color-text-light);
    text-decoration: none;
    border-bottom: 1px solid color-mix(in srgb, var(--color-text-light) 35%, transparent);
    transition: color 0.15s ease, border-color 0.15s ease;
}

.editor-ort-maps-link:hover {
    color: var(--color-accent);
    border-bottom-color: var(--color-accent);
}

.editor-ort-maps-link.is-disabled {
    opacity: 0.35;
    pointer-events: none;
    cursor: default;
}

.editor-field-with-action {
    display: flex;
    align-items: stretch;
    gap: 0.35rem;
}

.editor-field-with-action input {
    flex: 1;
    min-width: 0;
}

.editor-maps-open {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    flex-shrink: 0;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    background: var(--color-bg);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color 0.15s ease, color 0.15s ease;
}

.editor-maps-open:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.editor-field--personen-row input::placeholder {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.62rem;
    text-transform: lowercase;
    letter-spacing: 0.04em;
    color: var(--color-text-light);
    opacity: 0.85;
}

.editor-field-group--preis .editor-field-date-sub {
    margin-top: 0.35rem;
}

.editor-field--inline {
    margin-bottom: 0.35rem !important;
}

.editor-field .checkbox-inline {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-family: 'Inter', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--color-text);
    margin-bottom: 0;
    cursor: pointer;
}

.editor-field .checkbox-inline input {
    width: auto;
    margin: 0;
}

.category-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.category-label {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.45rem;
    border: 1px solid transparent;
    border-radius: 2px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.62rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text);
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.category-label input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.category-label.category-yoga {
    background: var(--color-highlight-yoga);
}

.category-label.category-tanz {
    background: var(--color-highlight-tanz);
}

.category-label.category-coaching {
    background: var(--color-highlight-coaching);
}

.category-label.category-koerperarbeit,
.category-label.category-korperarbeit {
    background: var(--color-highlight-koerperarbeit);
}

.category-label:has(input:checked) {
    border-color: var(--color-text);
    box-shadow: inset 0 0 0 1px var(--color-text);
}

.current-image {
    margin-top: 0.25rem;
    font-size: 0.72rem;
    line-height: 1.4;
}

.delete-link {
    color: #c62828;
}

.editor-actions {
    display: flex;
    gap: 0.4rem;
    margin-top: 0.65rem;
    padding-top: 0.55rem;
    border-top: 1px solid var(--color-border);
}

.editor-panel .panel-actions,
.image-panel .panel-actions {
    margin-top: 0.5rem;
    padding-top: 0;
    border-top: none;
}

.editor-panel .panel-actions .btn-cancel,
.image-panel .panel-actions .btn-cancel {
    width: 100%;
    padding: 0.4rem;
    font-size: 0.68rem;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
    h1 {
        font-size: 2.5rem;
    }

    h2 {
        font-size: 2rem;
    }

    .event-title-h1 {
        font-size: 2rem;
    }

    .title-subline,
    .event-subtitle,
    .type-faq-q,
    .page-ika-faq-heading,
    .text-accordion .text-accordion-heading {
        font-size: 1rem;
    }
    
    .block-facts {
        padding: 0.75rem 1rem;
    }

    .facts-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        column-gap: clamp(0.75rem, 4vw, 1.15rem);
        row-gap: 0.85rem;
    }
    
    nav {
        position: relative;
    }

    .menu-toggle {
        display: flex;
        z-index: 101;
    }
    
    nav ul {
        display: none;
        position: absolute;
        top: calc(100% + 0.5rem);
        right: 0;
        left: auto;
        min-width: min(100vw - 2 * var(--spacing-md), 280px);
        background: var(--color-bg);
        flex-direction: column;
        padding: var(--spacing-md);
        border: 1px solid var(--color-border);
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
        z-index: 100;
    }
    
    nav ul.active {
        display: flex;
    }
    
    h2 { font-size: 1.5rem; }
    h3 { font-size: 1.25rem; }
    
    .footer-content {
        flex-direction: column;
        gap: var(--spacing-sm);
        text-align: center;
    }

    .footer-links {
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
        width: 100%;
    }

    .footer-links a {
        display: block;
        width: 100%;
        line-height: 1.5;
    }

    .footer-admin-link,
    .footer-admin-hint {
        align-self: flex-end;
        margin-top: 0.25rem;
    }
}

/* Event editor panels — mobile bottom sheet */
@media (max-width: 768px) {
    body.admin-edit-page .editor-panel,
    body.admin-edit-page .image-panel,
    body.admin-edit-page #modularPanel {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        top: auto;
        width: 100%;
        max-width: 100%;
        max-height: min(88dvh, calc(100dvh - 0.5rem));
        margin: 0;
        border-radius: 14px 14px 0 0;
        border-bottom: none;
        z-index: 1002;
        padding-bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px));
        box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.22);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    body.admin-edit-page .editor-panel .panel-header,
    body.admin-edit-page .image-panel .panel-header,
    body.admin-edit-page #modularPanel .panel-header {
        flex-wrap: wrap;
        padding-top: 0.35rem;
    }

    body.admin-edit-page .editor-panel .panel-header::before,
    body.admin-edit-page .image-panel .panel-header::before,
    body.admin-edit-page #modularPanel .panel-header::before {
        content: '';
        flex: 0 0 100%;
        width: 2.75rem;
        height: 4px;
        margin: 0 auto 0.45rem;
        border-radius: 999px;
        background: color-mix(in srgb, var(--color-text-light) 35%, var(--color-border));
    }

    body.admin-edit-page .editor-panel .panel-close,
    body.admin-edit-page .image-panel .panel-close,
    body.admin-edit-page #modularPanel .panel-close {
        min-width: 2.25rem;
        min-height: 2.25rem;
        font-size: 1.35rem;
    }

    body.admin-edit-page .block-controls {
        transform: translate(calc(-100% - 0.35rem), -50%);
    }

    body.admin-edit-page #modularPanel.active[data-panel-text-mode='accordion'],
    body.admin-edit-page #modularPanel.active[data-panel-text-mode='timetable'],
    body.admin-edit-page #modularPanel.active[data-panel-text-mode='normal'],
    body.admin-edit-page #modularPanel.active[data-panel-text-mode='note'],
    body.admin-edit-page #modularPanel.active[data-panel-text-mode='footnote'],
    body.admin-edit-page #modularPanel.active[data-block-type='combo'] {
        height: min(88dvh, calc(100dvh - 0.5rem));
        max-height: min(88dvh, calc(100dvh - 0.5rem));
    }
}

/* ===== IMAGE PANEL (Block-specific) ===== */

.editor-panel .panel-header,
.image-panel .panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    margin-bottom: 0.6rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--color-border);
}

.editor-panel .panel-header h3,
.image-panel .panel-header h4 {
    margin: 0;
    padding: 0;
    border-bottom: none;
    flex: 1;
    min-width: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.editor-panel .panel-close,
.image-panel .panel-close {
    flex-shrink: 0;
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    margin: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    color: #888;
}

.editor-panel .panel-close:hover,
.image-panel .panel-close:hover {
    color: #333;
}

.editor-panel .panel-header-actions,
.image-panel .panel-header-actions,
#modularPanel .panel-header-actions {
    display: flex;
    align-items: center;
    gap: 0.2rem;
    flex-shrink: 0;
}

.editor-panel .editor-field--locked-link {
    margin-top: 0.65rem;
}

.editor-panel .event-locked-token-row {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.35rem;
}

.editor-panel .event-locked-token-label {
    flex-shrink: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    color: var(--color-text-light);
}

.editor-panel .event-locked-token-input {
    width: 7.5rem;
    max-width: 100%;
    padding: 0.45rem 0.55rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    color: var(--color-text);
}

.editor-panel .event-locked-link-row {
    display: flex;
    gap: 0.4rem;
    align-items: stretch;
}

.editor-panel .event-locked-link-input {
    flex: 1;
    min-width: 0;
    padding: 0.45rem 0.55rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #f9f9f9;
    color: var(--color-text);
}

.editor-panel .event-locked-link-copy {
    flex-shrink: 0;
    padding: 0.45rem 0.65rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
}

.editor-panel .event-locked-link-copy:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.editor-panel .editor-field-hint {
    margin: 0.35rem 0 0;
    font-size: 0.75rem;
    line-height: 1.4;
    color: var(--color-text-light);
}

.editor-panel .editor-checkbox {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.45rem;
    padding: 0.35rem 0.2rem 0.35rem 0;
    font-family: 'Inter', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    line-height: 1.45;
    color: var(--color-text);
    cursor: pointer;
}

.editor-panel .editor-checkbox input {
    box-sizing: border-box;
    width: 0.85rem;
    height: 0.85rem;
    min-width: 0.85rem;
    margin: 0.12rem 0 0;
    flex-shrink: 0;
    accent-color: var(--color-accent);
    cursor: pointer;
}

.editor-panel .editor-checkbox span {
    padding-top: 0.02rem;
}

.editor-panel .editor-field--weekly-terminliste {
    margin-top: 0.25rem;
}

.editor-panel .editor-field--weekly-terminliste .btn-secondary--compact {
    width: 100%;
}

.editor-panel .editor-field--visibility {
    margin-top: 0.85rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border);
}

.editor-panel .editor-field--protected-password {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.65rem;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border);
}

.editor-panel .editor-field--protected-password label {
    margin-bottom: 0;
    flex-shrink: 0;
    white-space: nowrap;
}

.editor-panel #eventProtectedPassword,
.editor-panel .event-protected-password-input {
    width: 9rem;
    flex: 0 0 auto;
    max-width: 100%;
    box-sizing: border-box;
}

/* Backend-Preview: versteckt / passwortgeschützt → Block-Inhalt 50 % transparent */
.admin-edit-wrapper .preview-block.modular-block--hidden .modular-block-content,
.admin-edit-wrapper .preview-block.modular-block--private .modular-block-content {
    opacity: 0.5;
}

/* Frontend: passwortgeschützte Blöcke */
.private-block-container {
    position: relative;
    margin: 0;
}

.private-content-blurred {
    filter: blur(8px);
    opacity: 0.5;
    pointer-events: none;
    user-select: none;
}

.password-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.9);
}

.password-box {
    text-align: center;
    padding: 2rem;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    max-width: 400px;
    width: 90%;
}

.password-icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.password-box h3 {
    margin: 0 0 0.5rem;
    font-size: 1.2rem;
}

.password-box input {
    padding: 0.75rem;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    text-align: center;
    width: 100%;
    margin-bottom: 0.75rem;
    box-sizing: border-box;
}

.password-box button {
    padding: 0.75rem 1.5rem;
    background: var(--color-accent, #c9a959);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-family: 'JetBrains Mono', monospace;
    width: 100%;
}

.password-error {
    color: #dc3545;
    font-size: 0.8rem;
    margin-top: 0.75rem;
    display: none;
}

.image-panel .image-preview {
    width: 100%;
    height: 120px;
    background: #eee;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.75rem;
    overflow: hidden;
}

.image-panel .image-preview img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
}

.image-panel .image-upload {
    margin-bottom: 0.75rem;
}

.image-panel .image-upload input[type="file"] {
    width: 100%;
    font-size: 0.8rem;
}

.image-panel .image-url {
    margin-bottom: 0.75rem;
}

.image-panel .image-url input {
    width: 100%;
    padding: 0.4rem;
    font-size: 0.8rem;
    border: 1px solid #ddd;
    border-radius: 4px;
}

.image-panel .panel-actions {
    display: flex;
    gap: 0.5rem;
}

.image-panel .panel-actions button {
    flex: 1;
    padding: 0.4rem;
    font-size: 0.75rem;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.image-panel .btn-save {
    background: var(--color-accent);
    color: white;
}

.image-panel .btn-cancel {
    background: #ddd;
    color: #333;
}

/* Image Panel - Compact */
.image-panel .image-preview-small {
    width: 100%;
    height: 80px;
    background: #eee;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.75rem;
    overflow: hidden;
}

.image-panel .image-preview-small img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
}

.image-panel .image-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.image-panel .image-actions button {
    width: 100%;
    padding: 0.5rem;
    font-size: 0.8rem;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    text-align: left;
}

.image-panel .btn-gallery {
    background: #e3f2fd;
    color: #333;
}

.image-panel .btn-gallery--primary {
    background: var(--color-accent);
    color: #fff;
    border: none;
}

.image-panel .btn-delete {
    background: #ffebee;
    color: #c62828;
}

.image-panel .image-gallery {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.image-panel .image-gallery h5 {
    font-size: 0.75rem;
    margin-bottom: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.image-panel .gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    max-height: 200px;
    overflow-y: auto;
}

.image-panel .gallery-grid img {
    width: 100%;
    height: 60px;
    object-fit: cover;
    border-radius: 4px;
    cursor: pointer;
    transition: transform 0.2s;
}

.image-panel .gallery-grid img:hover {
    transform: scale(1.05);
}

/* Image Cropper */
.image-cropper {
    position: relative;
    width: 100%;
    height: 120px;
    overflow: hidden;
    border-radius: 4px;
    background: #eee;
    cursor: grab;
    margin-bottom: 0.75rem;
}

.image-cropper__stage {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.image-cropper__empty {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #999;
    font-size: 0.8rem;
    pointer-events: none;
}

.image-cropper__browse {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    opacity: 0;
    pointer-events: none;
    padding: 0.35rem 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--color-text);
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.image-cropper:not(.image-cropper--has-image) .image-cropper__browse,
.image-cropper:hover .image-cropper__browse,
.image-cropper:focus-within .image-cropper__browse,
.image-cropper__browse:hover,
.image-cropper__browse:focus {
    opacity: 1;
    pointer-events: auto;
}

.image-cropper:active {
    cursor: grabbing;
}

.image-cropper img {
    position: absolute;
    max-width: none;
    user-select: none;
    pointer-events: none;
}

.image-cropper .crop-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border: 2px dashed var(--color-accent);
    pointer-events: none;
}

.image-cropper-info {
    font-size: 0.7rem;
    color: #666;
    text-align: center;
    margin-bottom: 0.5rem;
}

/* Modular event blocks (below mandatory blocks) */
.text-block-content {
    margin: 0;
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}

/* Einspaltig: kein Spaltenlayout, volle Event-Inhaltsbreite */
.text-block-content[data-columns="1"],
.text-note-content[data-columns="1"],
.text-box-content[data-columns="1"],
.text-accordion[data-columns="1"],
.event-content[data-columns="1"] {
    column-count: unset;
    column-gap: unset;
    columns: auto;
    width: 100%;
    max-width: 100%;
}

.text-block-content[data-columns="1"] :is(p, li, ul, ol, blockquote, h1, h2, h3, .text-title, .text-subtitle),
.text-note-content[data-columns="1"] :is(p, li, ul, ol, blockquote),
.event-content[data-columns="1"] :is(p, li, ul, ol, blockquote) {
    max-width: none;
}

.text-block-content p,
.text-block-content li,
.text-block-content blockquote {
    max-width: none;
    margin: 0;
    line-height: var(--type-body-line);
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
}

.text-block-content p:not(.ql-align-center):not(.ql-align-right),
.text-block-content .ql-align-left {
    text-align: justify;
}

.text-block-content .ql-align-center {
    text-align: center;
    hyphens: none;
}

.text-block-content .ql-align-right {
    text-align: right;
    hyphens: none;
}

/* Mehrspaltig: Zeilenraster + natürlicher Spaltenfluss (column-count) */
.text-block-content[data-columns]:not([data-columns="1"]),
.text-note-content[data-columns]:not([data-columns="1"]) {
    --text-col-line: 1.45;
    --text-col-baseline: calc(var(--type-body-size) * var(--text-col-line));
}

/* Absatz: Inline-Bold bleibt im Spaltenfluss (kein Absatz-Sprung durch orphans) */
.text-block-content[data-columns]:not([data-columns="1"]) {
    orphans: 1;
    widows: 1;
}

.text-note-content[data-columns]:not([data-columns="1"]) {
    orphans: 2;
    widows: 2;
}

/* Überschrift / Titel: volle Breite. Absatz-Modus: nur Feld-Headline + Titel, kein p.text-col-headline. */
.text-block-content[data-columns]:not([data-columns="1"]) :is(
    h1.text-title,
    h2.text-subtitle,
    .text-block-headline
),
.text-note-content[data-columns]:not([data-columns="1"]) :is(
    h1.text-title,
    h2.text-subtitle,
    p.text-col-headline
) {
    column-span: all;
    margin: 0;
    break-after: avoid;
}

.text-block-headline {
    font-family: var(--font-h1);
    font-weight: 400;
    font-size: var(--type-text-mark-size);
    line-height: var(--type-text-mark-line);
    margin: 0 0 0.45rem;
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.text-block-content[data-columns]:not([data-columns="1"]) > .text-block-headline {
    margin: 0 0 0.45rem;
}

.text-block-content[data-columns]:not([data-columns="1"]) p.text-col-headline .text-mark,
.text-note-content[data-columns]:not([data-columns="1"]) p.text-col-headline .text-mark {
    display: inline;
    font-size: var(--type-text-mark-size);
    line-height: var(--type-text-mark-line);
    margin: 0;
}

/* Leere Quill-Zeilen (<p><br></p>): eine Rasterzeile im Spaltenfluss */
.text-block-content p:has(> br:only-child),
.text-note-content p:has(> br:only-child) {
    margin: 0;
    padding: 0;
    line-height: var(--type-body-line);
    font-size: var(--type-body-size);
}

.text-block-content[data-columns]:not([data-columns="1"]) p:has(> br:only-child),
.text-note-content[data-columns]:not([data-columns="1"]) p:has(> br:only-child) {
    line-height: var(--text-col-baseline);
}

/* Event-Text: Bold im Block = Headline-Font, Größe wie H2 */
.text-block-content .text-mark,
.text-block-content strong,
.text-block-content b,
.text-note-content .text-mark,
.text-note-content strong,
.text-note-content b {
    font-family: var(--font-h1);
    font-size: var(--type-text-mark-size);
    font-weight: 400;
    line-height: var(--type-text-mark-line);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-accent);
    background: none;
    padding: 0;
    border-radius: 0;
    box-decoration-break: unset;
    -webkit-box-decoration-break: unset;
}

.block-text--note .text-note-content.text-note-content--accent :is(.text-mark, strong, b) {
    color: #fff;
}

.text-block-content .text-emphasis {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-value-line);
    letter-spacing: var(--mono-label-spacing);
    font-style: normal;
    text-transform: none;
    color: var(--color-text);
}

.text-block-content .text-color-accent {
    color: var(--color-accent);
}

.text-block-content .text-color-normal {
    color: var(--color-text);
}

.text-block-content .text-underline {
    text-decoration: underline;
    text-decoration-color: var(--color-accent);
    text-underline-offset: 0.12em;
}

.text-block-content .text-strikethrough,
:is(.ql-editor, #preview-content, .text-block-content, .text-note-content) .text-strikethrough {
    text-decoration: line-through;
    text-decoration-color: currentColor;
}

.text-block-content .text-title,
.text-block-content h1.text-title {
    font-family: var(--font-h1);
    font-size: 1.65rem;
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 0.5rem;
    text-align: inherit;
    hyphens: none;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.text-block-content .text-subtitle,
.text-block-content h2.text-subtitle {
    font-family: var(--font-h1);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 400;
    line-height: 1.15;
    margin: 0.75rem 0 0.45rem;
    text-align: inherit;
    hyphens: none;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-accent);
}

/* Quill-Editor: Bold = echtes Fett (Block-Vorschau nutzt .text-block-content .text-mark) */
#modularPanel .editor-field--quill .ql-editor :is(strong, b, .text-mark) {
    font-family: inherit;
    font-size: inherit;
    font-weight: 700;
    font-style: normal;
    line-height: inherit;
    margin: 0;
    padding: 0;
    background: none;
    border-radius: 0;
    text-decoration: none;
    text-transform: none;
    letter-spacing: inherit;
    color: inherit;
}

#modularPanel[data-panel-text-mode="note"] .editor-field--quill .ql-editor :is(strong, b, .text-mark) {
    font-weight: 700;
    text-transform: none;
    letter-spacing: inherit;
}

#modularPanel .ql-editor .text-emphasis,
:is(.ql-editor, #preview-content) .text-emphasis {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-value-line);
    letter-spacing: var(--mono-label-spacing);
    font-style: normal;
    text-transform: none;
    color: var(--color-text);
}

:is(.ql-editor, #preview-content, .text-block-content, .text-note-content) .text-color-accent {
    color: var(--color-accent);
}

:is(.ql-editor, #preview-content, .text-block-content, .text-note-content) .text-color-normal {
    color: var(--color-text);
}

#modularPanel .ql-editor .text-underline,
#modularPanel .ql-editor .text-title,
#modularPanel .ql-editor .text-subtitle,
#modularPanel .ql-editor h1,
#modularPanel .ql-editor h2 {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    font-style: normal;
    line-height: inherit;
    margin: 0;
    padding: 0;
    background: none;
    border-radius: 0;
    text-decoration: none;
    text-transform: none;
    letter-spacing: normal;
    color: inherit;
}

/* Quill-Aufzählungen: bündig links, Bullet in Akzentfarbe (Editor + Frontend) */
:is(
    .ql-editor,
    .text-block-content,
    .text-note-content,
    #preview-content
) :is(ol, ul) {
    margin: 0.35rem 0 0.75rem;
    padding-left: 0 !important;
    line-height: var(--type-body-line);
    list-style: none;
}

:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) :is(p, li) {
    line-height: var(--type-body-line);
}

/* Mehrspaltig: festes Zeilenraster (nach allgemeiner line-height-Regel) */
.text-block-content[data-columns]:not([data-columns="1"]) :is(p, li),
.text-note-content[data-columns]:not([data-columns="1"]) :is(p, li) {
    line-height: var(--text-col-baseline);
}

.text-block-content[data-columns]:not([data-columns="1"]) :is(h1.text-title, h2.text-subtitle),
.text-note-content[data-columns]:not([data-columns="1"]) :is(h1.text-title, h2.text-subtitle) {
    margin: 0;
}

:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) :is(
    ul > li,
    li[data-list='bullet']
) {
    padding-left: 1.05em !important;
}

:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) :is(
    ul > li:not(.ql-direction-rtl)::before,
    li[data-list='bullet']::before
) {
    color: var(--color-accent) !important;
    line-height: inherit;
    vertical-align: baseline;
    margin-left: 0 !important;
    margin-right: 0.25em;
    width: 0.85em;
    text-align: left;
}

/* Gespeichertes HTML (<ul><li>…) ohne Quill-::before */
:is(.text-block-content, .text-note-content, #preview-content) ul > li {
    position: relative;
    list-style: none;
}

:is(.text-block-content, .text-note-content, #preview-content) ul > li::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--color-accent);
    font-weight: 700;
}

/* Nummerierte Listen (Quill + HTML) */
:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) ol > li,
:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) li[data-list='ordered'] {
    padding-left: 1.75em !important;
}

:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) ol > li::before,
:is(.ql-editor, .text-block-content, .text-note-content, #preview-content) li[data-list='ordered']::before {
    color: inherit;
}

/* Zitat / Lead-Text (Kontakt + Event-Textblock „Zitat“) */
.lead-text {
    font-family: var(--font-quote);
    font-size: var(--font-quote-size);
    font-weight: var(--type-quote-weight, 300);
    font-style: normal;
    line-height: var(--font-quote-line-height);
    letter-spacing: 0.01em;
    color: var(--color-text);
    max-width: none;
    hyphens: none;
    -webkit-hyphens: none;
}

.site-quote {
    margin: 1.5rem 0 1.75rem;
    padding: 0;
    border: none;
    background: none;
    box-shadow: none;
}

.site-quote:not(.type-quote-group) .lead-text {
    margin: 0 0 0.75rem;
    padding: 0;
    border: none;
    background: none;
    text-align: center;
}

.site-quote.site-quote--start:not(.type-quote-group) .lead-text {
    text-align: left;
}

.site-quote.type-quote-group .lead-text {
    margin: 0;
    text-align: left;
}

.site-quote .lead-text p {
    margin: 0 0 0.65rem;
    padding: 0;
    font: inherit;
    text-align: inherit;
    hyphens: none;
    -webkit-hyphens: none;
}

.site-quote .lead-text p:last-child {
    margin-bottom: 0;
}

.site-quote--start .lead-text {
    text-align: left;
}

.site-quote--start.type-quote-group .site-quote__attrib,
.site-quote--start.type-quote-group .type-caption {
    text-align: left;
}

.site-quote:not(.type-quote-group) .site-quote__attrib {
    margin: 0.35rem 0 0;
}

.site-quote.type-quote-group .site-quote__attrib {
    margin: 0;
}

.site-quote__attrib {
    margin: 0;
    padding: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.88rem;
    font-weight: 400;
    line-height: 1.45;
    color: var(--color-text-light);
    text-align: center;
    letter-spacing: 0.02em;
}

/* Legacy: alte text-quote / blockquote in Textblöcken */
.text-block-content .text-quote,
.block-text--quote .text-quote {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
}

.text-block-content blockquote:not(.lead-text) {
    margin: 1.5rem 0;
    padding: 0;
    border: none;
    background: none;
    font-family: var(--font-quote);
    font-size: var(--font-quote-size);
    font-weight: var(--type-quote-weight, 300);
    line-height: var(--font-quote-line-height);
    text-align: center;
    color: var(--color-text);
}

.text-block-content blockquote:not(.lead-text) p {
    margin: 0;
    font: inherit;
}

.modular-quote-panel-actions {
    display: flex;
    align-items: stretch;
    gap: 0.4rem;
    margin-top: 0.15rem;
    padding-top: 0.65rem;
    border-top: 1px solid var(--color-border);
}

.modular-quote-nav-btn,
.modular-quote-generate-btn {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    border-radius: 4px;
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
    color: var(--color-accent);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.modular-quote-nav-btn {
    flex: 0 0 2.5rem;
    padding: 0.55rem 0;
    font-size: 1rem;
    line-height: 1;
    text-transform: none;
    letter-spacing: 0;
}

.modular-quote-generate-btn {
    flex: 1 1 auto;
    padding: 0.55rem 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.modular-quote-nav-btn:hover,
.modular-quote-nav-btn:focus-visible,
.modular-quote-generate-btn:hover,
.modular-quote-generate-btn:focus-visible {
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 16%, var(--color-bg));
    outline: none;
}

.modular-quote-nav-btn:disabled,
.modular-quote-generate-btn:disabled,
.modular-quote-add-btn:disabled {
    opacity: 0.55;
    cursor: wait;
}

.modular-quote-add-btn {
    width: 100%;
    margin-top: 0.45rem;
    padding: 0.55rem 0.85rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px dashed color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    border-radius: 4px;
    background: transparent;
    color: var(--color-accent);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, border-style 0.2s ease;
}

.modular-quote-add-btn:hover,
.modular-quote-add-btn:focus-visible {
    border-style: solid;
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 10%, var(--color-bg));
    outline: none;
}

.modular-quote-add-btn.is-saved {
    border-style: solid;
    background: color-mix(in srgb, var(--color-accent) 14%, var(--color-bg));
}

/* Zitat-Editor: Plain-Text (kein Zitat-Rendering im Panel) */
#modularPanel .editor-field--quote-plain .modular-quote-plain-input {
    width: 100%;
    min-height: 7rem;
    margin: 0;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    resize: vertical;
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    font-weight: 300;
    font-style: normal;
    line-height: 1.6;
    color: var(--color-text);
    text-align: left;
    box-sizing: border-box;
}

#modularPanel .editor-field--quote-plain .modular-quote-plain-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 15%, transparent);
}

#modularPanel[data-panel-text-mode="quote"] #modularPanelTextNormal,
#modularPanel[data-panel-text-mode="accordion"] #modularPanelTextNormal,
#modularPanel[data-panel-text-mode="timetable"] #modularPanelTextNormal {
    display: none !important;
}

/* Combo/Trainer nutzen #modularPanelTextNormal für Quill — Textmodus-Attribut von vorherigem Block ignorieren */
#modularPanel[data-block-type="combo"] #modularPanelTextNormal,
#modularPanel[data-block-type="trainer"] #modularPanelTextNormal {
    display: flex !important;
    flex-direction: column;
    min-height: 0;
}

#modularPanel[data-block-type="combo"] #modularPanelTextNormal {
    flex: 0 1 auto;
    overflow: hidden;
}

#modularPanel[data-block-type="trainer"] #modularPanelTextNormal {
    flex: 0 0 auto;
    overflow: visible;
}

/* Text-Block „Notiz“ — Mono + Caption, dezente Kästen */
.block-text--note .text-note-content {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    line-height: 1.5;
    color: var(--color-text);
    background: color-mix(in srgb, var(--color-text) 4.5%, var(--color-bg));
    border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
    border-radius: 6px;
    padding: 0.9rem 1.2rem;
    box-sizing: border-box;
}

.block-text--note .text-note-content.text-note-content--color-accent,
.block-text--note .text-note-content.text-note-content--accent {
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text));
    background: color-mix(in srgb, var(--color-accent) 11%, var(--color-bg));
    border-color: color-mix(in srgb, var(--color-accent) 26%, var(--color-border));
}

.block-text--note .text-note-content.text-note-content--color-outline {
    color: color-mix(in srgb, var(--color-accent) 78%, var(--color-text));
    background: var(--color-bg);
    border-color: color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
}

.block-text--note .text-note-content.text-note-content--color-frame-gray {
    color: var(--color-text);
    background: var(--color-bg);
    border-color: var(--color-text-light);
}

.block-text--note .text-note-content.text-note-content--color-frame-black {
    color: var(--color-text);
    background: var(--color-bg);
    border-color: var(--color-text);
}

.block-text--note .text-note-content.text-note-content--color-quote-note {
    font-family: var(--font-quote);
    font-size: var(--font-quote-size);
    font-weight: var(--type-quote-weight, 300);
    line-height: var(--font-quote-line-height);
    letter-spacing: 0.01em;
    text-transform: none;
    text-align: center;
    color: #fff;
    background: color-mix(in srgb, var(--color-accent) 50%, transparent);
    border: none;
    border-radius: var(--accordion-radius);
    overflow: hidden;
}

.block-text--note .text-note-content.text-note-content--color-quote-note :is(p, li) {
    -webkit-text-stroke: var(--font-quote-stroke) currentColor;
    paint-order: stroke fill;
}

.block-text--note .text-note-content.text-note-content--color-quote-note .text-link {
    color: #fff;
    text-decoration: none;
    opacity: 0.92;
}

.block-text--note .text-note-content.text-note-content--color-quote-note .text-link:hover {
    color: #fff;
    opacity: 1;
}

.block-text--note .text-note-content.text-note-content--color-quote-note .text-note-subline {
    margin: 0.6rem 0 0;
    padding: 0;
    text-align: center;
    color: color-mix(in srgb, #fff 82%, var(--color-accent));
}

/* Sticker-Panel — Headline oben, Quill darunter (volle Breite) */
#modularPanel[data-panel-text-mode="box"] #modularPanelText,
#modularPanel[data-panel-text-mode="box"] #modularPanelTextNormal {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 0.6rem;
}

#modularPanel[data-panel-text-mode="box"] .editor-field--text-mode,
#modularPanel[data-panel-text-mode="box"] .editor-field--box-headline,
#modularPanel[data-panel-text-mode="box"] .editor-field--quill {
    margin-bottom: 0;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex: 0 0 auto;
}

#modularPanel[data-panel-text-mode="box"] .editor-field--box-headline {
    flex: 0 0 auto;
}

#modularPanel[data-panel-text-mode="box"] .editor-field--quill {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#modularPanel[data-panel-text-mode="box"] .modular-box-headline-input {
    width: 100%;
    box-sizing: border-box;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text);
    padding: 0.4rem 0.5rem;
}

#modularPanel[data-panel-text-mode="box"] .editor-field--note-color,
#modularPanel[data-panel-text-mode="box"] .editor-field--note-subline,
#modularPanel[data-panel-text-mode="box"] .editor-field--footnote-contact {
    display: none !important;
}

#modularPanel[data-panel-text-mode="box"] .ql-formats--columns,
#modularPanel[data-panel-text-mode="sticker-duo"] .ql-formats--columns {
    display: none !important;
}

/* Sticker-Duo-Panel */
#modularPanel[data-panel-text-mode="sticker-duo"] #modularPanelText,
#modularPanel[data-panel-text-mode="sticker-duo"] #modularPanelTextNormal {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 0.6rem;
}

#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--text-mode,
#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--sticker-duo,
#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--quill {
    margin-bottom: 0;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex: 0 0 auto;
}

#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--quill {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#modularPanel[data-panel-text-mode="sticker-duo"] .sticker-duo-side-controls {
    margin-bottom: 0.35rem;
}

#modularPanel[data-panel-text-mode="sticker-duo"] .modular-box-headline-input {
    width: 100%;
    box-sizing: border-box;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text);
    padding: 0.4rem 0.5rem;
}

#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--box-headline,
#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--note-color,
#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--note-subline,
#modularPanel[data-panel-text-mode="sticker-duo"] .editor-field--footnote-contact {
    display: none !important;
}

/* Text-Modus Sticker (box) — volle Akzentfläche, Headline Subline-Mono, Body normal links */
.event-detail > .block-text--box {
    padding-top: 0;
    padding-bottom: 0;
}

.event-detail > .block-text--box.preview-block.active {
    background: transparent;
}

.block-text--box .text-box-content {
    display: block;
    width: 100%;
    max-width: 100%;
    margin: 0;
    color: #fff;
    background: var(--color-accent);
    border: none;
    border-radius: var(--accordion-radius);
    padding: clamp(1rem, 2.5vw, 1.35rem) clamp(1.1rem, 3vw, 1.5rem);
    overflow: hidden;
    box-sizing: border-box;
}

.block-text--box .text-box-headline.type-subline {
    color: #fff;
    text-align: left;
    text-transform: uppercase;
    margin: 0 0 0.5rem;
    line-height: 1.25;
    max-width: none;
}

.block-text--box .text-box-body {
    text-align: left;
    font-family: var(--font-body);
    font-size: inherit;
    line-height: var(--type-body-line);
    letter-spacing: normal;
    text-transform: none;
    -webkit-text-stroke: 0;
    paint-order: initial;
}

.block-text--box .text-box-body :is(p, li) {
    margin: 0;
    line-height: var(--type-body-line);
    max-width: none;
    -webkit-text-stroke: 0;
    paint-order: initial;
}

.block-text--box .text-box-body p:last-child {
    margin-bottom: 0;
}

.block-text--box .text-box-body .text-link {
    color: #fff;
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, #fff 75%, transparent);
    text-underline-offset: 0.15em;
    opacity: 0.92;
}

.block-text--box .text-box-body .text-link:hover {
    color: #fff;
    text-decoration-color: #fff;
    opacity: 1;
}

/* Quill-Formate im Sticker-Body (wie Fließtext, Farben für Akzentfläche) */
.block-text--box .text-box-body .text-emphasis,
.block-text--sticker-duo .text-box-body .text-emphasis {
    font-family: var(--mono-font);
    font-size: var(--mono-value-size);
    font-weight: var(--mono-value-weight);
    line-height: var(--mono-value-line);
    letter-spacing: var(--mono-label-spacing);
    font-style: normal;
    text-transform: none;
    color: #fff;
}

.block-text--box .text-box-body :is(.text-mark, strong, b),
.block-text--sticker-duo .text-box-body :is(.text-mark, strong, b) {
    font-family: var(--font-h1);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 400;
    line-height: 1.08;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: #fff;
    background: none;
    padding: 0;
    border-radius: 0;
    box-decoration-break: unset;
    -webkit-box-decoration-break: unset;
}

.block-text--box .text-box-body .text-underline,
.block-text--sticker-duo .text-box-body .text-underline {
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, #fff 75%, transparent);
    text-underline-offset: 0.12em;
}

.block-text--box .text-box-body .text-strikethrough,
.block-text--sticker-duo .text-box-body .text-strikethrough {
    text-decoration: line-through;
    text-decoration-color: currentColor;
}

.block-text--box .text-box-body .text-color-accent,
.block-text--sticker-duo .text-box-body .text-color-accent {
    color: color-mix(in srgb, #fff 88%, var(--color-accent));
}

.block-text--box .text-box-body .text-color-normal,
.block-text--sticker-duo .text-box-body .text-color-normal {
    color: #fff;
}

/* Sticker : Sticker — 2× quadratisch, 50/50 */
.event-detail > .block-text--sticker-duo {
    padding-top: 0;
    padding-bottom: 0;
}

.event-detail > .block-text--sticker-duo.preview-block.active {
    background: transparent;
}

.block-text--sticker-duo .text-box-duo {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(0.45rem, 1.2vw, 0.65rem);
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.block-text--sticker-duo .text-box-duo__cell {
    aspect-ratio: 1 / 1;
    min-width: 0;
}

.block-text--sticker-duo .text-box-content--duo {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    margin: 0;
    color: #fff;
    background: var(--color-accent);
    border: none;
    border-radius: var(--accordion-radius);
    padding: clamp(0.65rem, 1.8vw, 0.95rem) clamp(0.7rem, 2vw, 1rem);
    overflow: hidden;
    box-sizing: border-box;
}

.block-text--sticker-duo .text-box-headline.type-subline {
    flex: 0 0 auto;
    color: #fff;
    text-align: left;
    text-transform: uppercase;
    margin: 0 0 0.35rem;
    line-height: 1.25;
    max-width: none;
}

.block-text--sticker-duo .text-box-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    text-align: left;
    font-family: var(--font-body);
    font-size: inherit;
    line-height: var(--type-body-line);
    letter-spacing: normal;
    text-transform: none;
    -webkit-text-stroke: 0;
    paint-order: initial;
}

.block-text--sticker-duo .text-box-body :is(p, li) {
    margin: 0;
    line-height: var(--type-body-line);
    max-width: none;
    -webkit-text-stroke: 0;
    paint-order: initial;
}

.block-text--sticker-duo .text-box-body p:last-child {
    margin-bottom: 0;
}

.block-text--sticker-duo .text-box-body .text-link {
    color: #fff;
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, #fff 75%, transparent);
    text-underline-offset: 0.15em;
    opacity: 0.92;
}

.block-text--sticker-duo .text-box-body .text-link:hover {
    color: #fff;
    text-decoration-color: #fff;
    opacity: 1;
}

body.admin-edit-page .text-box-duo__cell.is-sticker-duo-active .text-box-content--duo {
    box-shadow: inset 0 0 0 2px color-mix(in srgb, #fff 62%, transparent);
}

.block-text--note .text-note-content p {
    margin: 0 0 0.35em;
    max-width: none;
}

.block-text--note .text-note-content p:last-child {
    margin-bottom: 0;
}

/* Notiz: Links in Akzent, ohne Unterstreichung (Mono-Caption-Stil) */
.block-text--note .text-note-content .text-link {
    color: var(--color-accent);
    text-decoration: none;
}

.block-text--note .text-note-content .text-link:hover {
    color: var(--color-accent);
    opacity: 0.85;
}

/* Text-Block „Fußnote“ — Mono-Caption wie Facts-Box, optional Kontakt-Button rechts */
.block-text--footnote .text-footnote {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem 1.25rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    line-height: 1.5;
    color: var(--color-text-light);
    background: #f5f5f5;
    border: none;
    border-radius: 12px;
    padding: 1rem 1.25rem;
    box-sizing: border-box;
}

.block-text--footnote .text-footnote__body {
    flex: 1 1 14rem;
    min-width: 0;
}

.block-text--footnote .text-footnote__body :is(p, li) {
    margin: 0;
    max-width: none;
    color: var(--color-text-light);
}

.block-text--footnote .text-footnote__body p + p {
    margin-top: 0.35em;
}

.block-text--footnote .text-footnote__aside {
    flex: 0 0 auto;
    margin-left: auto;
}

.block-text--footnote .text-footnote__cta {
    white-space: nowrap;
}

#modularPanel[data-panel-text-mode="footnote"] .ql-editor {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.12em;
    line-height: 1.45;
    text-transform: uppercase;
    color: var(--color-text-light);
    background: #f5f5f5;
    border: none;
    min-height: 2.75rem;
    height: auto;
}

/* Fußnote: kompakter Quill — kein Vollhöhen-Panel */
#modularPanel.active[data-panel-text-mode='footnote'] {
    height: auto;
    max-height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px));
}

#modularPanel.active[data-panel-text-mode='footnote'] #modularPanelTextNormal,
#modularPanel.active[data-panel-text-mode='footnote'] .editor-field--quill {
    flex: 0 0 auto;
    overflow: visible;
}

#modularPanel.active[data-panel-text-mode='footnote'] .editor-field--quill .modular-quill-wrap {
    flex: 0 0 auto;
    min-height: 0;
    max-height: 7rem;
    height: auto;
    overflow: hidden;
}

#modularPanel.active[data-panel-text-mode='footnote'] .editor-field--quill .modular-quill-editor {
    flex: 0 0 auto;
    height: auto;
}

#modularPanel.active[data-panel-text-mode='footnote'] .editor-field--quill .ql-container {
    flex: 0 0 auto;
    max-height: 5.5rem;
    overflow-y: auto !important;
}

/* Fußnote-Panel — kompaktes Editor-Layout */
#modularPanel[data-panel-text-mode="footnote"] #modularPanelText,
#modularPanel[data-panel-text-mode="footnote"] #modularPanelTextNormal {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: 0.6rem;
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--text-mode,
#modularPanel[data-panel-text-mode="footnote"] .editor-field--footnote-contact,
#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill {
    margin-bottom: 0;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill .modular-quill-wrap,
#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill .modular-quill-editor {
    width: 100%;
    max-width: 100%;
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--footnote-contact {
    padding: 0.6rem 0.7rem;
    background: color-mix(in srgb, var(--color-text-light) 6%, #fff);
    border: 1px solid color-mix(in srgb, var(--color-border) 85%, transparent);
    border-radius: 10px;
}

#modularPanel[data-panel-text-mode="footnote"] .footnote-contact-toggle {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    margin: 0;
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    text-transform: none;
    letter-spacing: 0;
    color: var(--color-text);
}

#modularPanel[data-panel-text-mode="footnote"] .footnote-contact-toggle input[type="checkbox"] {
    box-sizing: border-box;
    width: 0.9rem;
    height: 0.9rem;
    min-width: 0.9rem;
    margin: 0.12rem 0 0;
    flex-shrink: 0;
    accent-color: var(--color-accent);
    cursor: pointer;
}

#modularPanel[data-panel-text-mode="footnote"] .footnote-contact-toggle__copy {
    display: grid;
    gap: 0.1rem;
    min-width: 0;
}

#modularPanel[data-panel-text-mode="footnote"] .footnote-contact-toggle__title {
    font-size: 0.78rem;
    font-weight: 500;
    line-height: 1.35;
    color: var(--color-text);
}

#modularPanel[data-panel-text-mode="footnote"] .footnote-contact-toggle__hint {
    font-size: 0.68rem;
    font-weight: 400;
    line-height: 1.35;
    color: var(--color-text-light);
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill > .editor-field-label--quill {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill .modular-quill-wrap {
    border: none;
    border-radius: 12px;
    background: #f5f5f5;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 70%, transparent);
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill .ql-toolbar {
    background: color-mix(in srgb, var(--color-text-light) 7%, #f5f5f5);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
    padding: 0.2rem 0.35rem;
    border-radius: 12px 12px 0 0;
}

#modularPanel[data-panel-text-mode="footnote"] .editor-field--quill .ql-container {
    border-radius: 0 0 12px 12px;
    background: #f5f5f5;
}

#modularPanel[data-panel-text-mode="footnote"] .ql-formats--columns,
#modularPanel[data-panel-text-mode="footnote"] .ql-toolbar .ql-list,
#modularPanel[data-panel-text-mode="footnote"] .ql-toolbar button.ql-link {
    display: none !important;
}

#modularPanel.active[data-panel-text-mode='footnote'] #modularPanelTextNormal,
#modularPanel[data-panel-text-mode="note"] .ql-editor {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.12em;
    line-height: 1.45;
}

#modularPanel[data-panel-text-mode="note"] .ql-editor.ql-editor--note-color-neutral {
    color: var(--color-text);
    background: color-mix(in srgb, var(--color-text) 4.5%, var(--color-bg));
}

#modularPanel[data-panel-text-mode="note"] .ql-editor.ql-editor--note-color-accent,
#modularPanel[data-panel-text-mode="note"] .ql-editor.ql-editor--note-accent {
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text));
    background: color-mix(in srgb, var(--color-accent) 11%, var(--color-bg));
}

#modularPanel[data-panel-text-mode="note"] .ql-editor.ql-editor--note-color-outline {
    color: color-mix(in srgb, var(--color-accent) 78%, var(--color-text));
    background: var(--color-bg);
}

#modularPanel[data-panel-text-mode="note"] .ql-container:has(.ql-editor--note-color-accent),
#modularPanel[data-panel-text-mode="note"] .ql-container:has(.ql-editor--note-accent) {
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
}

#modularPanel[data-panel-text-mode="note"] .ql-container:has(.ql-editor--note-color-outline) {
    background: var(--color-bg);
}

#modularPanel .editor-field--note-color .note-color-options {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

#modularPanel .quote-color-options {
    gap: 0.25rem;
    width: fit-content;
}

#modularPanel .quote-color-options {
    flex-wrap: wrap;
}

#modularPanel .quote-color-btn {
    min-width: 0;
    padding: 0.3rem 0.5rem;
    font-size: 0.68rem;
}

#modularPanel .quote-color-btn[data-quote-color='highlight']::before {
    content: '';
    display: inline-block;
    width: 0.55rem;
    height: 0.55rem;
    margin-right: 0.3rem;
    border-radius: 3px;
    background: var(--color-accent);
    vertical-align: -0.05em;
}

#modularPanel .note-color-btn {
    flex: 1 1 0;
    min-width: 4.5rem;
    padding-left: 0.45rem;
    padding-right: 0.45rem;
}

#modularPanel .note-color-btn::before {
    content: '';
    display: inline-block;
    width: 0.65rem;
    height: 0.65rem;
    margin-right: 0.35rem;
    border-radius: 2px;
    border: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
    vertical-align: -0.05em;
}

#modularPanel .note-color-btn[data-note-color='neutral']::before {
    background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg));
}

#modularPanel .note-color-btn[data-note-color='accent']::before {
    background: color-mix(in srgb, var(--color-accent) 28%, var(--color-bg));
    border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

#modularPanel .note-color-btn[data-note-color='outline']::before {
    background: var(--color-bg);
    border-color: color-mix(in srgb, var(--color-accent) 50%, var(--color-border));
}

#modularPanel .note-color-btn[data-note-color='frame-gray']::before {
    background: var(--color-bg);
    border-color: var(--color-text-light);
}

#modularPanel .note-color-btn[data-note-color='frame-black']::before {
    background: var(--color-bg);
    border-color: var(--color-text);
}

#modularPanel .note-color-btn[data-note-color='quote-note']::before {
    background: color-mix(in srgb, var(--color-accent) 50%, transparent);
    border-color: color-mix(in srgb, var(--color-accent) 65%, var(--color-border));
}

#modularPanel[data-panel-text-mode="note"] .ql-editor.ql-editor--note-color-quote-note {
    font-family: var(--font-quote);
    font-size: var(--font-quote-size);
    font-weight: var(--type-quote-weight, 300);
    line-height: var(--font-quote-line-height);
    letter-spacing: 0.01em;
    text-transform: none;
    text-align: center;
    color: #fff;
    background: color-mix(in srgb, var(--color-accent) 50%, transparent);
    border-radius: var(--accordion-radius);
}

#modularPanel[data-panel-text-mode="note"] .ql-container:has(.ql-editor--note-color-quote-note) {
    background: color-mix(in srgb, var(--color-accent) 50%, transparent);
    border-radius: var(--accordion-radius);
    overflow: hidden;
}

.block-text--quote .site-quote {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin: 0;
    padding: 0;
}

.block-text--quote .site-quote .lead-text {
    width: 100%;
    max-width: 36rem;
    margin: 0 0 0.65rem;
}

.block-text--quote.block-text--quote-accent .site-quote .lead-text,
.block-text--quote.block-text--quote-accent .site-quote .lead-text p {
    color: var(--color-accent);
}

.block-text--quote.block-text--quote-highlight {
    background: var(--color-accent);
    border-radius: var(--accordion-radius);
    color: #fff;
    overflow: hidden;
}

.event-detail > .block-text--quote.block-text--quote-highlight {
    padding-top: 0;
    padding-bottom: 0;
}

.block-text--quote.block-text--quote-highlight .site-quote {
    align-items: stretch;
    width: 100%;
    margin: 0;
    min-height: 100%;
}

.block-text--quote.block-text--quote-highlight .site-quote .lead-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    max-width: none;
    margin: 0;
    padding: var(--modular-block-padding-y-emphasis) 1.15rem;
    background: transparent;
    color: inherit;
    border-radius: 0;
    min-height: 100%;
    box-sizing: border-box;
}

.block-text--quote.block-text--quote-highlight .site-quote .lead-text p {
    color: inherit;
}

.block-text--quote.block-text--quote-highlight .site-quote__attrib {
    margin: 0;
    padding: 0 1.15rem var(--modular-block-padding-y-emphasis);
    color: color-mix(in srgb, #fff 80%, transparent);
}

.block-text--quote .site-quote .lead-text p {
    margin-bottom: 0.5rem;
}

.block-text--quote .site-quote .lead-text p:last-child {
    margin-bottom: 0;
}

.block-text--quote .site-quote__attrib {
    display: block;
    width: 100%;
    max-width: 36rem;
    margin: 0;
    padding: 0.25rem 0 0;
    text-align: center;
}

/* Absatz / Combo-Text: Unterstreichung in Akzent, Hover volle Akzentfarbe */
.text-block-content .text-link,
.event-mixed__text.text-block-content .text-link {
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-accent);
    text-underline-offset: 0.15em;
}

.text-block-content .text-link:hover,
.event-mixed__text.text-block-content .text-link:hover {
    color: var(--color-accent);
    text-decoration-color: var(--color-accent);
}

/* Zitat: Lead-Text-Links wie Akzent-Markierung, ohne Linie */
.block-text--quote :is(.site-quote, .text-quote) .text-link {
    color: var(--color-accent);
    text-decoration: none;
}

.block-text--quote :is(.site-quote, .text-quote) .text-link:hover {
    color: var(--color-accent);
    opacity: 0.85;
}

/* Quill-Editor: Links je Modus */
#modularPanel[data-panel-text-mode="normal"] .ql-editor :is(.text-link, a[href]) {
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-accent);
    text-underline-offset: 0.15em;
}

#modularPanel[data-panel-text-mode="normal"] .ql-editor :is(.text-link, a[href]):hover {
    color: var(--color-accent);
    text-decoration-color: var(--color-accent);
}

#modularPanel[data-panel-text-mode="box"] .ql-editor :is(.text-link, a[href]),
#modularPanel[data-panel-text-mode="sticker-duo"] .ql-editor :is(.text-link, a[href]) {
    color: var(--color-text);
    text-decoration: underline;
    text-decoration-color: var(--color-accent);
    text-underline-offset: 0.15em;
}

#modularPanel[data-panel-text-mode="box"] .ql-editor :is(.text-link, a[href]):hover,
#modularPanel[data-panel-text-mode="sticker-duo"] .ql-editor :is(.text-link, a[href]):hover {
    color: var(--color-accent);
    text-decoration-color: var(--color-accent);
}

#modularPanel[data-panel-text-mode="note"] .ql-editor :is(.text-link, a[href]) {
    color: var(--color-accent);
    text-decoration: none;
}

#modularPanel[data-panel-text-mode="note"] .ql-editor :is(.text-link, a[href]):hover {
    color: var(--color-accent);
    opacity: 0.85;
}

#modularPanel[data-panel-text-mode="accordion"] .ql-editor :is(.text-link, a[href]),
#modularPanel[data-panel-text-mode="quote"] .ql-editor :is(.text-link, a[href]) {
    color: var(--color-accent);
    text-decoration: none;
}

#modularPanel[data-panel-text-mode="accordion"] .ql-editor :is(.text-link, a[href]):hover,
#modularPanel[data-panel-text-mode="quote"] .ql-editor :is(.text-link, a[href]):hover {
    color: var(--color-accent);
    opacity: 0.85;
}

.event-modular-image-figure {
    margin: 0;
}

.event-modular-image {
    width: 100%;
    height: auto;
    border-radius: 12px;
    display: block;
}

.event-modular-image-caption,
.event-modular-video-caption {
    margin: 0.65rem 0 0;
    text-align: center;
    font-family: var(--mono-font);
    font-size: var(--type-caption-size);
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.event-modular-image-caption.is-empty,
.event-modular-video-caption.is-empty {
    display: none;
}

.block-modular-image.preview-block .event-modular-image-caption.is-empty,
.block-video.preview-block .event-modular-video-caption.is-empty {
    display: block;
    min-height: 1.25rem;
    opacity: 0.35;
}

.event-modular-video-figure {
    margin: 0;
}

.event-modular-image-placeholder {
    width: 100%;
    min-height: 200px;
    background: #f0f0f0;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #999;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
}

/* Event-Bilder: immer Original (kein Hover-Effekt) */
.event-detail .event-gallery__img,
.event-detail .event-mixed__img,
.event-detail .event-modular-image,
.event-detail .event-mixed-trainer__photo img {
    filter: none;
    transition: none;
}

/* Combo Galerie (2×2 links + Text rechts) */
.event-mixed--gallery-text .event-mixed__layout {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: start;
}

.event-mixed--gallery-text .event-mixed__layout--ratio-1:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 4fr);
}

.event-mixed--gallery-text .event-mixed__layout--ratio-2:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
}

.event-mixed--gallery-text .event-mixed__layout--ratio-3:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.event-mixed--gallery-text .event-mixed__layout--ratio-1.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 4fr) minmax(0, 1fr);
}

.event-mixed--gallery-text .event-mixed__layout--ratio-2.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
}

.event-mixed--gallery-text .event-mixed__layout--ratio-3.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.event-mixed--gallery-text .event-mixed__media,
.event-mixed--gallery-text .event-mixed__text {
    min-width: 0;
}

.event-mixed__media--gallery-grid {
    margin: 0;
    width: 100%;
}

.event-mixed__gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
    width: 100%;
}

.event-mixed__gallery-thumb {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-border) 35%, #fff);
}

.event-mixed__gallery-thumb:not(:has(.event-mixed__gallery-img)) {
    display: none;
}

.event-mixed__gallery-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.event-mixed__gallery-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.25rem;
    color: color-mix(in srgb, var(--color-text-light) 70%, transparent);
}

/* Combo 50/50 — frei konfigurierbare Spalten */
.event-combo-columns__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-block-gap, 1.5rem);
    align-items: start;
}

.event-combo-columns__cell {
    min-width: 0;
}

.event-combo-columns__text {
    width: 100%;
}

/* Combo 50/50: gleiches Zeilenraster + bündige Headlines in beiden Spalten */
.event-combo-columns__text p.text-col-headline .text-mark,
.event-combo-columns__text p:has(> .text-mark:only-child) .text-mark {
    display: inline;
    font-size: var(--type-text-mark-size);
    line-height: var(--type-text-mark-line);
    margin: 0;
}

.event-combo-columns__text p.text-col-headline,
.event-combo-columns__text p:has(> .text-mark:only-child) {
    margin: 0;
}

/* Leere Quill-Zeilen (<p><br></p>): Absatzabstand wie in .text-block-content */
.event-combo-columns__text p:has(> br:only-child) {
    margin: 0;
    padding: 0;
    line-height: var(--type-body-line);
    font-size: var(--type-body-size);
}

.event-combo-columns__text-placeholder {
    color: color-mix(in srgb, var(--color-text-light) 75%, transparent);
}

.event-combo-columns__media {
    margin: 0;
    width: 100%;
}

.event-combo-columns__media-frame {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-border) 35%, #fff);
}

.event-combo-columns__media--square .event-combo-columns__media-frame,
.event-combo-columns__media--circle .event-combo-columns__media-frame {
    aspect-ratio: 1;
}

.event-combo-columns__media--circle .event-combo-columns__media-frame {
    border-radius: 50%;
}

.event-combo-columns__media--full .event-combo-columns__media-frame {
    aspect-ratio: auto;
    height: auto;
}

.event-combo-columns__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.event-combo-columns__media--full .event-combo-columns__img {
    width: auto;
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

.event-combo-columns__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 8rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
    color: color-mix(in srgb, var(--color-text-light) 70%, transparent);
}

.event-combo-columns__caption.is-empty {
    display: none;
}

.event-combo-columns__sticker {
    width: 100%;
    aspect-ratio: 1 / 1;
    min-width: 0;
}

.event-combo-columns__sticker .text-box-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: clamp(0.65rem, 1.8vw, 0.95rem) clamp(0.7rem, 2vw, 1rem);
}

.event-combo-columns__sticker .text-box-headline.type-subline {
    flex: 0 0 auto;
    margin: 0 0 0.35rem;
    line-height: 1.25;
}

.block-text--box .text-box-body p + p,
.block-text--sticker-duo .text-box-body p + p,
.event-combo-columns__sticker .text-box-body p + p {
    margin-top: -0.05em;
}

.block-title .event-subtitle {
    line-height: 1.35;
}

.event-combo-columns__sticker .text-box-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}

.event-combo-columns__gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
    width: 100%;
}

.event-combo-columns__gallery-thumb {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-border) 35%, #fff);
}

.event-combo-columns__gallery-thumb:not(:has(.event-combo-columns__gallery-img)) {
    display: none;
}

.event-combo-columns__gallery-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.event-combo-columns__gallery-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.25rem;
    color: color-mix(in srgb, var(--color-text-light) 70%, transparent);
}

.modular-combo-gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
    width: 100%;
}

.modular-combo-gallery-slot {
    position: relative;
    aspect-ratio: 1;
    padding: 0;
    border: 1px dashed var(--color-border);
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    cursor: pointer;
}

.modular-combo-gallery-slot.has-image {
    border-style: solid;
}

.modular-combo-gallery-slot__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.modular-combo-gallery-slot__img[hidden] {
    display: none;
}

.modular-combo-gallery-slot__empty {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.1rem;
    color: var(--color-text-light);
}

.modular-combo-gallery-slot__remove {
    position: absolute;
    top: 0.2rem;
    right: 0.2rem;
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    font-size: 0.85rem;
    line-height: 1.25rem;
    text-align: center;
    pointer-events: auto;
}

/* Combo block (Bild + Text) — 1–3 = Bildbreite; bei Swap Spalten spiegeln */
.event-mixed--image-text .event-mixed__layout {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    align-items: start;
}

/* Bild links (Standard) */
.event-mixed--image-text .event-mixed__layout--ratio-1:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 4fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-2:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-3:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

/* Bild rechts (getauscht) — schmale/breite Spalte bleibt am Bild */
.event-mixed--image-text .event-mixed__layout--ratio-1.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 4fr) minmax(0, 1fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-2.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-3.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

/*
 * Full = originales Seitenverhältnis (kein Square/Circle-Crop).
 * Spalte schrumpft auf die tatsächliche Bildbreite, max. gemäß Ratio-Buttons 1–3.
 */
.event-mixed--image-text .event-mixed__layout--ratio-1:has(.event-mixed__media--full):not(.event-mixed__layout--reverse) {
    grid-template-columns: fit-content(20%) minmax(0, 1fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-2:has(.event-mixed__media--full):not(.event-mixed__layout--reverse) {
    grid-template-columns: fit-content(40%) minmax(0, 1fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-3:has(.event-mixed__media--full):not(.event-mixed__layout--reverse) {
    grid-template-columns: fit-content(50%) minmax(0, 1fr);
}

.event-mixed--image-text .event-mixed__layout--ratio-1:has(.event-mixed__media--full).event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) fit-content(20%);
}

.event-mixed--image-text .event-mixed__layout--ratio-2:has(.event-mixed__media--full).event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) fit-content(40%);
}

.event-mixed--image-text .event-mixed__layout--ratio-3:has(.event-mixed__media--full).event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) fit-content(50%);
}

.event-mixed--image-text .event-mixed__layout:has(.event-mixed__media--full) .event-mixed__media {
    width: auto;
    max-width: 100%;
}

.event-mixed--image-text .event-mixed__layout:has(.event-mixed__media--full) .event-mixed__media-frame {
    width: auto;
    max-width: 100%;
}

/* Kreis + Verhältnis 1: Text vertikal zur Bildspalte zentrieren (nicht Trainer — siehe trainer-media-align.js) */
@media (min-width: 769px) {
    .event-mixed--image-text
        .event-mixed__layout--ratio-1:has(.event-mixed__media--circle):not(:has(.event-trainer__headline)) {
        align-items: center;
    }

    .block-trainer .event-mixed__layout {
        align-items: center;
    }

    .block-trainer .event-mixed__layout.event-mixed__layout--align-start {
        align-items: start;
    }
}

.event-mixed--image-text .event-mixed__media,
.event-mixed--image-text .event-mixed__text,
.event-mixed--video-text .event-mixed__media,
.event-mixed--video-text .event-mixed__text {
    min-width: 0;
}

.event-mixed--video-text .event-mixed__layout {
    display: grid;
    gap: clamp(1rem, 3vw, 1.75rem);
    align-items: start;
}

.event-mixed--video-text .event-mixed__layout--ratio-1:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 4fr);
}

.event-mixed--video-text .event-mixed__layout--ratio-2:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
}

.event-mixed--video-text .event-mixed__layout--ratio-3:not(.event-mixed__layout--reverse) {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.event-mixed--video-text .event-mixed__layout--ratio-1.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 4fr) minmax(0, 1fr);
}

.event-mixed--video-text .event-mixed__layout--ratio-2.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
}

.event-mixed--video-text .event-mixed__layout--ratio-3.event-mixed__layout--reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.event-mixed__media--video {
    margin: 0;
    width: 100%;
    min-width: 0;
}

.event-mixed__media--video .page-ika-video-frame {
    width: 100%;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
}

/* Mobile: Combo-Blöcke (Bild+Text / Video+Text / 50-50-Spalten) stapeln */
@media (max-width: 768px) {
    .event-mixed--image-text .event-mixed__layout,
    .event-mixed--gallery-text .event-mixed__layout,
    .event-mixed--video-text .event-mixed__layout,
    .event-combo-columns__grid {
        grid-template-columns: 1fr !important;
    }

    /* wenn "reverse": trotzdem Media oben, Text darunter */
    .event-mixed__layout--reverse .event-mixed__media {
        order: 0;
    }
    .event-mixed__layout--reverse .event-mixed__text {
        order: 1;
    }
}

.editor-field--combo-type .modular-combo-type-select {
    width: 100%;
}

.event-mixed__media {
    margin: 0;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
}

.event-mixed__media-frame {
    width: 100%;
    position: relative;
}

.event-mixed__media--square .event-mixed__media-frame,
.event-mixed__media--tile .event-mixed__media-frame {
    aspect-ratio: 1 / 1;
    border-radius: 14px;
    overflow: hidden;
    background: var(--color-border);
}

/* Kreis wie Galerie „Stacked circles“ (Rahmen + Schatten) */
.event-mixed__media--circle .event-mixed__media-frame {
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid var(--color-bg);
    box-shadow: 0 4px 16px color-mix(in srgb, var(--color-text) 14%, transparent);
    box-sizing: border-box;
    background: var(--color-border);
}

/* Original-Seitenverhältnis des Fotos (kein festes Crop-Format) */
.event-mixed__media--full .event-mixed__media-frame {
    border-radius: 14px;
    overflow: hidden;
    background: var(--color-border);
}

.event-mixed__media--full .event-mixed__img {
    width: auto;
    max-width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}

.event-mixed__media--full .event-mixed__media-placeholder {
    width: 100%;
    aspect-ratio: 4 / 3;
}

.event-mixed__caption {
    flex: 0 0 auto;
    padding-bottom: 0.35rem;
}

.block-combo.preview-block.active .event-mixed__caption.is-empty {
    display: block;
    min-height: 0.75rem;
    opacity: 0.35;
}

.block-combo.preview-block:not(.active) .event-mixed__caption.is-empty {
    display: none;
}

/* Trainer: keine Bildunterschrift */
.block-trainer .event-mixed__caption {
    display: none !important;
}

@media (min-width: 769px) {
    .event-mixed__layout--reverse .event-mixed__media {
        order: 2;
    }

    .event-mixed__layout--reverse .event-mixed__text {
        order: 1;
    }
}

.modular-mixed-layout-slider {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
    width: 100%;
}

.modular-mixed-layout-slider__option {
    width: 100%;
    min-width: 0;
    padding: 0.38rem 0.45rem !important;
}

.modular-mixed-layout-slider__preview {
    display: flex;
    align-items: center;
    gap: 0.22rem;
    width: 100%;
    min-height: 1.15rem;
}

.modular-mixed-layout-slider__media {
    flex: 0 0 38%;
    aspect-ratio: 1;
    max-height: 1.15rem;
    border-radius: 2px;
    background: color-mix(in srgb, var(--color-accent) 28%, var(--color-border));
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    transition: background 0.15s ease, border-color 0.15s ease;
}

.modular-mixed-layout-slider__text {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    min-width: 0;
}

.modular-mixed-layout-slider__text span {
    display: block;
    height: 0.14rem;
    border-radius: 1px;
    background: color-mix(in srgb, var(--color-text) 18%, var(--color-border));
}

.modular-mixed-layout-slider__text span:nth-child(2) {
    width: 88%;
}

.modular-mixed-layout-slider__text span:nth-child(3) {
    width: 62%;
}

.modular-mixed-layout-slider__option.active,
.modular-mixed-layout-slider__option[aria-pressed='true'] {
    background: color-mix(in srgb, var(--color-accent) 10%, var(--accordion-surface));
    border-color: color-mix(in srgb, var(--color-accent) 55%, var(--accordion-border));
}

.modular-mixed-layout-slider__option.active .modular-mixed-layout-slider__media,
.modular-mixed-layout-slider__option[aria-pressed='true'] .modular-mixed-layout-slider__media {
    background: var(--color-accent);
    border-color: var(--color-accent);
}

.modular-mixed-image-preview {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    margin-bottom: 0.25rem;
    border-radius: 12px;
    overflow: hidden;
    background: #e6e6e6;
    border: 1px solid var(--color-border);
}

.modular-mixed-image-preview--shape-square,
.modular-mixed-image-preview--shape-circle {
    aspect-ratio: 1 / 1;
}

.modular-mixed-image-preview--shape-full {
    aspect-ratio: auto;
    height: auto;
    min-height: 3.5rem;
}

.modular-mixed-image-preview--shape-full:not(.modular-mixed-image-preview--croppable) img {
    position: static;
    width: 100%;
    height: auto;
    max-width: 100%;
    object-fit: contain;
}

.modular-mixed-image-preview--shape-circle {
    border-radius: 50%;
}

.modular-mixed-image-preview--croppable {
    cursor: grab;
    touch-action: none;
}

.modular-mixed-image-preview--croppable:active {
    cursor: grabbing;
}

.modular-mixed-image-preview--croppable img {
    position: absolute;
    left: 0;
    top: 0;
    width: auto;
    height: auto;
    max-width: none;
    display: block;
    pointer-events: none;
    user-select: none;
}

.modular-mixed-image-preview__crop-overlay {
    position: absolute;
    inset: 0;
    border: 2px dashed var(--color-accent);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.modular-mixed-image-preview--croppable .modular-mixed-image-preview__crop-overlay {
    opacity: 1;
}

.modular-mixed-image-preview__hint {
    margin: 0 0 0.5rem;
    color: var(--color-text-light);
    font-size: 0.72rem;
}

.modular-mixed-image-zoom-row {
    display: grid;
    grid-template-columns: minmax(2.5rem, max-content) minmax(0, 1fr) 2.75rem;
    align-items: center;
    gap: 0.45rem;
    margin: 0 0 0.5rem;
}

.modular-mixed-image-zoom-row label {
    margin: 0;
    font-size: 0.78rem;
    white-space: nowrap;
}

.modular-mixed-image-zoom-row input[type='range'] {
    width: 100%;
    min-width: 0;
    margin: 0;
}

.modular-mixed-image-zoom-value {
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    line-height: 1;
    text-align: right;
    color: var(--color-text-light);
}

.modular-mixed-image-preview--has-image {
    background: var(--color-bg);
}

.modular-mixed-image-preview:not(.modular-mixed-image-preview--croppable) img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.modular-mixed-image-preview img[hidden] {
    display: none;
}

.modular-mixed-image-preview__placeholder {
    position: absolute;
    inset: 0;
    display: block;
    background-color: #e6e6e6;
    background-image: var(--mixed-preview-empty, none);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: 0.45;
}

.modular-mixed-image-preview--has-image .modular-mixed-image-preview__placeholder {
    display: none;
}

.modular-mixed-image-preview__browse {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    opacity: 0;
    pointer-events: none;
    padding: 0.35rem 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--color-text);
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.modular-mixed-image-preview:hover .modular-mixed-image-preview__browse,
.modular-mixed-image-preview:focus-within .modular-mixed-image-preview__browse,
.modular-mixed-image-preview__browse:hover,
.modular-mixed-image-preview__browse:focus {
    opacity: 1;
    pointer-events: auto;
}

.modular-mixed-image-preview {
    cursor: pointer;
}

.modular-mixed-image-shape-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.35rem;
    width: 100%;
}

.modular-mixed-image-shape-row .text-accordion-control--compact {
    flex: 1 1 0;
    min-width: 0;
    padding: 0.3rem 0.25rem;
    font-size: 0.68rem;
}

.event-mixed__img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: inherit;
}

.event-mixed__media-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: inherit;
    background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg));
    color: var(--color-text-light);
    font-family: var(--font-mono);
    font-size: 0.8rem;
}

.event-mixed__text-placeholder {
    color: var(--color-text-light);
}

.event-mixed-trainers {
    display: grid;
    gap: clamp(1.5rem, 3vw, 2.25rem);
}

.event-mixed-trainer {
    display: grid;
    grid-template-columns: minmax(5.5rem, 7.5rem) minmax(0, 1fr);
    gap: 1rem 1.25rem;
    align-items: start;
}

.event-mixed-trainer__photo {
    margin: 0;
}

.event-mixed-trainer__photo img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 999px;
    display: block;
}

.event-mixed-trainer__photo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg));
    color: var(--color-text-light);
    font-family: var(--font-mono);
    font-size: 0.7rem;
}

.event-mixed-trainer__name {
    margin: 0 0 0.35rem;
    font-size: 1.15rem;
    line-height: 1.25;
}

.event-mixed-trainer__role {
    margin: 0 0 0.65rem;
}

.event-mixed-trainer__bio :is(p, ul, ol) {
    margin: 0 0 0.65rem;
}

.event-mixed-trainer__bio :is(p, ul, ol):last-child {
    margin-bottom: 0;
}

.modular-trainer-editor {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    max-height: 50vh;
    overflow-y: auto;
}

.modular-trainer-card {
    padding: 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
}

.modular-trainer-card__row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.5rem;
}

.modular-trainer-card__row input[type="text"] {
    flex: 1 1 8rem;
    min-width: 0;
}

.modular-trainer-card__thumb {
    width: 3rem;
    height: 3rem;
    border-radius: 999px;
    object-fit: cover;
    background: #eee;
}

@media (max-width: 768px) {
    .event-mixed__media--circle {
        border-width: 3px;
    }

    .event-mixed-trainer {
        grid-template-columns: minmax(4.5rem, 5.5rem) minmax(0, 1fr);
    }
}

.block-gallery {
    margin: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.block-gallery .event-gallery,
.block-gallery .event-gallery__grid,
.block-gallery .event-gallery__head {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.event-detail > .block-gallery .event-gallery {
    margin: 0;
}

.event-gallery__grid {
    width: 100%;
    max-width: 100%;
}

.event-gallery__head {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.35rem 0.5rem;
    margin: 0 0 0.5rem;
    padding: 0.15rem 0;
    min-height: 0;
    line-height: 1;
}

.event-gallery__head:empty {
    display: none;
    margin: 0;
    padding: 0;
}

.event-gallery__head .type-caption {
    line-height: 1;
    padding: 0;
}

.event-gallery__head h2.text-subtitle {
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
    font-family: var(--font-h1);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 400;
    line-height: 1.15;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-accent);
}

.event-share-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: 1.55rem;
    height: 1.55rem;
    margin: 0;
    padding: 0.22rem;
    border: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border));
    border-radius: 4px;
    background: color-mix(in srgb, var(--color-accent) 7%, var(--color-bg));
    color: var(--color-accent);
    cursor: pointer;
    line-height: 0;
    transition:
        background 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease;
}

.event-share-btn:hover {
    background: color-mix(in srgb, var(--color-accent) 14%, var(--color-bg));
    border-color: var(--color-accent);
}

.event-share-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 35%, transparent);
    outline-offset: 2px;
}

.event-share-btn__icon {
    display: block;
    width: 0.9rem;
    height: 0.9rem;
    flex-shrink: 0;
}

.event-share-btn--labeled {
    width: auto;
    height: auto;
    gap: 0.35rem;
    padding: 0.3rem 0.55rem 0.3rem 0.42rem;
    line-height: 1;
}

.event-share-btn__label {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    line-height: 1;
}

.event-gallery__head .event-share-btn--labeled {
    width: auto;
    height: auto;
    padding: 0.28rem 0.5rem 0.28rem 0.38rem;
}

.event-gallery__head .event-share-btn--labeled .event-share-btn__icon {
    width: 0.85rem;
    height: 0.85rem;
}

.event-gallery__head .event-share-btn:not(.event-share-btn--labeled) {
    width: 1.45rem;
    height: 1.45rem;
    padding: 0.18rem;
}

.event-gallery__head .event-share-btn:not(.event-share-btn--labeled) .event-share-btn__icon {
    width: 0.82rem;
    height: 0.82rem;
}

.gallery-share-overlay {
    position: fixed;
    inset: 0;
    z-index: 4900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: rgba(0, 0, 0, 0.45);
    box-sizing: border-box;
}

.gallery-share-overlay[hidden] {
    display: none !important;
}

body.gallery-share-open {
    overflow: hidden;
}

.gallery-share-popover {
    position: relative;
    width: min(22rem, calc(100vw - 2rem));
    padding: 1.5rem 1rem 0.85rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    box-shadow: 0 10px 32px color-mix(in srgb, var(--color-text) 18%, transparent);
    box-sizing: border-box;
}

.gallery-share-popover__title {
    margin: 0 0 0.65rem;
}

.gallery-share-popover__row {
    display: flex;
    gap: 0.45rem;
    align-items: stretch;
}

.gallery-share-popover__input {
    flex: 1 1 auto;
    min-width: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.62rem;
    padding: 0.4rem 0.45rem;
    border: 1px solid var(--color-border);
    border-radius: 2px;
    background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
    color: var(--color-text);
}

.gallery-share-popover__copy {
    flex-shrink: 0;
}

.gallery-share-popover__close {
    position: absolute;
    top: 0.35rem;
    right: 0.35rem;
    width: 1.35rem;
    height: 1.35rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--color-text-light);
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
}

.gallery-share-popover__close:hover {
    color: var(--color-accent);
}

.event-gallery__empty {
    margin: 0;
    text-align: center;
    color: var(--color-text-light);
}

/* Masonry: JS-Layout (kürzeste Spalte) — event-gallery-masonry.js */
.event-gallery__grid--masonry {
    --event-gallery-masonry-gap: 0.35rem;
    position: relative;
    width: 100%;
    min-height: 1px;
}

.event-gallery__grid--masonry:not(.event-gallery__grid--masonry-ready) {
    visibility: hidden;
}

.event-gallery__grid--masonry.event-gallery__grid--masonry-ready {
    visibility: visible;
}

.event-gallery__grid--masonry .event-gallery__item {
    position: absolute;
    margin: 0;
    padding: 0;
    min-width: 0;
}

.event-gallery__grid--masonry .event-gallery__img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 5px;
    vertical-align: top;
}

/* Galerie: quadratische Blöcke (max. 4 / Zeile, sonst 2 Spalten) */
.event-gallery__grid--block {
    display: grid;
    gap: 0.75rem;
    width: 100%;
}

.event-gallery__grid--block-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.event-gallery__grid--block-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.event-gallery__grid--block .event-gallery__item--block {
    margin: 0;
    aspect-ratio: 1 / 1;
    border-radius: 14px;
    overflow: hidden;
    background: var(--color-border);
}

.event-gallery__grid--block .event-gallery__item--block .event-gallery__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit;
}

@media (max-width: 768px) {
    .event-gallery__grid--block-cols-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.event-gallery__grid .event-gallery__item {
    cursor: zoom-in;
}

.event-gallery__grid .event-gallery__img {
    cursor: zoom-in;
}

.event-gallery__grid .event-gallery__item--video,
.event-gallery__grid .event-gallery__item--video .event-gallery__img {
    cursor: pointer;
}

.event-gallery__item--video {
    position: relative;
}

.event-gallery__video-play {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    background: color-mix(in srgb, var(--color-accent) 88%, #fff);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    pointer-events: none;
    z-index: 2;
}

.event-gallery__video-play::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 54%;
    transform: translate(-50%, -50%);
    border-style: solid;
    border-width: 0.38rem 0 0.38rem 0.65rem;
    border-color: transparent transparent transparent var(--color-bg);
}

.event-gallery__video-placeholder {
    display: block;
    width: 100%;
    min-height: 5rem;
    background: #1a1a1a;
}

.event-gallery__grid--block .event-gallery__item--video .event-gallery__img--video-poster,
.event-gallery__grid--block .event-gallery__item--video .event-gallery__video-placeholder {
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
}

.event-gallery__grid--stacked-circles .event-gallery__item--video .event-gallery__video-placeholder {
    position: absolute;
    inset: 0;
    min-height: 0;
}

.event-gallery__grid--stacked-circles .event-gallery__item--video .event-gallery__video-play {
    width: 1.65rem;
    height: 1.65rem;
}

.event-gallery__grid--stacked-circles .event-gallery__item--video .event-gallery__video-play::after {
    border-width: 0.3rem 0 0.3rem 0.5rem;
}

/* Galerie-, Yoga-Modul-, Tanz-Spotify- & Medien-Picker-Vorschau-Lightbox */
.gallery-lightbox.media-lightbox,
.yoga-im-alltag-lightbox.media-lightbox,
.tanz-spotify-lightbox.media-lightbox,
.gallery-media-picker-preview.media-lightbox {
    position: fixed;
    inset: 0;
    z-index: 5000;
    background: rgba(0, 0, 0, 0.88);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    box-sizing: border-box;
}

.gallery-media-picker-preview.media-lightbox {
    z-index: 5200;
}

.yoga-im-alltag-lightbox.media-lightbox {
    z-index: 5100;
}

.gallery-lightbox.media-lightbox[hidden],
.yoga-im-alltag-lightbox.media-lightbox[hidden],
.tanz-spotify-lightbox.media-lightbox[hidden],
.gallery-media-picker-preview.media-lightbox[hidden] {
    display: none !important;
}

body.gallery-lightbox-open,
body.yoga-im-alltag-lightbox-open,
body.tanz-spotify-lightbox-open {
    overflow: hidden;
}

.media-lightbox__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 2;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid rgba(255, 255, 255, 0.35);
    background: rgba(0, 0, 0, 0.4);
    color: #fff;
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
    border-radius: 2px;
}

.media-lightbox__close:hover {
    background: rgba(255, 255, 255, 0.12);
}

.media-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid rgba(255, 255, 255, 0.35);
    background: rgba(0, 0, 0, 0.4);
    color: #fff;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    border-radius: 2px;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    padding: 0;
}

.media-lightbox__nav:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.12);
}

.media-lightbox__nav:disabled {
    opacity: 0.25;
    cursor: default;
}

.media-lightbox__nav--prev {
    left: 1rem;
}

.media-lightbox__nav--next {
    right: 1rem;
}

.media-lightbox__frame {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
    max-width: min(960px, calc(100% - 6rem));
    max-height: calc(100vh - 4rem);
}

.gallery-lightbox .media-lightbox__frame {
    overflow: visible;
    justify-content: center;
}

.gallery-lightbox .media-lightbox__content--video {
    width: 100%;
    flex: 0 1 auto;
    min-height: 0;
    overflow: visible;
}

.gallery-lightbox .media-lightbox__caption {
    flex: 0 0 auto;
    width: 100%;
    padding: 0 0.5rem;
    box-sizing: border-box;
}

.media-lightbox__content {
    flex: 1;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.media-lightbox__content img,
.media-lightbox__content .page-ika-video-frame:not(.gallery-lightbox__video) {
    max-width: 100%;
    max-height: calc(100vh - 7rem);
    width: auto;
    height: auto;
    display: block;
}

.media-lightbox__content video:not(.page-ika-video-player) {
    max-width: 100%;
    max-height: calc(100vh - 7rem);
    width: auto;
    height: auto;
    display: block;
}

.media-lightbox__caption {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.72);
    text-align: center;
    line-height: 1.45;
    max-width: 100%;
    word-break: break-word;
}

/* Galerie-Lightbox: natives Video (Controls zuverlässig — kein Plyr) */
.gallery-lightbox__video-host {
    width: 100%;
    max-width: min(960px, calc(100vw - 6rem));
    margin: 0 auto;
    border-radius: 12px;
    background: #141414;
    overflow: visible;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.22);
}

.gallery-lightbox__video-host .gallery-lightbox__video-el,
.gallery-lightbox__video-host video {
    display: block;
    width: 100%;
    height: auto;
    max-height: calc(100vh - 14rem);
    object-fit: contain;
    vertical-align: top;
    border-radius: 12px;
}

.event-detail .event-combo-columns__media--video .page-ika-plyr,
.event-detail .event-mixed__media--video .page-ika-plyr {
    cursor: zoom-in;
}

.event-gallery__grid--stacked-circles {
    --stack-count: 4;
    --stack-circle-min: 4.5rem;
    --stack-circle-overlap: 2.75rem;
    --stack-circle-size: max(
        var(--stack-circle-min),
        calc(
            (100% + (var(--stack-count) - 1) * var(--stack-circle-overlap)) /
                var(--stack-count)
        )
    );
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    max-width: 100%;
    gap: 0;
    padding: 1rem 0 0.6rem;
    box-sizing: border-box;
}

.event-gallery__grid--stacked-circles .event-gallery__item--circle {
    position: relative;
    display: block;
    flex: 0 0 var(--stack-circle-size);
    width: var(--stack-circle-size);
    height: var(--stack-circle-size);
    min-width: var(--stack-circle-size);
    min-height: var(--stack-circle-size);
    max-width: var(--stack-circle-size);
    max-height: var(--stack-circle-size);
    aspect-ratio: 1 / 1;
    margin: 0 0 0 calc(-1 * var(--stack-circle-overlap));
    padding: 0;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid var(--color-bg);
    box-shadow: 0 4px 16px color-mix(in srgb, var(--color-text) 14%, transparent);
    box-sizing: border-box;
    align-self: center;
}

.event-gallery__grid--stacked-circles .event-gallery__item--circle:first-child {
    margin-left: 0;
}

/* Block-Layout: ein einzelnes Bild nutzt die volle Breite */
.event-gallery__grid--block-cols-2:has(.event-gallery__item--block:only-child) {
    grid-template-columns: minmax(0, 1fr);
}

@media (max-width: 768px) {
    .event-gallery__grid--stacked-circles {
        --stack-circle-min: 3.75rem;
        --stack-circle-overlap: 2rem;
        padding: 0.75rem 0 0.45rem;
    }

    .event-gallery__grid--stacked-circles .event-gallery__item--circle {
        border-width: 3px;
    }
}

.event-gallery__item--stack-pos-0 { z-index: 1; }
.event-gallery__item--stack-pos-1 { z-index: 2; }
.event-gallery__item--stack-pos-2 { z-index: 3; }
.event-gallery__item--stack-pos-3 { z-index: 4; }
.event-gallery__item--stack-pos-4 { z-index: 5; }
.event-gallery__item--stack-pos-5 { z-index: 6; }
.event-gallery__item--stack-pos-6 { z-index: 7; }
.event-gallery__item--stack-pos-7 { z-index: 8; }
.event-gallery__item--stack-pos-8 { z-index: 9; }
.event-gallery__item--stack-pos-9 { z-index: 10; }
.event-gallery__item--stack-pos-10 { z-index: 11; }
.event-gallery__item--stack-pos-11 { z-index: 12; }

.event-gallery__grid--stacked-circles .event-gallery__item--circle .event-gallery__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 50%;
}

/* Galerie-Panel (Medienbibliothek) */
.modular-gallery-layout-select {
    width: 100%;
    padding: 0.45rem 0.55rem;
    font-family: 'Inter', sans-serif;
    font-size: 0.88rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
}

.modular-gallery-add-btn {
    width: 100%;
    justify-content: center;
}

.modular-gallery-selected {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 3.5rem;
    max-height: 14rem;
    overflow-y: auto;
    padding: 0.5rem;
    border: 1px dashed var(--color-border);
    border-radius: 6px;
    background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
}

.modular-gallery-selected__empty {
    margin: 0;
    width: 100%;
    text-align: center;
}

.modular-gallery-selected__row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: #fff;
}

.modular-gallery-selected__thumb {
    width: 2.5rem;
    height: 2.5rem;
    flex-shrink: 0;
    object-fit: contain;
    object-position: center;
    background: #e8e8e8;
    border-radius: 3px;
    display: block;
}

.modular-gallery-selected__thumb--video {
    position: relative;
    background: #1a1a1a;
}

.modular-gallery-selected__thumb--video::after {
    content: '▶';
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--color-accent);
}

.modular-gallery-selected__label {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 0;
}

.modular-gallery-selected__actions {
    display: flex;
    align-items: center;
    gap: 0.2rem;
    flex-shrink: 0;
}

.modular-gallery-selected__actions button {
    width: 1.25rem;
    height: 1.25rem;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 2px;
    background: #fff;
    font-size: 0.7rem;
    line-height: 1;
    cursor: pointer;
}

.modular-gallery-selected__actions button:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.modular-gallery-selected__remove {
    color: #c62828;
    border-color: #ef9a9a !important;
}

/* Medien-Picker (Galerie) — Grid & Filter wie Dashboard */
.media-filter-bar {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.media-filter-bar--categories .admin-filter-btn {
    font-size: 0.65rem;
    padding: 0.25rem 0.45rem;
}

.media-sort {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.75rem;
    padding: 0.35rem 0.5rem;
    border: 1px solid var(--color-border);
    background: var(--color-bg);
    color: var(--color-text);
    border-radius: 2px;
    cursor: pointer;
    flex-shrink: 0;
}

.media-sort:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 28%, transparent);
    outline-offset: 2px;
}

.media-library-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
    gap: var(--spacing-sm, 1rem);
}

.media-library-empty {
    grid-column: 1 / -1;
    margin: 0;
    text-align: center;
    color: var(--color-text-light);
    font-size: 0.85rem;
    padding: var(--spacing-md, 2rem);
}

.media-library-empty--error {
    color: #c62828;
}

.media-pagination {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 0.5rem 0 0;
}

.media-pagination[hidden] {
    display: none !important;
}

.media-pagination__meta {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.62rem;
    color: var(--color-text-light);
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.media-pagination__controls {
    display: flex;
    align-items: center;
    gap: 0.2rem;
}

.media-pagination__btn {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    min-width: 1.65rem;
    height: 1.65rem;
    padding: 0 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 2px;
    background: transparent;
    color: var(--color-text);
    cursor: pointer;
    transition:
        border-color 0.2s ease,
        color 0.2s ease,
        background 0.2s ease;
    line-height: 1;
}

.media-pagination__btn:hover:not(:disabled) {
    border-color: var(--color-accent);
    color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 6%, var(--color-bg));
}

.media-pagination__btn.is-active {
    background: var(--color-text);
    border-color: var(--color-text);
    color: var(--color-bg);
    cursor: default;
}

.media-pagination__btn:disabled {
    opacity: 0.35;
    cursor: default;
}

.media-pagination__btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 28%, transparent);
    outline-offset: 2px;
}

.media-pagination__gap {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.62rem;
    color: var(--color-text-light);
    padding: 0 0.1rem;
    user-select: none;
}

.gallery-media-picker {
    position: fixed;
    inset: 0;
    z-index: 3600;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    background: color-mix(in srgb, var(--color-text) 55%, transparent);
    box-sizing: border-box;
}

.gallery-media-picker[hidden] {
    display: none !important;
}

body.gallery-media-picker-open {
    overflow: hidden;
}

.gallery-media-picker__panel {
    display: flex;
    flex-direction: column;
    width: min(60rem, 100%);
    height: min(92vh, 58rem);
    max-height: calc(100vh - 2.5rem);
    min-height: 0;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    box-shadow: 0 16px 48px color-mix(in srgb, var(--color-text) 22%, transparent);
    box-sizing: border-box;
    overflow: hidden;
}

.gallery-media-picker__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
    padding: 0.85rem 1.25rem;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.gallery-media-picker__header-copy {
    min-width: 0;
}

.gallery-media-picker__header-copy .type-section {
    margin: 0 0 0.2rem;
}

.gallery-media-picker__header-copy .type-caption {
    margin: 0;
}

.gallery-media-picker__close {
    flex-shrink: 0;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: transparent;
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    color: var(--color-text);
}

.gallery-media-picker__close:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.gallery-media-picker__apply-btn {
    flex-shrink: 0;
    min-width: 6.5rem;
}

.gallery-media-picker__apply-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.gallery-media-picker__toolbar {
    flex-shrink: 0;
    padding: 0.65rem 1.25rem 0.75rem;
    border-bottom: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
}

.image-panel .btn-gallery--primary {
    font-weight: 600;
}

.gallery-media-picker__toolbar-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem 1rem;
}

.gallery-media-picker__toolbar-filters {
    display: flex;
    flex: 1 1 auto;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.65rem;
    min-width: 0;
}

.gallery-media-picker__toolbar-row .media-filter-bar {
    flex: 1 1 auto;
    min-width: 0;
}

.gallery-media-picker__search {
    flex: 0 1 11.5rem;
    min-width: 7.5rem;
    max-width: 100%;
    margin: 0;
    padding: 0.3rem 0.55rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    line-height: 1.35;
    color: var(--color-text);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    box-sizing: border-box;
}

.gallery-media-picker__search::placeholder {
    color: var(--color-text-light);
    opacity: 0.85;
}

.gallery-media-picker__search:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 22%, transparent);
}

.gallery-media-picker__body {
    flex: 1 1 0;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 0.5rem 1.25rem 0.35rem;
    -webkit-overflow-scrolling: touch;
}

.gallery-media-picker__grid {
    --gallery-picker-col-min: 7.25rem; /* = JS PICKER_GRID_MIN_COL 116px */
    --gallery-picker-row-gap: 0.55rem;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--gallery-picker-col-min), 1fr));
    grid-auto-rows: max-content;
    gap: var(--gallery-picker-row-gap);
    width: 100%;
    align-content: start;
    align-items: start;
}

.gallery-media-picker__empty {
    grid-column: 1 / -1;
    margin: 0;
    text-align: center;
    color: var(--color-text-light);
    font-size: 0.85rem;
    padding: 2rem 1rem;
}

.gallery-media-picker__empty--error {
    color: #c62828;
}

.gallery-media-picker__sentinel {
    grid-column: 1 / -1;
    min-height: 1px;
    pointer-events: none;
}

.gallery-media-picker__pexels {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    padding: 0.5rem 1.25rem 0.55rem;
    border-top: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-text) 2%, var(--color-bg));
}

.gallery-media-picker--video .gallery-media-picker__pexels {
    display: none;
}

.gallery-media-picker__pexels-bar {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.gallery-media-picker__pexels-label {
    flex: 0 0 auto;
    font-size: 0.58rem;
    font-weight: 500;
    color: var(--color-text-light);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

.gallery-media-picker__pexels-input {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
    padding: 0.32rem 0.45rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-bg);
    font-family: var(--font-mono-custom, monospace);
    font-size: 0.68rem;
    color: var(--color-text);
    box-sizing: border-box;
}

.gallery-media-picker__pexels-input:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 45%, transparent);
    outline-offset: 1px;
}

.gallery-media-picker__pexels-input:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.gallery-media-picker__pexels-btn {
    flex: 0 0 auto;
    font-family: var(--btn-font-family, var(--font-mono-custom, monospace));
    font-size: 0.62rem;
    font-weight: var(--btn-font-weight, 500);
    text-transform: uppercase;
    letter-spacing: var(--btn-letter-spacing, 0.08em);
    padding: 0.32rem 0.55rem;
    border-radius: var(--btn-radius, 4px);
    border: 1px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    background: transparent;
    color: var(--color-accent);
    cursor: pointer;
}

.gallery-media-picker__pexels-btn:hover:not(:disabled) {
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
}

.gallery-media-picker__pexels-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.gallery-media-picker__pexels-btn--clear {
    border-color: var(--color-border);
    color: var(--color-text-light);
}

.gallery-media-picker__pexels-btn--clear:hover:not(:disabled) {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.gallery-media-picker__pexels-btn--clear[hidden] {
    display: none !important;
}

.gallery-media-picker__footer {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 0.5rem 1rem;
    padding: 0.55rem 1.25rem 0.65rem;
    border-top: 1px solid var(--color-border);
    background: var(--color-bg);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

.gallery-media-picker__footer-zone {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.gallery-media-picker__footer-zone--start {
    justify-content: flex-start;
}

.gallery-media-picker__footer-zone--center {
    justify-content: center;
}

.gallery-media-picker__footer-zone--end {
    justify-content: flex-end;
}

.gallery-media-picker__dash-link {
    text-decoration: none;
}

.gallery-media-picker__card {
    display: block;
    width: 100%;
    min-width: 0;
    aspect-ratio: 1;
    padding: 0;
    margin: 0;
    border: 2px solid color-mix(in srgb, var(--color-border) 88%, transparent);
    border-radius: 8px;
    background: #ececec;
    cursor: pointer;
    overflow: hidden;
    text-align: left;
    appearance: none;
    -webkit-appearance: none;
    font: inherit;
    color: inherit;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}

.gallery-media-picker__card:hover {
    border-color: color-mix(in srgb, var(--color-accent) 50%, var(--color-border));
    transform: translateY(-1px);
}

.gallery-media-picker__card.is-selected {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 24%, transparent);
}

.gallery-media-picker__thumb-wrap {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
    line-height: 0;
    background: #e8e8e8;
}

.gallery-media-picker__thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    pointer-events: none;
}

.gallery-media-picker__thumb-fallback {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 1.25rem;
    color: var(--color-text-light);
    background: #e8e8e8;
}

.gallery-media-picker__card--video .gallery-media-picker__thumb-wrap::after {
    content: '▶';
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    color: #fff;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);
    pointer-events: none;
}

.gallery-media-picker__thumb-fallback--video {
    background: #1a1a1a;
    color: var(--color-accent);
    font-size: 1.75rem;
}

.gallery-media-picker__thumb-fallback--video::before {
    content: '▶';
}

.modular-video-selected {
    margin: 0 0 0.5rem;
    color: var(--color-text-light);
    word-break: break-all;
}

.modular-video-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
}

.modular-video-actions .btn-inline {
    flex: 1 1 auto;
    min-width: 0;
    margin: 0;
}

.modular-video-thumb-wrap {
    margin: 0 0 0.65rem;
    border-radius: 8px;
    overflow: hidden;
    background: #1a1a1a;
    aspect-ratio: 16 / 9;
}

.modular-video-thumb-preview {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-media-picker__check {
    position: absolute;
    top: 0.35rem;
    right: 0.35rem;
    width: 1.35rem;
    height: 1.35rem;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    color: #fff;
    background: var(--color-accent);
    border-radius: 50%;
}

.gallery-media-picker__card.is-selected .gallery-media-picker__check {
    display: flex;
}

.gallery-media-picker__card--pexels .gallery-media-picker__thumb-wrap {
    position: relative;
}

.gallery-media-picker__card--pexels:disabled {
    opacity: 0.55;
    cursor: wait;
}

.gallery-media-picker__pexels-credit {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 0.18rem 0.22rem;
    font-family: var(--font-mono-custom, monospace);
    font-size: 0.48rem;
    line-height: 1.2;
    color: #fff;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.72));
    text-align: left;
    pointer-events: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gallery-media-picker-preview__frame {
    gap: 0.85rem;
}

.gallery-media-picker-preview__select {
    flex-shrink: 0;
}

@media (max-width: 640px) {
    .gallery-media-picker__footer {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        gap: 0.55rem;
    }

    .gallery-media-picker__footer-zone--start,
    .gallery-media-picker__footer-zone--center,
    .gallery-media-picker__footer-zone--end {
        justify-content: stretch;
    }

    .gallery-media-picker__footer-zone--end {
        flex-wrap: wrap;
    }

    .gallery-media-picker__footer-zone--end .gallery-media-picker__apply-btn {
        flex: 1 1 auto;
    }
}

.event-video-container {
    width: 100%;
}

.event-video-container .page-ika-video-frame {
    width: 100%;
}

.event-video-placeholder {
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
}

.event-map-block {
    width: 100%;
}

.event-map-block__frame {
    position: relative;
    aspect-ratio: 2 / 1;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-accent) 28%, var(--color-border));
    background: color-mix(in srgb, var(--color-accent) 6%, var(--color-bg));
}

.event-map-block__canvas {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.event-map-block__canvas,
.event-map-block__canvas > div {
    width: 100%;
    height: 100%;
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
    font-family: inherit;
}

.event-map-block__accent {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--color-accent) 14%, transparent),
        transparent 55%
    );
}

.event-map-block__placeholder {
    aspect-ratio: 2 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    text-align: center;
    color: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
    border-radius: 12px;
    background: color-mix(in srgb, var(--color-accent) 22%, #2a2a2a);
    border: 1px dashed color-mix(in srgb, var(--color-accent) 45%, transparent);
}

.modular-map-status {
    margin: 0.35rem 0 0;
    color: var(--color-text-light);
}

.modular-map-status.is-error {
    color: #b42318;
}

.event-detail > .event-modular-picker {
    margin-top: var(--event-block-gap);
}

.event-modular-add-strip {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin: 0;
    padding: 0.85rem 1rem;
    background: #f5f5f5;
    border: 2px dashed var(--color-border);
    border-radius: 12px;
    text-align: center;
}

.event-modular-add-label {
    margin: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-light);
    line-height: 1.4;
}

.event-modular-add-buttons {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    width: 100%;
}

.event-modular-add-btn {
    height: 2rem;
    padding: 0 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.event-modular-add-btn:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.block-controls {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(calc(-100% - 0.75rem), -50%);
    display: none;
    flex-direction: column;
    gap: 0.25rem;
    align-items: center;
    z-index: 1002;
    pointer-events: auto;
    padding: 0.15rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.preview-block.active .block-controls,
.block-controls.visible {
    display: flex;
}

.block-controls button {
    width: 1.75rem;
    height: 1.75rem;
    padding: 0;
    margin: 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    font-size: 0.7rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.block-controls .block-arrow:hover {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.block-controls .block-duplicate {
    color: var(--color-text);
}

.block-controls .block-duplicate__icon {
    display: block;
    width: 0.95rem;
    height: 0.95rem;
}

.block-controls .block-duplicate:hover,
.block-controls .block-duplicate.is-menu-open {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.block-controls .block-duplicate[disabled],
.block-controls .block-duplicate[hidden] {
    display: none !important;
}

.event-block-copy-menu {
    position: fixed;
    z-index: 11050;
    min-width: 10.5rem;
    padding: 0.3rem;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.16);
    font-family: 'Inter', sans-serif;
}

.event-block-copy-menu[hidden] {
    display: none !important;
}

.event-block-copy-menu button {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0.45rem 0.65rem;
    border: none;
    border-radius: 5px;
    background: transparent;
    font-size: 0.82rem;
    text-align: left;
    color: var(--color-text);
    cursor: pointer;
}

.event-block-copy-menu button:hover,
.event-block-copy-menu button:focus-visible {
    background: color-mix(in srgb, var(--color-accent) 18%, var(--color-bg));
    outline: none;
}

.event-modular-add-btn--paste {
    margin-left: auto;
    border-style: dashed;
    font-weight: 500;
}

.event-modular-add-btn--paste[disabled] {
    display: none !important;
}

.block-controls .block-delete {
    background: transparent;
    color: color-mix(in srgb, var(--color-text, #1a1a1a) 70%, transparent);
}

.block-controls .block-delete:hover {
    background: color-mix(in srgb, var(--color-text, #1a1a1a) 6%, transparent);
    border-color: color-mix(in srgb, var(--color-text, #1a1a1a) 18%, transparent);
    color: var(--color-text, #1a1a1a);
}

/* Löschen-Bestätigung (modulare Blöcke) */
.admin-confirm-overlay {
    position: fixed;
    inset: 0;
    z-index: 12000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: rgba(0, 0, 0, 0.45);
}

.admin-confirm-overlay[hidden] {
    display: none !important;
}

body.admin-confirm-open {
    overflow: hidden;
}

.admin-confirm-dialog {
    width: min(100%, 22rem);
    padding: 1.25rem 1.35rem 1.1rem;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.22);
    font-family: 'Inter', sans-serif;
}

.admin-confirm-title {
    margin: 0 0 0.5rem;
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--color-text);
}

.admin-confirm-message {
    margin: 0 0 1.1rem;
    font-size: 0.9rem;
    line-height: 1.45;
    color: var(--color-text-light);
}

.admin-confirm-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.admin-confirm-cancel,
.admin-confirm-delete {
    padding: 0.45rem 0.85rem;
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    cursor: pointer;
    border: 1px solid var(--color-border);
    background: #fff;
    color: var(--color-text);
}

.admin-confirm-cancel:hover {
    border-color: var(--color-text-light);
    background: #f5f5f5;
}

.admin-confirm-delete {
    border-color: #c62828;
    background: #c62828;
    color: #fff;
}

.admin-confirm-delete:hover {
    background: #b71c1c;
    border-color: #b71c1c;
}

.block-controls .add-block-btn {
    background: var(--color-accent);
    color: #fff;
    border-color: var(--color-accent);
    font-size: 1rem;
}

.block-controls .add-block-btn:hover {
    filter: brightness(0.95);
}

.block-controls--add-only {
    padding: 0.1rem;
}

#newsletterHeaderPreview .block-controls,
#newsletterGreetingPreview .block-controls,
#newsletterFooterPreview .block-controls {
    z-index: 1003;
}

#modularPanel .editor-field--cols-inline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: nowrap;
}

#modularPanel .editor-field--cols-inline label {
    margin: 0;
    flex: 0 0 auto;
}

#modularPanel .editor-field--quill .modular-quill-wrap {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    width: 100%;
    min-height: 8rem;
    height: auto;
    max-height: none;
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 6px;
}

#modularPanel .editor-field--quill .modular-quill-editor {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

#modularPanel .editor-field--quill .ql-toolbar {
    flex-shrink: 0;
    border: none;
    border-bottom: 1px solid var(--color-border);
    border-radius: 6px 6px 0 0;
    font-family: 'JetBrains Mono', monospace;
    background: #fff;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

#modularPanel .editor-field--quill .ql-toolbar.ql-snow {
    padding: 0.12rem 0.2rem;
}

#modularPanel .ql-toolbar.ql-snow button,
#modularPanel .ql-toolbar.ql-snow .ql-picker-label {
    width: 1.28rem;
    height: 1.15rem;
    padding: 0.08rem;
}

#modularPanel .ql-toolbar.ql-snow .ql-formats {
    display: inline-flex;
    flex-shrink: 0;
    align-items: center;
    margin-right: 0;
}

#modularPanel .ql-toolbar.ql-snow .ql-formats:not(:first-child) {
    margin-left: 0.15rem;
    padding-left: 0.28rem;
    border-left: 1px solid var(--color-border);
}

#modularPanel .ql-toolbar .ql-formats--columns {
    gap: 0.06rem;
    align-items: center;
}

#modularPanel .ql-toolbar.ql-snow button.ql-columns {
    width: auto;
    min-width: 0;
    height: auto;
    min-height: 0;
    padding: 0 0.16rem;
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.58rem;
    font-weight: 600;
    line-height: 1;
    border-radius: 2px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
}

#modularPanel .ql-toolbar.ql-snow button.ql-columns.ql-active {
    color: #fff;
    background: var(--color-accent);
}

#modularPanel .editor-field--quill .ql-container {
    flex: 1 1 auto;
    border: none;
    min-height: 0 !important;
    height: auto !important;
    max-height: none;
    border-radius: 0 0 6px 6px;
    overflow-y: auto !important;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

#modularPanel .editor-field--quill .ql-editor {
    min-height: 100%;
    height: auto;
    overflow: visible;
    padding: 0.5rem 0.55rem;
}

#modularPanel:not([data-panel-text-mode='note']):not([data-panel-text-mode='footnote'])
    .editor-field--quill :is(.ql-container, .ql-editor) {
    font-size: var(--modular-quill-body-size);
    line-height: var(--modular-quill-body-line);
}

/* Bild-Block: Single | Galerie */
#modularPanel .modular-image-mode-select {
    width: 100%;
    padding: 0.45rem 0.55rem;
    font-family: 'Inter', sans-serif;
    font-size: 0.88rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    color: var(--color-text);
    cursor: pointer;
}

#modularPanel .modular-image-mode-select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 18%, transparent);
}

/* Text block modes (normal | note | quote | accordion | timetable) */
#modularPanel .modular-text-mode-select {
    width: 100%;
    padding: 0.45rem 0.55rem;
    font-family: 'Inter', sans-serif;
    font-size: 0.88rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fff;
    color: var(--color-text);
    cursor: pointer;
}

#modularPanel .modular-text-mode-select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 18%, transparent);
}

.modular-structure-add-btn {
    margin-top: 0.5rem;
    width: 100%;
    padding: 0.45rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    border: 1px dashed var(--color-border);
    border-radius: 6px;
    background: transparent;
    cursor: pointer;
}

.modular-structure-add-btn:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.modular-accordion-editor.text-accordion,
.modular-timetable-editor {
    max-height: 240px;
    overflow-y: auto;
}

/* Toggle-Editor: kompakt, Mono wie Panel-UI (≠ Frontend-Vorschau) */
.modular-accordion-editor.text-accordion {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.modular-accordion-editor .modular-accordion-item {
    margin: 0;
    padding: 0.3rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fafafa;
    box-shadow: none;
}

.modular-accordion-editor .modular-accordion-edit-head {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-bottom: 0.2rem;
}

#modularPanel .modular-accordion-editor .modular-structure-actions {
    gap: 0.15rem;
}

#modularPanel .modular-accordion-editor .modular-structure-move,
#modularPanel .modular-accordion-editor .modular-structure-remove {
    width: 1.2rem;
    height: 1.2rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    border-radius: 3px;
}

#modularPanel .modular-accordion-editor .modular-structure-remove {
    font-size: 0.75rem;
}

#modularPanel .modular-accordion-editor .modular-accordion-title {
    flex: 1;
    min-width: 0;
    width: auto;
    margin: 0;
    padding: 0.2rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: 0.02em;
    text-transform: none;
    color: var(--color-text);
}

#modularPanel .modular-accordion-editor .modular-accordion-title::placeholder {
    color: color-mix(in srgb, var(--color-text) 40%, transparent);
    font-weight: 400;
}

#modularPanel .modular-accordion-editor .modular-accordion-title:focus {
    outline: none;
    border-color: var(--color-accent);
}

#modularPanel .modular-accordion-editor .modular-accordion-body {
    display: block;
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    padding: 0.2rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: #fff;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.68rem;
    font-weight: 400;
    line-height: 1.4;
    color: var(--color-text);
    resize: vertical;
    height: 71px;
    min-height: 71px;
}

#modularPanel .modular-accordion-editor .modular-accordion-body:focus {
    outline: none;
    border-color: var(--color-accent);
}

.modular-timetable-row {
    padding: 0.55rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: #fafafa;
}

.modular-structure-row-head {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 0.4rem;
}

.modular-accordion-title,
.modular-timetable-fields input {
    width: 100%;
    padding: 0.4rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
}

.modular-accordion-body {
    width: 100%;
    padding: 0.4rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    line-height: 1.45;
    resize: vertical;
}

.modular-timetable-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
}

.modular-timetable-title-field {
    grid-column: 1 / -1;
}

.modular-timetable-row-label {
    flex: 1;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    color: var(--color-text-light);
}

.modular-structure-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    flex-shrink: 0;
}

.modular-structure-move {
    flex-shrink: 0;
    width: 1.6rem;
    height: 1.6rem;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-bg);
    color: var(--color-text);
    cursor: pointer;
    font-size: 0.85rem;
    line-height: 1;
}

.modular-structure-move:hover:not(:disabled) {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.modular-structure-move:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.modular-structure-remove {
    flex-shrink: 0;
    width: 1.6rem;
    height: 1.6rem;
    border: none;
    border-radius: 4px;
    background: #ffebee;
    color: #c62828;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
}

.modular-quote-author-input {
    width: 100%;
}

/* Timetable */
.event-timetable {
    list-style: none;
    margin: 0;
    padding: 0;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.event-timetable-row {
    display: grid;
    grid-template-columns: 4.5rem 4.5rem 1fr;
    gap: 0.35rem 0.75rem;
    padding: 0.65rem 0 0.65rem 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 60%, transparent);
}

.event-timetable-row:last-child {
    border-bottom: none;
}

.event-timetable-time,
.event-timetable-end {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.78rem;
    color: var(--color-accent);
    white-space: nowrap;
}

.event-timetable-title {
    font-weight: 500;
    grid-column: 3;
    grid-row: 1;
}

.event-timetable-note {
    grid-column: 1 / -1;
    font-size: 0.88rem;
    color: color-mix(in srgb, var(--color-text) 75%, var(--color-text-light));
    line-height: 1.45;
}

.event-timetable-note:empty {
    display: none;
}

.event-timetable-end:empty {
    visibility: hidden;
}

/* Terminliste — Kalender-Kacheln (Outline + Mono wie Toggle/FAQ) */
.block-text--terminliste .event-dates-block,
.block-text--note .event-dates-block {
    text-transform: none;
    letter-spacing: 0.02em;
    padding: 0;
    margin: 0;
    background: none;
    border: none;
    border-radius: 0;
}

.block-dates .event-dates-block,
.block-dates .event-dates-block:is(
    .text-note-content--color-accent,
    .text-note-content--accent,
    .text-note-content--color-outline,
    .text-note-content--color-frame-gray,
    .text-note-content--color-frame-black,
    .text-note-content--color-quote-note,
    .text-note-content--color-neutral
) {
    text-transform: none;
    letter-spacing: 0.02em;
    margin: 0;
    box-sizing: border-box;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-caption-size);
    font-weight: 500;
    line-height: 1.5;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

.event-dates-block :is(ul, ol) {
    margin: 0 !important;
    padding: 0 !important;
}

.event-dates-block ul > li.event-dates-chip {
    padding: 0 !important;
    margin: 0;
    position: static;
    list-style: none;
}

.event-dates-block ul > li.event-dates-chip::before,
.event-dates-block ul > li.event-dates-chip::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    margin: 0 !important;
}

.event-dates-block__label,
.event-dates-block__title {
    margin: 0 0 0.45rem;
    max-width: none;
}

.event-dates-block__title-heading {
    margin: 0;
    padding: 0;
    font-family: var(--font-h1);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.02em;
    color: var(--color-accent);
    text-transform: uppercase;
    align-self: flex-start;
}

.event-dates-block__title-heading .text-mark {
    text-transform: uppercase;
    font-size: inherit;
    line-height: inherit;
    vertical-align: top;
}

.event-dates-block__intro {
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    order: 2;
}

.event-dates-block__lede {
    margin: 0 0 0.45rem;
    max-width: none;
    hyphens: auto;
    -webkit-hyphens: auto;
}

.event-dates-block__lede.type-body {
    color: var(--color-text);
}

.event-dates-block__calendar {
    margin: 0.15rem 0 0;
}

.event-dates-block__calendar-link {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-accent);
    text-decoration: none;
    border-bottom: 1px solid color-mix(in srgb, var(--color-accent) 35%, transparent);
    transition: border-color 0.2s ease;
}

.event-dates-block__calendar-link:hover,
.event-dates-block__calendar-link:focus-visible {
    border-bottom-color: var(--color-accent);
}

.event-dates-block__label .text-mark {
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.event-dates-block__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: clamp(1.25rem, 3vw, 2rem);
    row-gap: clamp(0.85rem, 2vw, 1.25rem);
    align-items: start;
}

.event-dates-block__stats {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.5;
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text-light));
}

.event-dates-block__chips-col {
    min-width: 0;
    order: 1;
}

.event-dates-block__chips-col .event-dates-month__chips {
    --event-dates-gap: 0.38rem;
    --event-dates-cols: 6;
    display: grid;
    grid-template-columns: repeat(var(--event-dates-cols), minmax(0, 1fr));
    gap: var(--event-dates-gap);
}

.event-dates-block__chips-col .event-dates-month__chips > .event-dates-chip {
    flex: unset;
    width: 100%;
    height: auto;
    max-width: none;
    aspect-ratio: 1;
}

.event-dates-block__chips-col .event-dates-chip__sheet {
    padding: 0.28rem 0.18rem 0.24rem;
    gap: 0.06rem;
}

.event-dates-block__chips-col .event-dates-chip__weekday,
.event-dates-block__chips-col .event-dates-chip__month {
    font-size: clamp(0.48rem, 0.92vw, 0.6rem);
}

.event-dates-block__chips-col .event-dates-chip__day {
    font-size: clamp(0.82rem, 1.75vw, 1.08rem);
    margin: 0.04rem 0 0.02rem;
}

.event-dates-months {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
}

.event-dates-month {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
    margin: 0;
    padding: 0;
}

.event-dates-month__chips {
    --event-dates-chip-size: clamp(2.65rem, 5.5vw, 3.15rem);
    --event-dates-gap: 0.38rem;
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: var(--event-dates-gap);
}

.event-dates-month__chips > .event-dates-chip {
    flex: 0 0 var(--event-dates-chip-size);
    width: var(--event-dates-chip-size);
    height: var(--event-dates-chip-size);
    max-width: var(--event-dates-chip-size);
    position: relative;
    display: block;
    padding: 0 !important;
    margin: 0;
    list-style: none;
    overflow: hidden;
}

.event-dates-month__chips > .event-dates-chip::before,
.event-dates-month__chips > .event-dates-chip::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    margin: 0 !important;
}

.event-dates-chip {
    margin: 0;
}

.event-dates-chip__sheet {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.08rem;
    box-sizing: border-box;
    margin: 0;
    padding: 0.28rem 0.18rem 0.22rem;
    border: var(--line-weight) solid var(--color-accent);
    border-radius: var(--accordion-radius);
    background: var(--color-accent);
    box-shadow: var(--accordion-shadow);
    line-height: 1;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    color: #fff;
    transition:
        border-color var(--accordion-ease),
        background-color var(--accordion-ease),
        color var(--accordion-ease);
}

.event-dates-chip:not(.event-dates-chip--past):hover .event-dates-chip__sheet {
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 88%, #000);
}

.event-dates-chip--past .event-dates-chip__sheet {
    background: transparent;
    border-color: var(--accordion-border-open);
    color: var(--color-accent);
}

.event-dates-chip--past:hover .event-dates-chip__sheet {
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 6%, transparent);
}

.event-dates-month__chips > .event-dates-chip.event-dates-chip--cancelled .event-dates-chip__sheet {
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
    border-style: dashed;
    border-width: calc(var(--line-weight) + 1px);
    border-color: color-mix(in srgb, var(--color-accent) 72%, var(--color-border));
    color: color-mix(in srgb, var(--color-accent) 88%, var(--color-text));
    opacity: 1;
    text-decoration: line-through;
    text-decoration-thickness: 2px;
    text-decoration-color: currentColor;
}

.event-dates-month__chips > .event-dates-chip.event-dates-chip--cancelled:hover .event-dates-chip__sheet {
    background: color-mix(in srgb, var(--color-accent) 14%, var(--color-bg));
    border-color: var(--color-accent);
}

.event-dates-chip--cancelled .event-dates-chip__weekday,
.event-dates-chip--cancelled .event-dates-chip__day,
.event-dates-chip--cancelled .event-dates-chip__month {
    text-decoration: inherit;
}

.event-dates-chip__weekday,
.event-dates-chip__month {
    font-family: inherit;
    font-size: clamp(0.52rem, 1.05vw, 0.68rem);
    font-weight: 400;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: inherit;
}

.event-dates-chip__day {
    font-family: inherit;
    font-size: clamp(0.95rem, 2.1vw, 1.28rem);
    font-weight: 400;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
    color: inherit;
    margin: 0.06rem 0 0.03rem;
}

@media (max-width: 520px) {
    .event-dates-block__layout {
        grid-template-columns: 1fr;
        column-gap: 0;
    }

    .event-dates-block__chips-col .event-dates-month__chips,
    .event-dates-month__chips {
        --event-dates-gap: 0.32rem;
    }

    .event-dates-block__chips-col .event-dates-month__chips {
        --event-dates-cols: 6;
    }
}

#modularPanel .modular-quote-author-input {
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    line-height: var(--mono-secondary-line);
    font-weight: var(--mono-value-weight);
    color: var(--color-text);
    text-align: left;
    padding: 0.3rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: var(--accordion-radius);
    background: #fff;
}

#modularPanel .modular-quote-author-input::placeholder {
    font-family: var(--mono-font);
    font-size: var(--mono-secondary-size);
    color: var(--color-text-light);
    opacity: 0.85;
}

#modularPanel .modular-quote-author-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 15%, transparent);
}

/* ===== KI-TEXT (MAGIC) — Warte-Feedback im Text-Panel (#modularPanel) ===== */
#modularPanel.magic-ai-panel-busy {
    overflow: hidden;
}

.magic-ai-panel-overlay {
    position: absolute;
    inset: 0;
    z-index: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border-radius: 6px;
    pointer-events: all;
}

.magic-ai-panel-overlay[hidden] {
    display: none !important;
}

.magic-ai-panel-overlay__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
    max-width: 16rem;
    padding: 1rem 1.1rem;
    text-align: center;
    background: #fff;
    border: 2px solid var(--color-accent, #ce8746);
    border-radius: 8px;
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.14);
}

.magic-ai-spinner {
    width: 2.25rem;
    height: 2.25rem;
    border: 3px solid #e0e0e0;
    border-top-color: var(--color-accent, #ce8746);
    border-radius: 50%;
    animation: magic-ai-spin 0.7s linear infinite;
}

.magic-ai-panel-overlay__title {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent, #ce8746);
}

.magic-ai-panel-overlay__sub {
    margin: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    line-height: 1.45;
    color: var(--color-text-light, #666);
}

#modularPanel .magic-ai-status {
    margin: 0 0 0.65rem;
    padding: 0.45rem 0.5rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    line-height: 1.35;
    color: var(--color-accent, #ce8746);
    background: color-mix(in srgb, var(--color-accent, #ce8746) 12%, #fff);
    border: 1px solid color-mix(in srgb, var(--color-accent, #ce8746) 40%, var(--color-border, #ccc));
    border-radius: 4px;
}

#modularPanel .magic-ai-status[hidden] {
    display: none !important;
}

#modularPanel .ql-toolbar button.ql-magic-wand.is-loading .ql-magic-wand-icon {
    animation: magic-ai-spin 0.85s linear infinite;
}

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

/* ===== KONTAKT PAGE ===== */
.page-kontakt:not(.page-design-system) {
    max-width: 100%;
    --kontakt-section-gap: var(--spacing-lg);
    --kontakt-inner-gap: var(--spacing-md);
    --kontakt-after-heading: var(--spacing-sm);
    --kontakt-text-gap: var(--spacing-sm);
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-section-gap);
}

.page-kontakt > .page-kontakt-intro,
.page-kontakt > .page-kontakt-pillars,
.page-kontakt > .page-kontakt-motto,
.page-kontakt > .page-kontakt-columns,
.page-kontakt > .page-kontakt-facts,
.page-kontakt > .page-kontakt-form-wrap,
.page-kontakt > .page-ika-hero,
.page-kontakt > .page-ika-visual,
.page-kontakt > .page-ika-philosophy,
.page-kontakt > .page-ika-background,
.page-kontakt > .page-ika-raum,
.page-kontakt > .page-ika-session,
.page-kontakt > .page-ika-process,
.page-kontakt > .page-ika-legacy,
.page-kontakt > .page-ika-journey-lab,
.page-kontakt > .page-ika-journey,
.page-kontakt > .page-ika-faq,
.page-kontakt > .page-tanz-spotify,
.page-kontakt > .page-ika-closing,
.page-kontakt > .page-ika-footer {
    padding: 0;
    margin: 0;
    border: none;
}

.page-kontakt > .page-kontakt-form-wrap {
    width: 100%;
    max-width: 100%;
}

/* Überschriften: kein globales h2-margin-top, einheitlicher Abstand nach unten */
.page-kontakt h2,
.page-kontakt h3 {
    margin-top: 0;
}

.page-kontakt h2 {
    margin-bottom: var(--kontakt-after-heading);
}

.page-kontakt p:not(.lead-text p) {
    margin-top: 0;
    margin-bottom: var(--kontakt-text-gap);
}

.page-kontakt p:last-child,
.page-kontakt .page-kontakt-col p:last-child,
.page-kontakt .page-kontakt-pillar p,
.page-kontakt .page-kontakt-place-meta,
.page-kontakt .lead-text p {
    margin-bottom: 0;
}

body:not(.admin-page) main .page-kontakt p:not(.lead-text) {
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
}

body:not(.admin-page) main .page-kontakt .lead-text,
body:not(.admin-page) main .page-kontakt .lead-text p {
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
}

.page-kontakt-intro {
    display: grid;
    grid-template-columns: minmax(220px, 34%) 1fr;
    gap: var(--spacing-sm);
    align-items: center;
}

.page-kontakt-portrait {
    margin: 0;
    width: min(100%, 280px);
    aspect-ratio: 1;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.page-kontakt-portrait img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
    filter: contrast(0.68) brightness(1.22);
    transition: filter 0.45s ease;
}

.page-kontakt-portrait:hover img,
.page-kontakt-portrait:focus-within img {
    filter: contrast(1) brightness(1);
}

.page-kontakt-lead.site-quote {
    margin: 0;
}

.page-kontakt-intro .lead-text {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    box-shadow: none;
}

.page-kontakt-intro .lead-text p {
    margin: 0;
    text-align: inherit;
}

.page-kontakt-pillars {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
}

.page-kontakt-pillar {
    padding: var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: var(--color-bg);
}

.page-kontakt-pillar--yoga {
    border-top: 3px solid var(--color-highlight-yoga);
}

.page-kontakt-pillar--ika {
    border-top: 3px solid var(--color-highlight-koerperarbeit);
}

.page-kontakt-pillar--tanz {
    border-top: 3px solid var(--color-highlight-tanz);
}

.page-kontakt-pillar-title {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0 0 var(--kontakt-after-heading);
    line-height: 1.4;
}

.page-kontakt-pillar-title .highlight {
    font-size: inherit;
    padding: 0.15em 0.45em;
    border-radius: 3px;
}

.page-kontakt-pillar p {
    max-width: none;
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.65;
}

.page-kontakt-pillar a {
    text-decoration-color: var(--color-accent);
}

.page-kontakt-motto {
    text-align: center;
}

.page-kontakt-motto .lead-text {
    margin: 0 auto;
    max-width: 36rem;
}

.page-kontakt-motto .lead-text p {
    text-align: center;
}

.page-kontakt-motto .site-quote__attrib {
    margin-top: 0.65rem;
}

body:not(.admin-page) main .page-kontakt-motto .lead-text,
body:not(.admin-page) main .page-kontakt-motto .lead-text p,
body:not(.admin-page) main .page-kontakt-motto .site-quote__attrib {
    text-align: center;
}

/* Kontakt: Zitat-Karussell (Wort-für-Wort + Swipe + Bullet-Dots) */
.quote-carousel {
    position: relative;
    --quote-carousel-fade: 1.8s;
    --quote-word-fade-fast: 0.28s;
    --quote-word-fade-slow: 0.65s;
    --quote-word-fade: var(--quote-word-fade-slow);
    --quote-carousel-ease: cubic-bezier(0.45, 0.05, 0.25, 1);
}

.quote-carousel[data-fade-mode='fast'] {
    --quote-word-fade: var(--quote-word-fade-fast);
}

.quote-carousel[data-fade-mode='slow'] {
    --quote-word-fade: var(--quote-word-fade-slow);
}

.quote-carousel-viewport {
    overflow: hidden;
    touch-action: pan-y;
    outline: none;
    position: relative;
    z-index: 1;
}

.quote-carousel-track {
    position: relative;
    display: block;
    transition: min-height var(--quote-carousel-fade) var(--quote-carousel-ease);
}

.quote-carousel-slide {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    transition: visibility 0s linear var(--quote-carousel-fade);
}

.quote-carousel-slide.is-active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 2;
    transition: visibility 0s linear 0s;
}

.quote-carousel-slide .lead-text p {
    margin: 0;
}

.quote-word {
    display: inline;
    opacity: 0;
    transition: opacity var(--quote-word-fade) var(--quote-carousel-ease);
}

.quote-word.is-visible {
    opacity: 1;
}

.quote-carousel-slide .site-quote__attrib {
    opacity: 0;
    transition: opacity var(--quote-word-fade) var(--quote-carousel-ease);
}

.quote-carousel-slide .site-quote__attrib.is-visible {
    opacity: 1;
}

.quote-carousel-slide .lead-text,
.quote-carousel-slide .site-quote__attrib {
    width: 100%;
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.quote-carousel-dots {
    position: relative;
    z-index: 3;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.15rem;
    margin-top: var(--kontakt-after-heading, var(--spacing-sm));
    padding: 0;
    pointer-events: auto;
}

.quote-carousel-dot {
    width: 0.55rem;
    height: 0.55rem;
    min-width: 1.35rem;
    min-height: 1.35rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: transparent;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
    position: relative;
    flex-shrink: 0;
}

.quote-carousel-dot::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0.55rem;
    height: 0.55rem;
    margin: -0.275rem 0 0 -0.275rem;
    border-radius: 50%;
    background: var(--color-border);
    transition: background 0.2s ease, transform 0.2s ease;
}

.quote-carousel-dot:hover::before,
.quote-carousel-dot:focus-visible::before {
    background: var(--color-text-light);
}

.quote-carousel-dot:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.quote-carousel-dot.is-active::before {
    background: var(--color-accent);
    transform: scale(1.15);
}

@media (prefers-reduced-motion: reduce) {
    .quote-carousel-track,
    .quote-carousel-slide,
    .quote-word,
    .quote-carousel-slide .site-quote__attrib {
        transition: none;
    }
}

.page-kontakt-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--kontakt-inner-gap);
}

.page-kontakt-cta-wrap {
    margin-top: var(--kontakt-inner-gap);
    margin-bottom: 0;
}

.page-kontakt-facts {
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-inner-gap);
    padding: 0;
}

.page-kontakt-form-title {
    font-family: var(--font-h1);
    font-size: clamp(1.75rem, 2.8vw, 2.35rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin: 0 0 var(--kontakt-after-heading);
    color: var(--color-accent);
}

.page-kontakt-cv {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--kontakt-inner-gap) var(--spacing-xl);
    align-items: start;
}

.page-kontakt-cv-title,
.page-kontakt-col-title {
    font-family: var(--font-h1);
    font-size: clamp(1.75rem, 2.8vw, 2.35rem);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin: 0 0 var(--kontakt-after-heading);
    color: var(--color-accent);
}

.page-kontakt-cv-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.page-kontakt-cv-list li {
    display: grid;
    grid-template-columns: 5.5rem 1fr;
    gap: 0.65rem 1rem;
    padding: 0.5rem 0 0.5rem 1rem;
    margin: 0;
    max-width: none;
    font-size: 0.95rem;
    line-height: 1.5;
}

.page-kontakt-cv-list li + li {
    margin-top: 0.15rem;
}

.page-kontakt-cv-year {
    font-family: 'Inter', sans-serif;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: var(--color-accent);
    line-height: 1.45;
    white-space: nowrap;
}

.page-kontakt-cv-text {
    color: var(--color-text);
}

.page-kontakt-cv-text a {
    color: var(--color-text);
    text-decoration-color: var(--color-accent);
}

.page-kontakt-col p {
    max-width: none;
    font-size: 1.05rem;
    line-height: 1.75;
}

.page-kontakt-standort,
.page-kontakt-form-wrap,
.page-kontakt-place p {
    text-align: left;
    hyphens: none;
}

.page-kontakt-standort {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
    margin: 0;
    padding: 0;
    border: none;
}

.page-kontakt-place {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: var(--color-bg);
}

.page-kontakt-place--praxis {
    border-top: 3px solid var(--color-highlight-koerperarbeit);
}

.page-kontakt-place--region {
    border-top: 3px solid var(--color-accent);
}

.page-kontakt-place-title {
    margin: 0;
    color: var(--color-text-light);
}

.page-kontakt-place-main {
    margin: 0;
    max-width: none;
}

.page-kontakt-place-meta {
    margin: 0;
    max-width: none;
    color: var(--color-text-light);
}

body:not(.admin-page) main .page-kontakt-place-main,
body:not(.admin-page) main .page-kontakt-place-meta {
    text-align: left;
}

.page-kontakt-form-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-after-heading);
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    border: none;
    box-sizing: border-box;
}

.page-kontakt-form-head {
    margin: 0;
    padding: 0;
}

.page-kontakt-form-wrap p {
    max-width: none;
}

.page-kontakt-form-lead {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.65;
    color: var(--color-text);
    max-width: none;
}

body:not(.admin-page) main .page-kontakt-form-lead {
    text-align: left;
}

.page-kontakt-form-lead a {
    text-decoration-color: color-mix(in srgb, var(--color-accent) 50%, var(--color-border));
}

.page-kontakt-form-stage {
    display: block;
    position: relative;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    transition: min-height 0.55s cubic-bezier(0.45, 0.05, 0.25, 1);
}

.page-kontakt-form-panel--form,
.page-kontakt-form-panel--success {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding-top: 0;
    box-sizing: border-box;
}

/* [hidden] muss display:flex der Success-Panel-Regel schlagen — sonst nur ~50 % Breite */
.page-kontakt-form-panel[hidden] {
    display: none !important;
}

.page-kontakt-form-panel--form {
    transition:
        opacity 0.48s cubic-bezier(0.4, 0, 0.2, 1),
        transform 0.55s cubic-bezier(0.4, 0, 0.2, 1),
        filter 0.45s ease;
    transform-origin: center top;
}

.page-kontakt-form-panel--form.is-exiting {
    opacity: 0;
    transform: translateY(-14px) scale(0.96);
    filter: blur(8px);
    pointer-events: none;
}

.page-kontakt-form-panel--form.is-exiting .page-kontakt-form-row,
.page-kontakt-form-panel--form.is-exiting > .page-kontakt-form-field {
    animation: kontakt-form-row-out 0.42s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.page-kontakt-form-panel--form.is-exiting .page-kontakt-form-row:nth-child(1),
.page-kontakt-form-panel--form.is-exiting > .page-kontakt-form-field:nth-of-type(1) {
    animation-delay: 0ms;
}

.page-kontakt-form-panel--form.is-exiting .page-kontakt-form-row:nth-child(2),
.page-kontakt-form-panel--form.is-exiting > .page-kontakt-form-field:nth-of-type(2) {
    animation-delay: 45ms;
}

.page-kontakt-form-panel--form.is-exiting .page-kontakt-form-row:nth-child(3),
.page-kontakt-form-panel--form.is-exiting > .page-kontakt-form-field:nth-of-type(3) {
    animation-delay: 90ms;
}

.page-kontakt-form-panel--form.is-exiting .page-kontakt-form-aside {
    animation: kontakt-form-row-out 0.42s cubic-bezier(0.4, 0, 0.2, 1) 0.14s both;
}

@keyframes kontakt-form-row-out {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-10px);
    }
}

.page-kontakt-form-wrap.is-form-submitting .page-kontakt-form-panel--form {
    opacity: 0.72;
    pointer-events: none;
}

.page-kontakt-form-wrap.is-form-submitting .btn-inline {
    cursor: wait;
}

.page-kontakt-form-panel--success:not([hidden]) {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    padding: 0 0 var(--spacing-sm);
    opacity: 0;
    transform: translateY(28px) scale(0.94);
    filter: blur(4px);
    transition:
        opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.55s ease;
}

.page-kontakt-form-panel--success.is-entering,
.page-kontakt-form-panel--success.is-shown {
    opacity: 1;
    transform: none;
    filter: none;
}

/* Fallback ohne JS (Redirect ?gesendet=1) */
.page-kontakt-form-wrap.is-success-landing .page-kontakt-form-panel--success:not(.is-entering):not(.is-shown) {
    opacity: 1;
    transform: none;
    filter: none;
}

.page-kontakt-form-wrap.is-success-landing .page-kontakt-form-panel--success:not(.is-entering):not(.is-shown) .page-kontakt-form-success-kicker,
.page-kontakt-form-wrap.is-success-landing .page-kontakt-form-panel--success:not(.is-entering):not(.is-shown) .page-kontakt-form-success-text {
    opacity: 1;
    transform: none;
}

.page-kontakt-form-wrap.is-success-landing .page-kontakt-form-panel--success:not(.is-entering):not(.is-shown) .page-kontakt-form-success-circle,
.page-kontakt-form-wrap.is-success-landing .page-kontakt-form-panel--success:not(.is-entering):not(.is-shown) .page-kontakt-form-success-check {
    stroke-dashoffset: 0;
}

.page-kontakt-form-success {
    position: relative;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
}

.page-kontakt-form-success-body {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--spacing-lg);
    align-items: start;
}

.page-kontakt-form-success-copy {
    text-align: left;
    min-width: 0;
}

.page-kontakt-form-success-copy p {
    text-transform: none;
    letter-spacing: normal;
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
}

.page-kontakt-form-success-burst {
    position: absolute;
    left: 2.5rem;
    top: 50%;
    width: 11rem;
    height: 11rem;
    margin: -5.5rem 0 0 -5.5rem;
    border-radius: 50%;
    background: radial-gradient(
        circle,
        color-mix(in srgb, var(--color-accent) 28%, transparent) 0%,
        transparent 68%
    );
    opacity: 0;
    transform: scale(0.4);
    pointer-events: none;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-burst {
    animation: kontakt-success-burst 1.1s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
}

@keyframes kontakt-success-burst {
    0% {
        opacity: 0;
        transform: scale(0.35);
    }
    35% {
        opacity: 1;
        transform: scale(1.05);
    }
    100% {
        opacity: 0;
        transform: scale(1.35);
    }
}

.page-kontakt-form-success-mark {
    position: relative;
    z-index: 1;
    display: flex;
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    margin: 0.1rem 0 0;
}

.page-kontakt-form-success-icon {
    display: block;
    overflow: visible;
}

.page-kontakt-form-success-circle {
    stroke: color-mix(in srgb, var(--color-accent) 55%, var(--color-border));
    stroke-dasharray: 145;
    stroke-dashoffset: 145;
}

.page-kontakt-form-success-check {
    stroke: var(--color-accent);
    stroke-dasharray: 48;
    stroke-dashoffset: 48;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-circle {
    animation: kontakt-success-circle-draw 0.65s cubic-bezier(0.45, 0.05, 0.25, 1) 0.12s forwards;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-check {
    animation: kontakt-success-check-draw 0.45s cubic-bezier(0.45, 0.05, 0.25, 1) 0.55s forwards;
}

.page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-circle,
.page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-check {
    stroke-dashoffset: 0;
}

@keyframes kontakt-success-circle-draw {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes kontakt-success-check-draw {
    to {
        stroke-dashoffset: 0;
    }
}

.page-kontakt-form-success-kicker {
    margin: 0 0 0.45rem;
    font-family: var(--font-serif);
    font-size: clamp(1.35rem, 2.2vw, 1.65rem);
    font-weight: 400;
    line-height: 1.25;
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--color-accent);
    opacity: 0;
    transform: translateY(10px);
}

.page-kontakt-form-success-text {
    margin: 0;
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.65;
    color: var(--color-text);
    max-width: none;
    opacity: 0;
    transform: translateY(14px);
}

.page-kontakt-form-success-new {
    display: inline-block;
    margin-top: var(--spacing-md);
    text-transform: none;
    letter-spacing: 0.02em;
    text-decoration: none;
}

.page-kontakt-form-panel--success.is-exiting {
    opacity: 0;
    transform: translateY(-10px) scale(0.98);
    filter: blur(4px);
    pointer-events: none;
    transition:
        opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
        transform 0.5s cubic-bezier(0.4, 0, 0.2, 1),
        filter 0.4s ease;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-new {
    animation: kontakt-success-text-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.82s both;
}

.page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-new {
    opacity: 1;
    transform: none;
}

.page-kontakt-form-success-new {
    opacity: 0;
    transform: translateY(10px);
}

body:not(.admin-page) main .page-kontakt-form-success-kicker,
body:not(.admin-page) main .page-kontakt-form-success-text {
    text-align: left;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-kicker {
    animation: kontakt-success-text-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.45s both;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-text {
    animation: kontakt-success-text-in 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.58s both;
}

.page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-mark {
    animation: kontakt-success-mark-in 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
}

@keyframes kontakt-success-mark-in {
    from {
        opacity: 0;
        transform: scale(0.82);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-kicker,
.page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-text {
    opacity: 1;
    transform: none;
}

@keyframes kontakt-success-text-in {
    from {
        opacity: 0;
        transform: translateY(14px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.page-kontakt-form-wrap.is-form-success .page-kontakt-form-head {
    opacity: 0.55;
    transition: opacity 0.5s ease;
}

.page-kontakt-form-wrap:not(.is-form-success) .page-kontakt-form-head {
    opacity: 1;
}

.page-kontakt-form-global-error {
    margin: var(--spacing-sm) 0 0;
    padding: 0;
    font-size: 0.92rem;
    line-height: 1.5;
    color: #a33;
    text-align: left;
    grid-column: 1 / -1;
}

.page-kontakt-form-global-error[hidden] {
    display: none;
}

@media (prefers-reduced-motion: reduce) {
    .page-kontakt-form-stage,
    .page-kontakt-form-panel--form,
    .page-kontakt-form-panel--success,
    .page-kontakt-form-panel--form.is-exiting .page-kontakt-form-row,
    .page-kontakt-form-panel--form.is-exiting > .page-kontakt-form-field,
    .page-kontakt-form-panel--form.is-exiting .page-kontakt-form-aside,
    .page-kontakt-form-panel--form.is-exiting .page-kontakt-form-main {
        transition: none;
        animation: none;
    }

    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-burst,
    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-circle,
    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-check,
    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-kicker,
    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-text,
    .page-kontakt-form-panel--success.is-entering .page-kontakt-form-success-mark {
        animation: none;
    }

    .page-kontakt-form-panel--success,
    .page-kontakt-form-panel--success.is-entering,
    .page-kontakt-form-panel--success.is-shown {
        opacity: 1;
        transform: none;
        filter: none;
    }

    .page-kontakt-form-success-kicker,
    .page-kontakt-form-success-text,
    .page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-circle,
    .page-kontakt-form-panel--success.is-shown .page-kontakt-form-success-check {
        opacity: 1;
        transform: none;
        stroke-dashoffset: 0;
    }
}

.page-kontakt-form {
    display: grid;
    gap: var(--kontakt-text-gap);
    width: 100%;
    max-width: 100%;
    margin: 0;
    box-sizing: border-box;
}

.page-kontakt-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: var(--kontakt-inner-gap);
    align-items: stretch;
    width: 100%;
    max-width: 100%;
}

.page-kontakt-form-main {
    display: grid;
    gap: var(--kontakt-text-gap);
    min-width: 0;
}

.page-kontakt-form-aside {
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-text-gap);
    min-width: 0;
}

.page-kontakt-form-submit {
    margin-top: auto;
    padding-top: var(--kontakt-text-gap);
}

.page-kontakt-form-submit .btn-inline {
    width: 100%;
    justify-content: center;
    text-align: center;
}

.page-kontakt-form-field--message {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.page-kontakt-form-field--message textarea {
    flex: 1;
    min-height: 9.5rem;
}

.page-kontakt-form-hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.page-kontakt-form-row {
    display: grid;
    gap: var(--spacing-sm);
}

.page-kontakt-form-row--2 {
    grid-template-columns: 1fr 1fr;
}

.page-kontakt-form-field {
    display: grid;
    gap: 0.35rem;
}

.page-kontakt-form-field label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-kontakt-form-required {
    color: var(--color-accent);
}

.page-kontakt-form-optional {
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
    opacity: 0.85;
}

.page-kontakt-form-field input::placeholder,
.page-kontakt-form-field textarea::placeholder {
    color: var(--color-text-light);
    opacity: 0.75;
}

.page-kontakt-form-field input:not([type="checkbox"]),
.page-kontakt-form-field select,
.page-kontakt-form-field textarea {
    width: 100%;
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.5;
    color: var(--color-text);
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--color-border);
    border-radius: 0;
    padding: 0.55rem 0 0.65rem;
    transition: border-color 0.2s ease;
    outline: none;
    box-shadow: none;
    appearance: none;
}

.page-kontakt-form-field select {
    cursor: pointer;
    background-image: linear-gradient(45deg, transparent 50%, var(--color-text-light) 50%),
        linear-gradient(135deg, var(--color-text-light) 50%, transparent 50%);
    background-position: calc(100% - 14px) calc(50% + 2px), calc(100% - 8px) calc(50% + 2px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 1.75rem;
}

.page-kontakt-form-field textarea {
    resize: vertical;
    min-height: 8rem;
}

.page-kontakt-form-field input:not([type="checkbox"]):focus,
.page-kontakt-form-field select:focus,
.page-kontakt-form-field textarea:focus {
    outline: none;
    border-bottom-color: var(--color-accent);
    box-shadow: none;
}

.page-kontakt-form-field.is-invalid input:not([type="checkbox"]),
.page-kontakt-form-field.is-invalid select,
.page-kontakt-form-field.is-invalid textarea {
    border-bottom-color: #c45c5c;
    box-shadow: 0 2px 0 0 #c45c5c;
}

.page-kontakt-form-field.is-invalid.page-kontakt-form-field--checkbox {
    outline: 1px solid color-mix(in srgb, #c45c5c 75%, transparent);
    outline-offset: 5px;
    border-radius: 4px;
}

.page-kontakt-form-field.is-invalid.page-kontakt-form-field--checkbox input[type="checkbox"] {
    outline: 2px solid #c45c5c;
    outline-offset: 2px;
}

.page-kontakt-form-field--checkbox {
    padding: 0.15rem 0;
}

.page-kontakt-form-field--checkbox label,
.page-kontakt-form-field--checkbox .page-kontakt-form-checkbox {
    text-transform: none;
    letter-spacing: 0;
    font-family: 'Inter', sans-serif;
    font-size: 0.78rem;
    font-weight: 300;
    line-height: 1.45;
    color: var(--color-text);
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    padding: 0.3rem 0.15rem 0.3rem 0;
    margin: 0;
    cursor: pointer;
}

.page-kontakt-form-checkbox input[type="checkbox"] {
    box-sizing: border-box;
    width: 0.85rem;
    height: 0.85rem;
    min-width: 0.85rem;
    margin: 0.1rem 0 0;
    flex-shrink: 0;
    appearance: checkbox;
    -webkit-appearance: checkbox;
    accent-color: var(--color-accent);
    cursor: pointer;
    border: 1px solid color-mix(in srgb, var(--color-accent) 50%, var(--color-border));
    border-radius: 2px;
    padding: 0;
    background: var(--color-bg);
}

.page-kontakt-form-checkbox span {
    padding-top: 0.02rem;
}

@media (max-width: 768px) {
    .page-kontakt-pillars {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .page-kontakt:not(.page-design-system) {
        --kontakt-section-gap: var(--spacing-md);
        --kontakt-inner-gap: var(--spacing-sm);
        --kontakt-after-heading: 0.75rem;
    }

    .page-kontakt-intro {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
        justify-items: center;
        text-align: center;
    }

    .page-kontakt-portrait {
        grid-column: auto;
        grid-row: auto;
        width: min(68vw, 220px);
        margin: 0 auto;
    }

    .page-kontakt-lead {
        grid-column: auto;
        grid-row: auto;
        align-self: auto;
        width: 100%;
    }

    body:not(.admin-page) main .page-kontakt-intro .lead-text,
    body:not(.admin-page) main .page-kontakt-intro .lead-text p {
        text-align: center;
    }

    .page-kontakt-pillar {
        padding: var(--spacing-sm);
    }

    .page-kontakt-motto .lead-text {
        max-width: none;
        padding: 0 0.25rem;
    }

    .page-kontakt-columns {
        grid-template-columns: 1fr;
        gap: var(--kontakt-inner-gap);
    }

    .page-kontakt-col p {
        font-size: 1rem;
        line-height: 1.65;
    }

    .page-kontakt-cta-wrap .btn-inline {
        display: flex;
        width: 100%;
        justify-content: center;
        text-align: center;
        box-sizing: border-box;
    }

    .page-kontakt-cv {
        grid-template-columns: 1fr;
        gap: var(--kontakt-inner-gap);
    }

    .page-kontakt-cv-title,
    .page-kontakt-col-title,
    .page-kontakt-form-title {
        font-size: clamp(1.5rem, 6vw, 1.85rem);
    }

    .page-kontakt-cv-list li {
        grid-template-columns: 1fr;
        gap: 0.2rem;
        padding-left: 0.85rem;
    }

    .page-kontakt-cv-year {
        white-space: normal;
    }

    .page-kontakt-standort {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }

    .page-kontakt-place {
        padding: var(--spacing-sm);
    }

    .page-kontakt-place-main {
        overflow-wrap: anywhere;
    }

    .page-kontakt-form-layout {
        grid-template-columns: 1fr;
    }

    .page-kontakt-form-row--2 {
        grid-template-columns: 1fr;
    }

    .page-kontakt-form-field input:not([type="checkbox"]),
    .page-kontakt-form-field select,
    .page-kontakt-form-field textarea {
        font-size: 16px;
    }

    .page-kontakt-form-submit {
        margin-top: 0;
        padding-top: 0;
    }

    .page-kontakt-form-success-body {
        gap: var(--spacing-md);
    }

    .page-kontakt-form-success-burst {
        left: 1.25rem;
    }

    .page-kontakt-form-success-icon {
        width: 52px;
        height: 52px;
    }

    .page-ika-process-grid {
        grid-template-columns: 1fr 1fr;
    }

    .page-ika-raum-list {
        grid-template-columns: 1fr 1fr;
    }

    .page-ika-steps--full {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--kontakt-inner-gap);
    }

    .page-ika-journey-step::after {
        display: none;
    }

    .page-ika-journey-step {
        padding: 0;
    }

    .page-ika-journey-methods {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .page-ika-journey-b {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-b-aside {
        position: static;
    }

    .page-ika-journey-c-bento {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
    }

    .page-ika-journey-c-card--1,
    .page-ika-journey-c-card--2,
    .page-ika-journey-c-card--3,
    .page-ika-journey-c-card--4 {
        grid-column: 1 / -1;
        grid-row: auto;
    }

    .page-ika-journey-c-methods ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* ===== ANGEBOTSSEITEN (Körperarbeit, Yoga, Tanz, Coaching) ===== */
.page-offering--yoga {
    --offering-tint: var(--color-highlight-yoga);
    --yoga-process-photo-focus: 50% 32%;
}

.page-offering--koerperarbeit {
    --yoga-process-photo-focus: 50% 35%;
}

.page-offering .page-ika-process-formats {
    display: flex;
    flex-direction: column;
    gap: 0;
    list-style: none;
    margin: 0 0 var(--kontakt-text-gap);
    padding: 0;
}

.page-offering .page-ika-process-formats li {
    display: grid;
    grid-template-columns: minmax(6.75rem, 9.5rem) minmax(0, 1fr);
    align-items: baseline;
    column-gap: 1.25rem;
    row-gap: 0.15rem;
    margin: 0;
    padding: 0.72rem 0;
    border: none;
    border-bottom: 1px solid color-mix(in srgb, var(--color-accent) 10%, var(--color-border));
    background: transparent;
}

.page-offering .page-ika-process-formats li:first-child {
    padding-top: 0;
}

.page-offering .page-ika-process-formats li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.page-offering .page-ika-process-formats-label.type-subline {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-subline-size);
    font-weight: 400;
    line-height: var(--type-subline-line);
    letter-spacing: 0.04em;
    color: var(--color-accent);
    margin: 0;
}

.page-offering .page-ika-process-formats-detail {
    font-size: 0.96rem;
    line-height: 1.5;
    color: var(--color-text);
}

.page-offering--tanz {
    --offering-tint: var(--color-highlight-tanz);
    --yoga-process-photo-focus: 50% 38%;
}

/* Tanz: Spotify — nur Akzent-Karte (kein iframe; Spotify-UI nicht stylebar) */
.page-tanz-spotify {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-inner-gap);
}

.page-tanz-spotify-head .page-ika-section-title {
    margin-top: 0;
}

.page-tanz-spotify-lead {
    margin: 0;
    max-width: none;
    font-size: 1.02rem;
    line-height: 1.65;
}

.page-tanz-spotify-player {
    min-width: 0;
}

.page-tanz-spotify-accent-player {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    appearance: none;
    -webkit-appearance: none;
    font: inherit;
    text-align: inherit;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 16px 48px color-mix(in srgb, var(--color-accent) 14%, transparent);
    border: var(--line-weight) solid color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.page-tanz-spotify-accent-player:hover,
.page-tanz-spotify-accent-player:focus-visible {
    box-shadow: 0 20px 52px color-mix(in srgb, var(--color-accent) 22%, transparent);
    transform: translateY(-1px);
}

.page-tanz-spotify-accent-player__bar {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.85rem 1rem;
    align-items: center;
    padding: 0.85rem 1rem;
    background: var(--color-accent);
    color: var(--color-bg);
}

.page-tanz-spotify-accent-player__cover {
    display: block;
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 8px;
    object-fit: cover;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}

.page-tanz-spotify-accent-player__cover--placeholder {
    background: color-mix(in srgb, var(--color-bg) 22%, transparent);
}

.page-tanz-spotify-accent-player__meta {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.page-tanz-spotify-accent-player__label {
    margin: 0;
    color: color-mix(in srgb, var(--color-bg) 72%, transparent);
}

.page-tanz-spotify-accent-player__title {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: var(--type-subline-size);
    line-height: var(--type-subline-line);
    letter-spacing: 0.03em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.page-tanz-spotify-accent-player__cta.btn-solid {
    flex-shrink: 0;
    background: var(--color-bg);
    color: var(--color-accent);
    border-color: var(--color-bg);
}

.page-tanz-spotify-accent-player:hover .page-tanz-spotify-accent-player__cta.btn-solid,
.page-tanz-spotify-accent-player:focus-visible .page-tanz-spotify-accent-player__cta.btn-solid {
    background: color-mix(in srgb, var(--color-bg) 88%, var(--color-accent));
    color: var(--color-accent);
    border-color: color-mix(in srgb, var(--color-bg) 88%, var(--color-accent));
}

.tanz-spotify-lightbox.media-lightbox {
    background: rgba(0, 0, 0, 0.94);
}

.tanz-spotify-lightbox__frame {
    max-width: min(640px, calc(100% - 1.5rem));
    gap: 0.65rem;
    padding: 1rem 1rem 0.85rem;
    background: #000;
    border-radius: 12px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}

.tanz-spotify-lightbox__title {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    text-align: center;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.tanz-spotify-lightbox .media-lightbox__content {
    width: 100%;
    background: #000;
    border-radius: 8px;
    overflow: hidden;
}

.tanz-spotify-lightbox__iframe {
    display: block;
    width: 100%;
    min-height: 480px;
    height: min(82vh, 720px);
    border: 0;
    border-radius: 8px;
    background: #000;
}

.tanz-spotify-lightbox .media-lightbox__caption a {
    color: rgba(255, 255, 255, 0.9);
}

.page-offering--coaching {
    --offering-tint: var(--color-highlight-coaching);
}

.page-offering--koerperarbeit,
.page-kontakt.page-ika:not([class*="page-offering--"]) {
    --offering-tint: var(--color-highlight-koerperarbeit);
}

.page-kontakt.page-ika,
.page-kontakt.page-offering {
    --ika-hero-intro-gap: var(--spacing-md);
}

.page-kontakt.page-ika > .page-ika-intro,
.page-kontakt.page-offering > .page-ika-intro {
    margin-top: calc(var(--ika-hero-intro-gap) - var(--kontakt-section-gap));
}

.page-ika-hero {
    text-align: left;
}

/* .page-ika-title — Typo via .type-h1; Abstand zur Subline in .type-headline-group */
.page-ika-title {
    margin: 0 0 var(--type-headline-subline-gap);
}

.page-ika-intro {
    grid-template-columns: minmax(0, 1.65fr) minmax(220px, 0.75fr);
    gap: var(--kontakt-inner-gap);
    align-items: start;
}

.page-ika-intro--reverse {
    grid-template-columns: minmax(220px, 0.75fr) minmax(0, 1.65fr);
}

.page-ika-intro--reverse .page-ika-video {
    order: 2;
}

.page-ika-intro--reverse .page-ika-lead {
    order: 1;
}

.page-ika-visual {
    margin: 0;
}

.page-ika-visual-frame {
    margin: 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.1);
}

.page-ika-visual-frame img {
    display: block;
    width: 100%;
    aspect-ratio: 21 / 9;
    object-fit: cover;
    object-position: center 35%;
}

.page-ika-intro--reverse .page-ika-visual-frame img,
.page-offering--tanz .page-ika-visual-frame img {
    object-position: center 40%;
}

.page-offering--coaching .page-ika-intro {
    grid-template-columns: minmax(220px, 0.75fr) minmax(0, 1.65fr);
    grid-template-areas:
        "aside frame"
        ". caption";
    align-items: stretch;
    row-gap: 0.45rem;
    column-gap: var(--kontakt-inner-gap);
}

.page-offering--coaching .page-ika-intro .page-ika-video {
    display: contents;
}

.page-offering--coaching .page-ika-intro .page-ika-video-frame {
    grid-area: frame;
    align-self: start;
}

.page-offering--coaching .page-ika-intro .page-ika-video-caption {
    grid-area: caption;
    margin-top: 0.2rem;
}

.page-offering--coaching .page-ika-intro .page-ika-video-frame > img {
    object-position: center 42%;
}

.page-offering--coaching .page-ika-intro-aside {
    grid-area: aside;
    display: flex;
    flex-direction: column;
    align-self: stretch;
    min-width: 0;
    min-height: 0;
}

.page-offering--coaching .page-ika-intro-aside .page-ika-lead {
    flex: 0 1 auto;
}

.page-offering--coaching .page-ika-intro-aside .page-ika-intro-cta {
    margin: auto 0 0;
    flex-shrink: 0;
}

/* Krishnamurti-Zitat in „Raum“ — breiter als Standard-Zitat (36rem) */
.page-offering--coaching .page-ika-raum .type-quote-group--center {
    width: min(100%, 48rem);
    max-width: 48rem;
}

.page-ika-visual-caption {
    margin: 0;
    padding: 0.55rem 0.15rem 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-light);
    text-align: left;
}

.page-ika-plyr--youtube .offering-video-youtube,
.page-ika-plyr--youtube .plyr__video-embed {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.page-ika-plyr--youtube {
    position: relative;
}

.page-ika-intro .page-ika-video {
    margin: 0;
    width: 100%;
    min-width: 0;
    align-self: start;
}

.page-ika-intro-cta {
    display: flex;
    justify-content: flex-end;
    margin: 0;
    padding: 0;
    max-width: none;
    align-self: start;
}

.page-offering--koerperarbeit .page-ika-intro {
    grid-template-areas:
        "frame aside"
        "caption .";
    align-items: stretch;
    row-gap: 0.35rem;
    column-gap: var(--kontakt-inner-gap);
}

.page-offering--koerperarbeit .page-ika-intro .page-ika-video {
    display: contents;
}

.page-offering--koerperarbeit .page-ika-intro .page-ika-video-frame {
    grid-area: frame;
    align-self: start;
}

.page-offering--koerperarbeit .page-ika-intro .page-ika-video-caption {
    grid-area: caption;
    margin-top: 0.2rem;
}

/* Zeilenhöhe nur vom Video-Frame; Aside = Frame-Höhe, CTA an Unterkante */
.page-offering--koerperarbeit .page-ika-intro-aside {
    grid-area: aside;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    align-self: stretch;
    align-content: stretch;
    height: 0;
    min-height: 100%;
    overflow: visible;
    min-width: 0;
}

.page-offering--koerperarbeit .page-ika-intro-aside .page-ika-lead {
    min-height: 0;
    align-self: start;
}

.page-offering--koerperarbeit .page-ika-intro-aside .page-ika-intro-cta {
    margin: 0;
    align-self: end;
}

.page-ika-intro .page-ika-lead {
    margin: 0;
    align-self: start;
}

.page-ika-video-frame {
    aspect-ratio: 16 / 9;
    border-radius: 12px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
    background: #1a1a1a;
    overflow: hidden;
}

.page-ika-intro .page-ika-video-frame > img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.page-ika-plyr {
    --plyr-color-main: var(--color-accent);
    --plyr-video-background: #141414;
    --plyr-menu-background: color-mix(in srgb, var(--color-bg) 94%, #000);
    --plyr-menu-color: var(--color-text);
    --plyr-captions-background: color-mix(in srgb, var(--offering-tint, var(--color-accent)) 92%, #000);
    --plyr-captions-text-color: #fff;
    --plyr-font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    --plyr-font-size-time: 0.72rem;
    --plyr-font-size-badge: 0.68rem;
    --plyr-font-size-small: 0.72rem;
    --plyr-control-icon-size: 1rem;
    --plyr-control-spacing: 0.65rem;
    --plyr-control-radius: 4px;
}

.page-ika-plyr .plyr {
    border-radius: 12px;
    min-width: 0;
}

.page-ika-plyr .plyr__control--overlaid {
    background: color-mix(in srgb, var(--color-accent) 88%, #fff);
    color: var(--color-bg);
    padding: 1.1rem;
}

.page-ika-plyr .plyr__control--overlaid:hover {
    background: var(--color-accent);
}

.page-ika-plyr .plyr:not(.plyr--user-started) .plyr__controls {
    background: transparent;
    padding: 0;
}

.page-ika-plyr .plyr:not(.plyr--user-started) .plyr__controls > *:not(.plyr__control--overlaid) {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    max-height: 0;
    overflow: hidden;
}

.page-ika-plyr .plyr.plyr--user-started .plyr__controls > *:not(.plyr__control--overlaid) {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    max-height: none;
    transition: opacity 0.2s ease, visibility 0.2s ease;
}

.page-ika-plyr .plyr.plyr--user-started .plyr__controls {
    padding: 0.55rem 0.65rem 0.65rem;
    background: linear-gradient(
        transparent,
        color-mix(in srgb, #000 72%, transparent)
    );
}

/* Yoga-Modul Lightbox: Controls immer sichtbar (Autoplay kann geblockt sein) */
.yoga-im-alltag-lightbox .page-ika-plyr .plyr__controls {
    padding: 0.55rem 0.65rem 0.65rem;
    background: linear-gradient(
        transparent,
        color-mix(in srgb, #000 72%, transparent)
    );
}

.yoga-im-alltag-lightbox .page-ika-plyr .plyr__controls > *:not(.plyr__control--overlaid) {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    max-height: none;
    overflow: visible;
}

/* Galerie-Lightbox: Plyr-Controls — siehe .gallery-lightbox__plyr-host oben */

.page-ika-plyr .plyr__control {
    color: #f5f5f5;
}

.page-ika-plyr .plyr__control:hover {
    background: color-mix(in srgb, var(--color-accent) 35%, transparent);
    color: #fff;
}

.page-ika-plyr .plyr__progress__buffer {
    color: color-mix(in srgb, #fff 22%, transparent);
}

.page-ika-plyr .plyr__volume {
    max-width: 5.5rem;
}

.page-ika-plyr .plyr__captions,
.page-ika-plyr .plyr__captions .plyr__caption,
.page-ika-plyr .plyr__captions span {
    font-family: 'Inter', sans-serif !important;
    font-size: clamp(0.8rem, 1.25vw, 0.92rem) !important;
    font-weight: 450;
    line-height: 1.45;
    letter-spacing: 0.01em;
    text-align: center;
    -webkit-font-smoothing: antialiased;
}

.page-ika-plyr .plyr__captions span {
    background: color-mix(in srgb, var(--color-accent) 92%, #000);
    color: #fff;
    border-radius: 4px;
    padding: 0.22em 0.5em;
    box-decoration-break: clone;
    text-shadow: none;
}

.page-ika-plyr video::cue {
    font-family: 'Inter', sans-serif;
    font-size: clamp(0.8rem, 1.25vw, 0.92rem);
    font-weight: 450;
    line-height: 1.45;
    background: color-mix(in srgb, var(--color-accent) 92%, #000);
    color: #fff;
}

.page-ika-video-player {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    vertical-align: top;
}

.gallery-lightbox .page-ika-video-frame .page-ika-video-player {
    height: auto;
    max-height: calc(100vh - 14rem);
}

.page-ika-video-caption {
    margin: 0.55rem 0 0;
    text-align: left;
}

.page-ika-lead.site-quote {
    margin: 0;
}

/* .page-ika-section-title — Typo via .type-section */
.page-ika-section-title,
.page-ika-block-title {
    margin: 0 0 var(--kontakt-after-heading);
}

.page-ika-raum-lead,
.page-ika-einzel-lead {
    max-width: none;
    font-size: 1.02rem;
    line-height: 1.7;
}

.page-ika-raum-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(11.5rem, 1fr));
    gap: 0.55rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.page-ika-raum-list li {
    margin: 0;
    padding: 0.55rem 0.85rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 24%, var(--color-border));
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 55%, var(--color-bg));
    font-family: 'Inter', sans-serif;
    font-size: 0.88rem;
    font-weight: 400;
    line-height: 1.35;
    color: var(--color-text);
    text-align: left;
    hyphens: none;
}

.page-ika-columns .page-ika-block-title {
    font-size: clamp(1.15rem, 2vw, 1.45rem);
}

.page-ika-foundations-label {
    margin: var(--kontakt-inner-gap) 0 0.45rem;
}

.page-ika-foundations {
    margin: 0;
    padding: 0 0 0 1.1rem;
    list-style: disc;
}

.page-ika-foundations li {
    margin-bottom: 0.35rem;
    max-width: none;
}

.page-ika-background .page-ika-steps {
    gap: var(--kontakt-text-gap);
}

.page-ika-background .page-ika-steps li {
    max-width: none;
}

.page-ika-steps {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: var(--kontakt-text-gap);
}

.page-ika-steps li {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.15rem 0.75rem;
    padding: 0.85rem 0 0.85rem 1rem;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
    max-width: none;
}

.page-ika-steps--full {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--kontakt-inner-gap);
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-ika-steps--full li {
    margin: 0;
}

.page-ika-process-lead {
    margin: 0 0 var(--kontakt-inner-gap);
    max-width: none;
    font-size: 1.02rem;
    line-height: 1.7;
}

.page-ika-process-layout {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--kontakt-inner-gap);
    align-items: stretch;
}

.page-ika-process-layout--reverse .page-ika-process-body {
    order: 1;
}

.page-ika-process-layout--reverse .page-ika-process-gallery {
    order: 2;
}

.page-ika-process-gallery--with-dots {
    --process-gallery-dots-tail: calc(0.85rem + 0.55rem + 0.65rem);
}

.page-ika-process-body {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    height: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.page-ika-process-gallery--with-dots + .page-ika-process-body {
    padding-bottom: var(--process-gallery-dots-tail);
}

.page-ika-process-body > .page-ika-process-formats {
    margin-bottom: 0;
}

.page-ika-process-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.page-ika-process-list li {
    margin: 0;
    padding: 0.8rem 0 0.8rem 1rem;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    border-bottom: 1px solid color-mix(in srgb, var(--color-accent) 10%, var(--color-border));
}

.page-ika-process-list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.page-ika-process-list li:first-child {
    padding-top: 0;
}

.page-ika-process-list-label {
    display: block;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-process-list-detail {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.96rem;
    line-height: 1.5;
    color: var(--color-text);
}

.page-ika-process-note {
    grid-row: 2;
    align-self: end;
    margin: 0;
    padding-top: var(--kontakt-inner-gap);
    border-top: none;
}

.page-ika-process-note .type-body {
    margin: 0 0 var(--kontakt-text-gap);
    max-width: none;
    text-align: left;
}

.page-ika-process-note .type-body:last-of-type {
    margin-bottom: 0;
}

.page-ika-process-note-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: flex-end;
    margin: 0;
    padding: 0;
    max-width: none;
}

.page-ika-process-symbol {
    margin: 0;
    min-width: 0;
}

.page-ika-process-symbol .page-ika-visual-frame {
    aspect-ratio: 4 / 5;
    width: 100%;
    position: relative;
    overflow: hidden;
}

.page-ika-process-symbol .page-ika-visual-frame img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    aspect-ratio: auto;
    object-fit: cover;
    object-position: var(--yoga-process-photo-focus, 50% 32%);
}

.page-ika-process-symbol--placeholder .page-ika-visual-frame {
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-yoga)) 12%, var(--color-bg));
}

.page-ika-process-symbol--placeholder .page-ika-visual-frame img {
    object-fit: contain;
    object-position: center;
    padding: 2.5rem;
    opacity: 0.45;
}

.page-ika-process-symbol--placeholder .page-ika-visual-caption {
    color: var(--color-text-light);
}

.page-ika-process-gallery {
    --process-gallery-fade: 900ms;
    --process-gallery-ease: cubic-bezier(0.45, 0.05, 0.25, 1);
    margin: 0;
    min-width: 0;
}

.page-ika-process-gallery-viewport {
    position: relative;
}

.page-ika-process-gallery-slide {
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transition:
        opacity var(--process-gallery-fade) var(--process-gallery-ease),
        visibility 0s linear var(--process-gallery-fade);
}

.page-ika-process-gallery-slide:not(.is-active) {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.page-ika-process-gallery-slide.is-active {
    position: relative;
    opacity: 1;
    visibility: visible;
    transition:
        opacity var(--process-gallery-fade) var(--process-gallery-ease),
        visibility 0s linear 0s;
}

.page-ika-process-gallery .page-ika-visual-frame {
    aspect-ratio: 4 / 5;
    width: 100%;
    position: relative;
    overflow: hidden;
}

.page-ika-process-gallery .page-ika-visual-frame img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    aspect-ratio: auto;
    object-fit: cover;
    object-position: var(--yoga-process-photo-focus, 50% 32%);
}

.page-ika-process-gallery-dots {
    display: flex;
    justify-content: center;
    gap: 0.55rem;
    margin-top: 0.85rem;
}

.page-ika-process-gallery-dot {
    width: 0.55rem;
    height: 0.55rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

.page-ika-process-gallery-dot:hover,
.page-ika-process-gallery-dot:focus-visible {
    background: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    transform: scale(1.15);
}

.page-ika-process-gallery-dot.is-active {
    background: var(--color-accent);
}

@media (prefers-reduced-motion: reduce) {
    .page-ika-process-gallery-slide {
        transition: none;
    }
}

/* Körperarbeit: Layout-Labor (Varianten A–G) */
.page-ika-legacy {
    display: flex;
    flex-direction: column;
    gap: var(--kontakt-section-gap);
    margin-top: var(--kontakt-section-gap);
    padding-top: var(--kontakt-section-gap);
    border-top: 1px solid color-mix(in srgb, var(--color-accent) 12%, var(--color-border));
}

.page-ika-journey-lab {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.page-ika-journey-lab-intro {
    margin: 0;
    padding: var(--spacing-sm) var(--spacing-md);
    border-left: 3px solid var(--color-accent);
    font-size: 0.98rem;
    line-height: 1.65;
    color: var(--color-text);
    max-width: none;
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 28%, var(--color-bg));
    border-radius: 0 8px 8px 0;
}

.page-ika-journey-lab-intro strong {
    color: var(--color-accent);
    font-weight: 600;
}

.page-ika-journey-lab .page-ika-journey {
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px dashed color-mix(in srgb, var(--color-accent) 22%, var(--color-border));
}

.page-ika-journey-lab .page-ika-journey:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.page-ika-journey-variant-head {
    margin-bottom: var(--kontakt-inner-gap);
}

.page-ika-journey-variant-tag {
    display: inline-block;
    margin-bottom: 0.5rem;
    padding: 0.28rem 0.65rem;
    border-radius: 999px;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-bg);
    background: var(--color-accent);
}

.page-ika-journey--a .page-ika-journey-variant-tag {
    background: color-mix(in srgb, var(--color-accent) 88%, #000);
}

.page-ika-journey--e .page-ika-journey-variant-tag,
.page-ika-journey--f .page-ika-journey-variant-tag,
.page-ika-journey--g .page-ika-journey-variant-tag {
    color: var(--color-accent);
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 65%, var(--color-bg));
    border: 1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.page-ika-journey-variant-title {
    margin: 0 0 0.35rem;
    font-family: var(--font-h1);
    font-size: clamp(1.25rem, 2.2vw, 1.65rem);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-journey-variant-note {
    margin: 0 0 0.35rem;
    max-width: 40rem;
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--color-text);
}

.page-ika-journey-variant-inspire {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--color-text-light);
    max-width: 42rem;
}

.page-ika-journey-variant-inspire-label {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-right: 0.35rem;
}

/* Körperarbeit: „Gemeinsam im Prozess“ (Produktiv-Section) */
.page-ika-journey .type-section-body {
    display: flex;
    flex-direction: column;
    gap: var(--type-section-body-gap);
}

.page-ika-journey-lead {
    margin: 0;
    max-width: 52rem;
}

.page-ika-journey-panel {
    padding: var(--kontakt-inner-gap) var(--spacing-md);
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 22%, var(--color-border));
    background: linear-gradient(
        165deg,
        color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 38%, var(--color-bg)) 0%,
        var(--color-bg) 55%
    );
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.05);
}

.page-ika-journey-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    counter-reset: ika-journey;
}

.page-ika-journey-step {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin: 0;
    padding: 0 1rem 0 0;
    max-width: none;
}

.page-ika-journey-step:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 1.15rem;
    left: calc(2.15rem + 0.35rem);
    right: -0.35rem;
    height: 2px;
    background: linear-gradient(
        90deg,
        color-mix(in srgb, var(--color-accent) 55%, var(--color-border)),
        color-mix(in srgb, var(--color-accent) 18%, var(--color-border))
    );
    pointer-events: none;
}

.page-ika-journey-step-num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    margin-bottom: 0.65rem;
    border-radius: 50%;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    color: var(--color-bg);
    background: var(--color-accent);
    flex-shrink: 0;
}

.page-ika-journey-step-body {
    min-width: 0;
    padding-right: 0.5rem;
}

.page-ika-journey-step-title {
    margin: 0 0 0.35rem;
    font-family: var(--font-serif);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-step-text {
    margin: 0;
    font-size: 0.94rem;
    line-height: 1.6;
    color: var(--color-text);
    max-width: none;
}

.page-ika-journey-bridge {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin: var(--kontakt-inner-gap) 0;
}

.page-ika-journey-bridge-line {
    flex: 1;
    height: 1px;
    background: color-mix(in srgb, var(--color-accent) 28%, var(--color-border));
}

.page-ika-journey-bridge-label {
    flex-shrink: 0;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-journey-methods {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-ika-journey-method {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    margin: 0;
    padding: 0.75rem 0.85rem;
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-bg) 88%, var(--color-accent));
    border: 1px solid color-mix(in srgb, var(--color-accent) 14%, var(--color-border));
    max-width: none;
}

.page-ika-journey-method-label {
    font-family: var(--font-h1);
    font-size: 1.05rem;
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-journey-method-detail {
    font-family: 'Inter', sans-serif;
    font-size: 0.86rem;
    font-weight: 300;
    line-height: 1.45;
    color: var(--color-text-light);
}

/* Variation B — vertikale Editorial-Timeline + Seitenleiste */
.page-ika-journey-b {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.65fr);
    gap: var(--spacing-lg);
    align-items: start;
}

.page-ika-journey-b-timeline {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.page-ika-journey-b-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    margin: 0;
    max-width: none;
}

.page-ika-journey-b-rail {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 2.5rem;
    flex-shrink: 0;
}

.page-ika-journey-b-dot {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 50%;
    border: 2px solid var(--color-accent);
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--color-accent);
    background: var(--color-bg);
    flex-shrink: 0;
}

.page-ika-journey-b-stem {
    flex: 1;
    width: 2px;
    min-height: 1.5rem;
    margin: 0.35rem 0;
    background: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}

.page-ika-journey-b-content {
    padding: 0.15rem 0 1.35rem;
    min-width: 0;
}

.page-ika-journey-b-title {
    margin: 0 0 0.3rem;
    font-family: var(--font-serif);
    font-size: 1.12rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-b-text {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.65;
    max-width: none;
}

.page-ika-journey-b-aside {
    position: sticky;
    top: 1rem;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 45%, var(--color-bg));
}

.page-ika-journey-b-aside-kicker {
    margin: 0 0 0.75rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-journey-b-methods {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.page-ika-journey-b-methods li {
    margin: 0;
    padding: 0.55rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-accent) 12%, var(--color-border));
    max-width: none;
}

.page-ika-journey-b-methods li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.page-ika-journey-b-methods strong {
    display: block;
    font-family: var(--font-h1);
    font-size: 0.95rem;
    font-weight: 400;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 0.15rem;
}

.page-ika-journey-b-methods span {
    font-size: 0.86rem;
    line-height: 1.45;
    color: var(--color-text-light);
}

/* Variation C — Bento-Mosaik */
.page-ika-journey-c-bento {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-auto-rows: minmax(7.5rem, auto);
    gap: 0.75rem;
}

.page-ika-journey-c-card {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    margin: 0;
    padding: 1rem 1.1rem;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 16%, var(--color-border));
    background: var(--color-bg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
    min-width: 0;
}

.page-ika-journey-c-card--1 {
    grid-column: span 7;
    grid-row: span 2;
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 55%, var(--color-bg)),
        var(--color-bg)
    );
}

.page-ika-journey-c-card--2 {
    grid-column: span 5;
}

.page-ika-journey-c-card--3 {
    grid-column: span 5;
}

.page-ika-journey-c-card--4 {
    grid-column: span 7;
}

.page-ika-journey-c-index {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    color: var(--color-text-light);
    margin-bottom: 0.35rem;
}

.page-ika-journey-c-title {
    margin: 0 0 0.35rem;
    font-family: var(--font-serif);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-c-card--1 .page-ika-journey-c-title {
    font-size: 1.28rem;
}

.page-ika-journey-c-text {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: none;
}

.page-ika-journey-c-methods {
    grid-column: 1 / -1;
    padding: 1rem 1.15rem;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 20%, var(--color-border));
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
}

.page-ika-journey-c-methods-kicker {
    margin: 0 0 0.65rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-journey-c-methods ul {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-ika-journey-c-methods li {
    margin: 0;
    max-width: none;
}

.page-ika-journey-c-method-label {
    display: block;
    font-family: var(--font-h1);
    font-size: 0.92rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-journey-c-method-detail {
    font-size: 0.84rem;
    color: var(--color-text-light);
}

/* Variation D — horizontal scroll + Tags */
.page-ika-journey-d-scroll-wrap {
    overflow-x: auto;
    overflow-y: hidden;
    margin: 0 calc(-1 * var(--spacing-md));
    padding: 0.25rem var(--spacing-md) 0.75rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border)) transparent;
}

.page-ika-journey-d-track {
    display: flex;
    gap: 0.85rem;
    margin: 0;
    padding: 0 0.15rem;
    list-style: none;
    width: max-content;
    min-width: 100%;
}

.page-ika-journey-d-card {
    flex: 0 0 min(78vw, 19rem);
    scroll-snap-align: start;
    margin: 0;
    padding: 1.15rem 1.2rem 1.25rem;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 42%, var(--color-bg)) 0%,
        var(--color-bg) 100%
    );
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
    max-width: none;
}

.page-ika-journey-d-phase {
    display: block;
    margin-bottom: 0.45rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-journey-d-title {
    margin: 0 0 0.4rem;
    font-family: var(--font-serif);
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-d-text {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.6;
    max-width: none;
}

.page-ika-journey-d-hint {
    margin: 0.15rem 0 var(--spacing-sm);
    text-align: center;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    color: var(--color-text-light);
}

@media (min-width: 901px) {
    .page-ika-journey-d-hint {
        display: none;
    }
}

.page-ika-journey-d-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-ika-journey-d-tags li {
    display: inline-flex;
    flex-direction: column;
    gap: 0.1rem;
    margin: 0;
    padding: 0.5rem 0.75rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 22%, var(--color-border));
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 50%, var(--color-bg));
    max-width: none;
}

.page-ika-journey-d-tag-label {
    font-family: var(--font-h1);
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-accent);
    line-height: 1.2;
}

.page-ika-journey-d-tag-detail {
    font-size: 0.72rem;
    color: var(--color-text-light);
    line-height: 1.3;
}

/* Variation E — editorial split + method strip */
.page-ika-journey-e-split {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: var(--spacing-lg);
    align-items: start;
}

.page-ika-journey-e-visual {
    position: sticky;
    top: 1.25rem;
    margin: 0;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08);
}

.page-ika-journey-e-visual img {
    display: block;
    width: 100%;
    height: auto;
    min-height: 22rem;
    max-height: 34rem;
    object-fit: cover;
    aspect-ratio: 4 / 5;
}

.page-ika-journey-e-visual-cap {
    margin: 0;
    padding: 0.65rem 0.85rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text-light);
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 55%, var(--color-bg));
    border-top: 1px solid color-mix(in srgb, var(--color-accent) 15%, var(--color-border));
}

.page-ika-journey-e-lead {
    margin: 0 0 var(--spacing-sm);
    font-size: 1rem;
    line-height: 1.65;
    max-width: none;
}

.page-ika-journey-e-steps {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.page-ika-journey-e-step {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding-bottom: 0.85rem;
    border-bottom: 1px dashed color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
}

.page-ika-journey-e-step:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.page-ika-journey-e-thumb {
    flex-shrink: 0;
    width: 4.5rem;
    height: 4.5rem;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid color-mix(in srgb, var(--color-accent) 20%, var(--color-border));
}

.page-ika-journey-e-step-num {
    display: block;
    margin-bottom: 0.2rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.65rem;
    letter-spacing: 0.12em;
    color: var(--color-text-light);
}

.page-ika-journey-e-step-title {
    margin: 0 0 0.25rem;
    font-family: var(--font-serif);
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-e-step-text {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: none;
}

.page-ika-journey-e-methods {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin: var(--spacing-md) 0 0;
    padding: 0;
    list-style: none;
}

.page-ika-journey-e-method {
    margin: 0;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    background: var(--color-bg);
    max-width: none;
}

.page-ika-journey-e-method img {
    display: block;
    width: 100%;
    height: 4.5rem;
    object-fit: cover;
}

.page-ika-journey-e-method-text {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.55rem 0.65rem 0.7rem;
}

.page-ika-journey-e-method-text strong {
    font-family: var(--font-h1);
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 400;
}

.page-ika-journey-e-method-text span {
    font-size: 0.78rem;
    line-height: 1.4;
    color: var(--color-text-light);
}

/* Variation F — image cards 2×2 */
.page-ika-journey-f-lead {
    margin: 0 0 var(--spacing-sm);
    font-size: 1rem;
    line-height: 1.65;
    max-width: none;
}

.page-ika-journey-f-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--spacing-sm);
}

.page-ika-journey-f-card {
    margin: 0;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    background: var(--color-bg);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.05);
}

.page-ika-journey-f-media {
    position: relative;
    margin: 0;
}

.page-ika-journey-f-media img {
    display: block;
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.page-ika-journey-f-badge {
    position: absolute;
    top: 0.65rem;
    left: 0.65rem;
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    color: var(--color-bg);
    background: color-mix(in srgb, var(--color-accent) 88%, #000);
}

.page-ika-journey-f-body {
    padding: 0.85rem 1rem 1.1rem;
}

.page-ika-journey-f-title {
    margin: 0 0 0.35rem;
    font-family: var(--font-serif);
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--color-accent);
}

.page-ika-journey-f-text {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: none;
}

.page-ika-journey-f-methods {
    margin-top: var(--spacing-md);
    padding: 1rem 1.15rem;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--color-accent) 20%, var(--color-border));
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 45%, var(--color-bg));
}

.page-ika-journey-f-methods-kicker {
    margin: 0 0 0.6rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-journey-f-methods-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.page-ika-journey-f-methods-list li {
    margin: 0;
    max-width: none;
}

.page-ika-journey-f-methods-list strong {
    display: block;
    font-family: var(--font-h1);
    font-size: 0.88rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 400;
}

.page-ika-journey-f-methods-list span {
    font-size: 0.84rem;
    color: var(--color-text-light);
    line-height: 1.45;
}

/* Variation G — zigzag storytelling */
.page-ika-journey-g-lead {
    margin: 0 0 var(--spacing-md);
    font-size: 1rem;
    line-height: 1.65;
    max-width: none;
}

.page-ika-journey-g-story {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.page-ika-journey-g-row {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: var(--spacing-md);
    align-items: center;
}

.page-ika-journey-g-row--reverse .page-ika-journey-g-media {
    order: 2;
}

.page-ika-journey-g-row--reverse .page-ika-journey-g-copy {
    order: 1;
}

.page-ika-journey-g-media {
    margin: 0;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.07);
}

.page-ika-journey-g-media img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.page-ika-journey-g-num {
    display: block;
    margin-bottom: 0.35rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    color: var(--color-text-light);
}

.page-ika-journey-g-title {
    margin: 0 0 0.4rem;
    font-family: var(--font-serif);
    font-size: clamp(1.15rem, 2vw, 1.35rem);
    font-weight: 500;
    line-height: 1.25;
    color: var(--color-accent);
}

.page-ika-journey-g-text {
    margin: 0;
    font-size: 0.94rem;
    line-height: 1.6;
    max-width: none;
}

.page-ika-journey-g-methods {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--spacing-sm);
    margin: var(--spacing-lg) 0 0;
    padding: var(--spacing-sm) 0 0;
    list-style: none;
    border-top: 1px solid color-mix(in srgb, var(--color-accent) 20%, var(--color-border));
}

.page-ika-journey-g-method {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.35rem;
    margin: 0;
    max-width: none;
}

.page-ika-journey-g-method-photo {
    display: block;
    width: 4.25rem;
    height: 4.25rem;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid color-mix(in srgb, var(--color-accent) 30%, var(--color-border));
}

.page-ika-journey-g-method-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.page-ika-journey-g-method-label {
    font-family: var(--font-h1);
    font-size: 0.85rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-journey-g-method-detail {
    font-size: 0.8rem;
    line-height: 1.45;
    color: var(--color-text-light);
}

.page-ika-faq-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 3fr);
    gap: var(--spacing-xl);
    align-items: start;
}

.page-ika-faq-intro .page-ika-section-title {
    margin-top: 0;
}

.page-ika-faq-lead {
    margin: 0;
    max-width: none;
    font-size: 1.02rem;
    line-height: 1.7;
}

.page-ika-faq-lead + .page-ika-faq-lead {
    margin-top: 0.75rem;
}

.page-ika-faq-toggles {
    min-width: 0;
}

.page-ika-faq-columns {
    display: flex;
    flex-direction: column;
    gap: var(--accordion-gap);
    align-items: stretch;
}

.page-ika-faq-col {
    display: contents;
}

.page-ika-faq-item {
    border: var(--line-weight) solid var(--accordion-border);
    border-radius: var(--accordion-radius, 16px);
    background: transparent;
    overflow: hidden;
    transition: border-color var(--accordion-ease);
}

.page-ika-faq-item.is-accordion-open {
    border-color: var(--color-accent);
}

.page-ika-faq-a p {
    margin: 0;
    max-width: none;
}

/* FAQ-Übersicht (/faq) — gruppiert nach Angebot */
.page-faq-overview-intro {
    margin-bottom: var(--spacing-lg);
    max-width: var(--layout-content-max);
}

.page-faq-overview-cta {
    margin: var(--spacing-sm) 0 0;
}

.page-faq-group {
    margin-bottom: var(--spacing-xl);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.page-faq-group:last-of-type {
    border-bottom: none;
    padding-bottom: 0;
}

.page-faq-group-header .page-ika-section-title {
    margin-bottom: var(--spacing-md);
}

.page-faq-group-toggles {
    max-width: var(--layout-content-max);
}

.page-faq-group-more {
    margin: var(--spacing-md) 0 0;
}

.page-ika-closing {
    margin: 0;
    padding: var(--kontakt-text-gap) 0 0;
    border-top: 1px solid var(--color-border);
    text-align: left;
}

.page-ika-closing .lead-text {
    margin: 0;
    max-width: none;
}

.page-ika-closing .lead-text p {
    font-style: italic;
    color: var(--color-text);
}

.page-ika-closing .site-quote__attrib {
    margin-top: 0.65rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

body:not(.admin-page) main .page-ika-closing .lead-text,
body:not(.admin-page) main .page-ika-closing .lead-text p,
body:not(.admin-page) main .page-ika-closing .site-quote__attrib {
    text-align: left;
    hyphens: none;
}

.page-ika-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--kontakt-text-gap) var(--spacing-md);
    padding-top: var(--kontakt-text-gap);
    border-top: 1px solid var(--color-border);
}

.page-ika-footer-text {
    margin: 0;
    flex: 1 1 16rem;
    font-size: 0.98rem;
    line-height: 1.55;
    color: var(--color-text-light);
    max-width: none;
}

.page-ika-step-title {
    grid-column: 1 / -1;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.page-ika-step-text {
    grid-column: 1 / -1;
    font-size: 0.96rem;
    line-height: 1.6;
    color: var(--color-text);
}

.page-ika-pullquote {
    margin: var(--kontakt-inner-gap) 0 0;
    padding: var(--kontakt-text-gap) 0 0;
    border-top: 1px solid var(--color-border);
}

.page-ika-pullquote .lead-text p {
    font-style: italic;
    color: var(--color-accent);
}

.page-ika-motto {
    padding: var(--kontakt-text-gap) 0;
}

.page-ika-elements {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    margin: var(--kontakt-text-gap) 0;
    padding: 0;
}

.page-ika-elements li {
    margin: 0;
}

.page-ika-elements a,
.page-ika-elements span {
    display: inline-block;
    padding: 0.45rem 0.9rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--color-text);
    background: var(--color-bg);
    transition: border-color 0.2s ease, color 0.2s ease;
}

.page-ika-elements a:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.page-ika-elements span {
    border-top-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
    background: color-mix(in srgb, var(--offering-tint, var(--color-highlight-koerperarbeit)) 40%, var(--color-bg));
}

.page-ika-process-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--kontakt-text-gap);
}

.page-ika-process-item {
    padding: var(--kontakt-text-gap) var(--spacing-sm);
    border: 1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-border));
    border-top: 3px solid var(--color-highlight-koerperarbeit);
    border-radius: 6px;
    background: var(--color-bg);
    text-align: left;
}

.page-ika-process-label {
    display: block;
    font-family: var(--font-h1);
    font-size: 1.05rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 0.35rem;
}

.page-ika-process-detail {
    display: block;
    font-size: 0.9rem;
    line-height: 1.45;
    color: var(--color-text-light);
}

.page-ika-package-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--kontakt-inner-gap);
    margin-top: var(--kontakt-text-gap);
}

.page-ika-package {
    padding: var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: var(--color-bg);
}

.page-ika-package--yin {
    border-top: 3px solid color-mix(in srgb, var(--color-highlight-yoga) 80%, var(--color-accent));
}

.page-ika-package--deep {
    border-top: 3px solid color-mix(in srgb, var(--color-highlight-koerperarbeit) 90%, var(--color-accent));
}

.page-ika-package-title {
    margin: 0 0 var(--kontakt-after-heading);
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-text);
}

.page-ika-package-for {
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--color-text-light);
}

.page-ika-benefits {
    margin: var(--kontakt-text-gap) 0;
    padding-left: 1.15rem;
}

.page-ika-benefits li {
    margin-bottom: 0.35rem;
    max-width: none;
    font-size: 0.94rem;
    line-height: 1.5;
}

.page-ika-package-meta {
    margin-top: var(--kontakt-text-gap);
    padding-top: var(--kontakt-text-gap);
    border-top: 1px dashed var(--color-border);
}

.page-ika-package-meta p {
    max-width: none;
    font-size: 0.92rem;
    line-height: 1.5;
}

.page-ika-price {
    margin-top: 0.5rem;
    font-size: 1rem;
}

.page-ika-price-note {
    display: block;
    margin-top: 0.2rem;
    font-size: 0.82rem;
    color: var(--color-text-light);
    font-weight: 300;
}

.page-ika-prep {
    margin-top: var(--kontakt-inner-gap);
    padding: var(--spacing-sm) var(--spacing-md);
    border-left: 3px solid var(--color-accent);
    background: color-mix(in srgb, var(--color-highlight-koerperarbeit) 35%, var(--color-bg));
}

.page-ika-prep-title {
    margin: 0 0 0.5rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

.page-ika-prep-list {
    margin: 0;
    padding-left: 1.1rem;
}

.page-ika-prep-list li {
    max-width: none;
}

.page-ika-facts .page-kontakt-standort {
    grid-template-columns: 1fr;
}

.page-ika-contact-lines {
    margin: 0.5rem 0 0;
    font-size: 0.9rem;
    line-height: 1.6;
    max-width: none;
}

.page-ika-contact-lines a {
    text-decoration-color: var(--color-accent);
}

.page-ika-contact-sep {
    margin: 0 0.25rem;
    color: var(--color-text-light);
}

.page-ika-cta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--kontakt-text-gap) var(--spacing-md);
    margin-top: var(--kontakt-inner-gap);
}

.page-ika-cta-text {
    margin: 0;
    flex: 1 1 100%;
    font-family: var(--font-serif);
    font-size: 1.1rem;
    line-height: 1.5;
    max-width: none;
}

.page-ika-cta-secondary {
    opacity: 0.92;
}

body:not(.admin-page) main .page-ika p,
body:not(.admin-page) main .page-ika li {
    text-align: left;
    hyphens: none;
    -webkit-hyphens: none;
}

@media (max-width: 900px) {
    .page-ika-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    /* —— Angebotsseiten: Einspaltig (schlägt Desktop-Grid-Areas & Speziallayouts) —— */
    .page-kontakt.page-offering .page-kontakt-intro.page-ika-intro,
    .page-kontakt.page-offering .page-ika-intro.page-ika-intro--reverse {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas: none;
        row-gap: var(--spacing-md);
    }

    .page-kontakt.page-offering .page-ika-intro .page-ika-video {
        display: block;
        order: 1;
        width: 100%;
    }

    .page-kontakt.page-offering .page-ika-intro .page-ika-video-frame,
    .page-kontakt.page-offering .page-ika-intro .page-ika-video-caption {
        grid-area: auto;
    }

    .page-kontakt.page-offering .page-ika-intro .page-ika-lead,
    .page-kontakt.page-offering .page-ika-intro-aside {
        order: 2;
        grid-area: auto;
    }

    .page-kontakt.page-offering .page-ika-intro-aside {
        display: flex;
        flex-direction: column;
        height: auto;
        min-height: 0;
        grid-template-rows: none;
    }

    .page-kontakt.page-offering .page-ika-intro-aside .page-ika-intro-cta {
        justify-content: center;
        margin: var(--spacing-sm) 0 0;
    }

    .page-kontakt.page-offering .page-ika-process-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .page-kontakt.page-offering .page-ika-faq-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .page-kontakt.page-offering .page-kontakt-columns {
        grid-template-columns: minmax(0, 1fr);
    }

    .page-kontakt.page-offering .page-ika-process-formats li {
        grid-template-columns: minmax(0, 1fr);
        align-items: start;
        row-gap: 0.25rem;
    }

    .page-ika-process-layout {
        grid-template-columns: 1fr;
    }

    /* Galerie vor Text — auch bei --reverse (Referenz Yoga) */
    .page-ika-process-layout--reverse .page-ika-process-body,
    .page-ika-process-layout--reverse .page-ika-process-gallery {
        order: unset;
    }

    .page-ika-process-body {
        height: auto;
        grid-template-rows: auto;
    }

    .page-ika-faq-layout {
        grid-template-columns: 1fr;
    }

    .page-tanz-spotify-accent-player__bar {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .page-tanz-spotify-accent-player__cta {
        grid-column: 1 / -1;
        justify-self: start;
    }

    .page-ika-visual-frame img {
        aspect-ratio: 16 / 10;
    }

    .page-ika-process-symbol .page-ika-visual-frame {
        aspect-ratio: 4 / 5;
    }

    .page-ika-process-symbol .page-ika-visual-frame img {
        aspect-ratio: auto;
        object-position: var(--yoga-process-photo-focus, 50% 32%);
    }

    .page-ika-process-grid {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-panel {
        padding: var(--spacing-sm);
    }

    .page-ika-journey-flow {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }

    .page-ika-journey-step {
        flex-direction: row;
        gap: 0.85rem;
        padding: 0 0 0 0.15rem;
        border-left: 2px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
        padding-left: 0.85rem;
    }

    .page-ika-journey-step-num {
        margin-bottom: 0;
    }

    .page-ika-journey-methods {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-c-methods ul {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-d-card {
        flex-basis: min(88vw, 17rem);
    }

    .page-ika-journey-e-split {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-e-visual {
        position: static;
    }

    .page-ika-journey-e-visual img {
        max-height: 20rem;
        aspect-ratio: 16 / 10;
    }

    .page-ika-journey-e-methods {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .page-ika-journey-f-grid {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-f-methods-list {
        grid-template-columns: 1fr 1fr;
    }

    .page-ika-journey-g-row,
    .page-ika-journey-g-row--reverse {
        grid-template-columns: 1fr;
    }

    .page-ika-journey-g-row--reverse .page-ika-journey-g-media,
    .page-ika-journey-g-row--reverse .page-ika-journey-g-copy {
        order: unset;
    }

    .page-ika-journey-g-methods {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--spacing-sm);
    }

    .page-ika-raum-list {
        grid-template-columns: 1fr;
    }

    .page-ika-footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .page-ika-footer .btn-inline {
        width: 100%;
        justify-content: center;
    }
}

/* —— Yoga Online-Modul —— */
.page-yoga-im-alltag {
    --yoga-im-alltag-gap: clamp(1.5rem, 3vw, 2.5rem);
    --yoga-im-alltag-stack-gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.page-yoga-im-alltag-intro {
    max-width: none;
    margin: 0 0 var(--yoga-im-alltag-stack-gap);
}

.page-yoga-im-alltag-intro.page-ika-lead.site-quote {
    margin: 0 0 var(--yoga-im-alltag-stack-gap);
}

.yoga-im-alltag-intro-main {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.yoga-im-alltag-intro-actions {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    max-height: 12rem;
    overflow: hidden;
    padding-top: var(--yoga-im-alltag-stack-gap);
    transition:
        max-height 0.52s cubic-bezier(0.22, 1, 0.36, 1),
        padding-top 0.52s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.42s ease,
        transform 0.52s cubic-bezier(0.22, 1, 0.36, 1);
}

.yoga-im-alltag-intro-actions.is-intro-actions-exit {
    max-height: 0;
    padding-top: 0;
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
}

.yoga-im-alltag-intro-actions[hidden] {
    display: none !important;
}

.yoga-im-alltag-intro-actions__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: stretch;
}

.yoga-im-alltag-intro-swap {
    position: relative;
    display: grid;
    grid-template: 1fr / 1fr;
    align-items: start;
    min-width: 0;
    overflow: hidden;
}

.yoga-im-alltag-intro-swap.is-welcome-swap-active {
    height: var(--welcome-swap-from);
    min-height: var(--welcome-swap-from);
    transition:
        height 0.36s cubic-bezier(0.22, 1, 0.36, 1),
        min-height 0.36s cubic-bezier(0.22, 1, 0.36, 1);
}

.yoga-im-alltag-intro-swap.is-welcome-swap-to-target {
    height: var(--welcome-swap-to);
    min-height: var(--welcome-swap-to);
}

.yoga-im-alltag-intro-swap.is-welcome-height-locked {
    height: auto;
    min-height: var(--welcome-swap-lock);
}

.yoga-im-alltag-intro-swap__original,
.yoga-im-alltag-intro-swap__welcome {
    grid-area: 1 / 1;
    min-width: 0;
    transition:
        opacity 0.32s ease,
        transform 0.36s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0.32s;
}

.yoga-im-alltag-intro-swap__original {
    margin: 0;
}

.yoga-im-alltag-intro-swap__welcome {
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    pointer-events: none;
}

.yoga-im-alltag-intro-swap__welcome[hidden] {
    display: none !important;
}

.page-yoga-im-alltag.is-welcome-sequencing .yoga-im-alltag-intro-swap__original.is-welcome-original-exit,
.page-yoga-im-alltag.is-yoga-im-alltag-unlocked .yoga-im-alltag-intro-swap__original {
    position: absolute;
    width: 100%;
    inset: 0 auto auto 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    pointer-events: none;
}

.page-yoga-im-alltag.is-welcome-sequencing .yoga-im-alltag-intro-swap__welcome,
.page-yoga-im-alltag.is-yoga-im-alltag-unlocked .yoga-im-alltag-intro-swap__welcome {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.yoga-im-alltag-welcome {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.yoga-im-alltag-welcome.is-welcome-placeholder .yoga-im-alltag-welcome-type:empty {
    min-height: 1.5em;
}

.yoga-im-alltag-welcome-type,
[data-yoga-im-alltag-subline] {
    position: relative;
}

.yoga-im-alltag-welcome-type {
    margin: 0;
}

.yoga-im-alltag-type-ghost {
    visibility: hidden;
    display: block;
}

.yoga-im-alltag-type-visible {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}

.yoga-im-alltag-welcome-zip.is-welcome-zip-reserved {
    visibility: hidden;
}

.yoga-im-alltag-welcome-zip.is-welcome-zip-reveal {
    animation: yoga-im-alltag-welcome-zip-in 0.75s ease forwards;
}

@keyframes yoga-im-alltag-welcome-zip-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.yoga-im-alltag-type-visible.is-typing::after,
[data-yoga-im-alltag-subline] .yoga-im-alltag-type-visible.is-typing::after {
    content: '';
    display: inline-block;
    width: 2px;
    height: 0.88em;
    margin-left: 1px;
    vertical-align: -0.08em;
    background: var(--color-accent);
    animation: yoga-im-alltag-welcome-cursor 0.85s step-end infinite;
}

@keyframes yoga-im-alltag-welcome-cursor {
    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0;
    }
}

.yoga-im-alltag-welcome-zip {
    margin: 0;
}

.yoga-im-alltag-welcome-zip-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.yoga-im-alltag-unlock-form {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    min-width: 0;
    max-width: none;
    margin-top: 0.35rem;
}

.yoga-im-alltag-purchase {
    margin: 0;
    min-width: 0;
}

.yoga-im-alltag-price {
    color: var(--color-accent);
    font-family: inherit;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.yoga-im-alltag-order-btn,
.yoga-im-alltag-login-btn {
    font-size: clamp(0.82rem, 1.05vw, 0.92rem);
    padding: 1rem 1.85rem;
    min-height: 2.85rem;
    letter-spacing: 0.07em;
    align-items: center;
    justify-content: center;
}

.page-yoga-im-alltag.is-unlock-sequence .yoga-im-alltag-intro-actions,
.page-yoga-im-alltag.is-unlocking .yoga-im-alltag-intro-actions,
.page-yoga-im-alltag.is-yoga-im-alltag-unlocked .yoga-im-alltag-intro-actions {
    display: none;
}

.yoga-im-alltag-login-modal .contact-form-modal__dialog {
    width: min(100%, 28rem);
}

.yoga-im-alltag-login-modal .yoga-im-alltag-unlock-row {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
}

.yoga-im-alltag-login-modal .yoga-im-alltag-unlock-row input[type='password'] {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
    height: auto;
    min-height: 0;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.yoga-im-alltag-login-modal .yoga-im-alltag-unlock-btn {
    width: auto;
    flex-shrink: 0;
    align-self: stretch;
}

.yoga-im-alltag-audio-zip-btn__icon {
    display: block;
    flex-shrink: 0;
}

.yoga-im-alltag-audio-zip-btn--pending {
    pointer-events: none;
    cursor: default;
}

.yoga-im-alltag-audio-modal .contact-form-modal__dialog {
    width: min(100%, 26rem);
}

.yoga-im-alltag-audio-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
}

.yoga-im-alltag-audio-list__item {
    border-bottom: 1px solid var(--color-border);
}

.yoga-im-alltag-audio-list__item:last-child {
    border-bottom: 0;
}

.yoga-im-alltag-audio-list__item--zip {
    background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
}

.yoga-im-alltag-audio-list__item--zip.is-generating {
    animation: yoga-im-alltag-zip-pulse 1.35s ease-in-out infinite;
}

.yoga-im-alltag-audio-list__item--zip.is-generating .yoga-im-alltag-audio-list__link {
    pointer-events: none;
    cursor: wait;
}

.yoga-im-alltag-audio-list__item--zip.is-generating-error {
    background: color-mix(in srgb, #c44 14%, var(--color-bg));
}

@keyframes yoga-im-alltag-zip-pulse {
    0%,
    100% {
        background: color-mix(in srgb, var(--color-accent) 8%, var(--color-bg));
    }

    50% {
        background: color-mix(in srgb, var(--color-accent) 26%, var(--color-bg));
    }
}

.yoga-im-alltag-audio-list__link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    width: 100%;
    padding: 0.7rem 0.9rem;
    border: 0;
    background: transparent;
    text-decoration: none;
    color: var(--color-text);
    font: inherit;
    text-align: left;
    cursor: pointer;
    transition: background 0.15s ease;
    box-sizing: border-box;
}

a.yoga-im-alltag-audio-list__link:hover,
a.yoga-im-alltag-audio-list__link:focus-visible {
    background: color-mix(in srgb, var(--color-accent) 12%, var(--color-bg));
    outline: none;
}

.yoga-im-alltag-audio-list__label {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 0.92rem;
    line-height: 1.3;
}

.yoga-im-alltag-audio-list__meta {
    flex-shrink: 0;
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.68rem;
}

.yoga-im-alltag-audio-list__icon {
    display: block;
    flex-shrink: 0;
    color: var(--color-accent);
}

.yoga-im-alltag-audio-list__item.is-pending .yoga-im-alltag-audio-list__link {
    opacity: 0.42;
    cursor: default;
    pointer-events: none;
}

.yoga-im-alltag-access.is-highlight .yoga-im-alltag-intro-actions__buttons {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 55%, transparent);
    outline-offset: 4px;
    border-radius: 8px;
}

.yoga-im-alltag-unlock-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
    width: 100%;
}

.yoga-im-alltag-unlock-row input[type='password'] {
    flex: 1 1 10rem;
    min-width: 0;
    padding: 0.5rem 0.65rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.85rem;
    line-height: 1.35;
    background: var(--color-bg);
    color: var(--color-text);
    box-sizing: border-box;
}

.yoga-im-alltag-unlock-row input[type='password']:focus {
    outline: 2px solid color-mix(in srgb, var(--color-accent) 55%, transparent);
    outline-offset: 1px;
}

.yoga-im-alltag-unlock-btn {
    flex: 0 0 auto;
    padding: 0.5rem 0.85rem;
}

.yoga-im-alltag-unlock-error {
    margin: 0;
    font-size: 0.82rem;
    color: #c0392b;
}

.yoga-im-alltag-access-note {
    margin: 0;
    padding-top: var(--yoga-im-alltag-stack-gap);
    color: var(--color-text-light);
}

.yoga-im-alltag-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--yoga-im-alltag-gap) var(--spacing-xl);
    align-items: start;
}

.yoga-im-alltag-grid.is-grid-slide-active {
    transition: transform 0.52s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

.yoga-im-alltag-item {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    min-width: 0;
}

.yoga-im-alltag-copy {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.page-yoga-im-alltag:not(.is-yoga-im-alltag-unlocked) .yoga-im-alltag-item--locked .yoga-im-alltag-copy {
    opacity: 0.52;
    transition: opacity 0.55s ease;
}

.page-yoga-im-alltag.is-yoga-im-alltag-unlocked .yoga-im-alltag-item--locked .yoga-im-alltag-copy,
.yoga-im-alltag-item--locked.is-copy-lit .yoga-im-alltag-copy {
    opacity: 1;
}

.yoga-im-alltag-video-wrap {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: 12px;
    overflow: hidden;
    background: #141414;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
    transition:
        filter 0.85s ease,
        opacity 0.85s ease,
        box-shadow 0.85s ease,
        transform 0.85s ease;
}

.page-yoga-im-alltag:not(.is-yoga-im-alltag-unlocked) .yoga-im-alltag-video--locked:not(.is-active):not(.is-activating) .yoga-im-alltag-video-wrap {
    filter: saturate(0.22) brightness(1.2) contrast(0.78);
    opacity: 0.62;
    cursor: default;
    pointer-events: none;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
}

.yoga-im-alltag-poster {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-color: #1a1a1a;
}

.yoga-im-alltag-watch-note {
    margin: 0;
    color: var(--color-text-light);
    letter-spacing: 0.04em;
}

.page-yoga-im-alltag:not(.is-yoga-im-alltag-unlocked) .yoga-im-alltag-video--locked:not(.is-active):not(.is-activating) .yoga-im-alltag-poster::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        165deg,
        rgba(255, 255, 255, 0.48) 0%,
        rgba(255, 255, 255, 0.28) 55%,
        rgba(255, 255, 255, 0.18) 100%
    );
    pointer-events: none;
}

.yoga-im-alltag-lock-hint {
    position: absolute;
    left: 0.75rem;
    bottom: 0.65rem;
    z-index: 1;
    margin: 0;
    padding: 0.22rem 0.55rem;
    border-radius: 4px;
    background: color-mix(in srgb, var(--color-bg) 78%, transparent);
    color: var(--color-text-light);
    letter-spacing: 0.08em;
    pointer-events: none;
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.yoga-im-alltag-video.is-active .yoga-im-alltag-lock-hint,
.yoga-im-alltag-video.is-activating .yoga-im-alltag-lock-hint,
.page-yoga-im-alltag.is-yoga-im-alltag-unlocked .yoga-im-alltag-lock-hint {
    opacity: 0;
    transform: translateY(4px);
}

.yoga-im-alltag-video.is-activating .yoga-im-alltag-video-wrap {
    pointer-events: none;
    animation: yoga-im-alltag-wake 1s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.yoga-im-alltag-video.is-activating + .yoga-im-alltag-copy,
.yoga-im-alltag-item--locked:has(.yoga-im-alltag-video.is-activating) .yoga-im-alltag-copy,
.yoga-im-alltag-item--locked:has(.yoga-im-alltag-video.is-active) .yoga-im-alltag-copy {
    opacity: 1;
    transition: opacity 0.65s ease 0.18s;
}

@keyframes yoga-im-alltag-wake {
    0% {
        filter: saturate(0.22) brightness(1.2) contrast(0.78);
        opacity: 0.62;
        transform: scale(0.982);
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
    }
    42% {
        filter: saturate(1.05) brightness(1.04) contrast(1.03);
        opacity: 1;
        transform: scale(1.014);
        box-shadow:
            0 22px 52px rgba(0, 0, 0, 0.14),
            0 0 0 2px color-mix(in srgb, var(--color-accent) 42%, transparent);
    }
    100% {
        filter: none;
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
    }
}

@keyframes yoga-im-alltag-wake-mobile {
    0% {
        filter: saturate(0.22) brightness(1.2) contrast(0.78);
        opacity: 0.62;
        box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
    }
    42% {
        filter: saturate(1.05) brightness(1.04) contrast(1.03);
        opacity: 1;
        box-shadow:
            0 12px 28px rgba(0, 0, 0, 0.12),
            inset 0 0 0 2px color-mix(in srgb, var(--color-accent) 42%, transparent);
    }
    100% {
        filter: none;
        opacity: 1;
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.1);
    }
}

.yoga-im-alltag-access.is-success .yoga-im-alltag-intro-actions__buttons {
    animation: yoga-im-alltag-access-success 0.55s ease;
}

@keyframes yoga-im-alltag-access-success {
    0% { transform: scale(1); }
    35% { transform: scale(1.015); }
    100% { transform: scale(1); }
}

.yoga-im-alltag-play {
    position: absolute;
    right: 0.65rem;
    bottom: 0.65rem;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 0;
    padding: 0;
    margin: 0;
    background: transparent;
    cursor: pointer;
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.yoga-im-alltag-video.is-active .yoga-im-alltag-play:not([hidden]) {
    animation: yoga-im-alltag-play-in 0.42s cubic-bezier(0.22, 1, 0.36, 1) 0.08s both;
}

@keyframes yoga-im-alltag-play-in {
    0% {
        opacity: 0;
        transform: scale(0.88);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.yoga-im-alltag-play:hover .yoga-im-alltag-play-icon,
.yoga-im-alltag-play:focus-visible .yoga-im-alltag-play-icon {
    transform: scale(1.06);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.34);
}

.yoga-im-alltag-play-icon {
    width: 2.85rem;
    height: 2.85rem;
    border-radius: 50%;
    background: color-mix(in srgb, var(--color-accent) 88%, #fff);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.28);
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.yoga-im-alltag-play-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 54%;
    transform: translate(-50%, -50%);
    border-style: solid;
    border-width: 0.48rem 0 0.48rem 0.82rem;
    border-color: transparent transparent transparent var(--color-bg);
}

.yoga-im-alltag-video--intro .yoga-im-alltag-play {
    display: flex !important;
}

.yoga-im-alltag-video--intro .yoga-im-alltag-video-wrap {
    cursor: pointer;
}

.yoga-im-alltag-video.is-active .yoga-im-alltag-video-wrap,
.yoga-im-alltag-video--intro .yoga-im-alltag-video-wrap {
    cursor: pointer;
    pointer-events: auto;
}

.yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__frame {
    max-width: min(920px, calc(100% - 5rem));
    width: 100%;
    max-height: calc(100vh - 4rem);
    max-height: calc(100dvh - 4rem);
    background: #141414;
    border-radius: 12px;
    overflow: hidden;
}

.yoga-im-alltag-lightbox.media-lightbox:not([hidden]) {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.yoga-im-alltag-lightbox.media-lightbox.is-visible:not([hidden]) {
    opacity: 1;
}

.yoga-im-alltag-lightbox__layout {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 0;
    width: 100%;
    align-items: stretch;
    transition: opacity 0.28s ease, transform 0.28s ease;
    will-change: opacity, transform;
}

.yoga-im-alltag-lightbox__layout.is-enter-start {
    opacity: 0;
    transform: scale(0.985) translateY(10px);
}

.yoga-im-alltag-lightbox__layout.is-exit-left {
    opacity: 0;
    transform: translateX(-36px);
}

.yoga-im-alltag-lightbox__layout.is-exit-right {
    opacity: 0;
    transform: translateX(36px);
}

.yoga-im-alltag-lightbox__layout.is-enter-from-right {
    opacity: 0;
    transform: translateX(36px);
}

.yoga-im-alltag-lightbox__layout.is-enter-from-left {
    opacity: 0;
    transform: translateX(-36px);
}

.yoga-im-alltag-lightbox__media {
    min-width: 0;
    padding: 0.35rem 0.5rem 0;
}

.yoga-im-alltag-lightbox__media .media-lightbox__content {
    width: 100%;
    flex: none;
    min-height: 0;
    align-items: center;
    justify-content: center;
}

.yoga-im-alltag-lightbox .media-lightbox__content .page-ika-video-frame,
.yoga-im-alltag-lightbox .yoga-im-alltag-lightbox-player {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 16 / 9;
    max-height: min(56vw, calc(100vh - 16rem));
    margin: 0 auto;
}

.yoga-im-alltag-lightbox#yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__info,
.yoga-im-alltag-lightbox#yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__info :is(
    .type-section,
    .type-body,
    .type-caption,
    .type-label,
    .yoga-im-alltag-lightbox__counter,
    .yoga-im-alltag-lightbox__title,
    .yoga-im-alltag-lightbox__description,
    .yoga-im-alltag-lightbox__practice-label,
    .yoga-im-alltag-lightbox__practice-note
) {
    color: #fff;
}

.yoga-im-alltag-lightbox__info {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    min-width: 0;
    max-width: none;
    max-height: min(34vh, 16rem);
    overflow-y: auto;
    padding: 0.65rem 1.15rem 1rem;
    border-top: 1px solid color-mix(in srgb, #fff 14%, transparent);
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.25) transparent;
    -webkit-overflow-scrolling: touch;
}

.yoga-im-alltag-lightbox__counter {
    margin: 0;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.yoga-im-alltag-lightbox__title {
    margin: 0;
    line-height: 1.15;
}

.yoga-im-alltag-lightbox__info-cols {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: clamp(1rem, 3vw, 1.5rem);
    align-items: start;
}

.yoga-im-alltag-lightbox__info-cols:not(:has(.yoga-im-alltag-lightbox__practice:not([hidden]))) .yoga-im-alltag-lightbox__description {
    grid-column: 1 / -1;
    column-count: 2;
    column-gap: clamp(1rem, 3vw, 1.5rem);
}

.yoga-im-alltag-lightbox__description {
    margin: 0;
}

.yoga-im-alltag-lightbox#yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__description.type-body {
    font-size: 0.82rem;
    font-weight: 300;
    line-height: 1.5;
    text-align: left;
    max-width: none;
}

.yoga-im-alltag-lightbox__practice {
    margin: 0;
    padding: 0 0 0 clamp(0.85rem, 2vw, 1.15rem);
    border: 0;
    border-left: 1px solid color-mix(in srgb, #fff 18%, transparent);
}

.yoga-im-alltag-lightbox__practice-label {
    margin: 0 0 0.45rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    opacity: 0.78;
}

.yoga-im-alltag-lightbox#yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__practice-note.type-body {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 300;
    line-height: 1.48;
    text-align: left;
    max-width: none;
    opacity: 0.92;
}

.yoga-im-alltag-lightbox-player {
    width: 100%;
    margin: 0;
    box-shadow: none;
    position: relative;
}

.yoga-im-alltag-lightbox-player.is-loading::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 2;
    border-radius: inherit;
    background: color-mix(in srgb, #000 28%, transparent);
    pointer-events: none;
}

.yoga-im-alltag-lightbox-player.is-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 3;
    width: 2.25rem;
    height: 2.25rem;
    margin: -1.125rem 0 0 -1.125rem;
    border: 2px solid color-mix(in srgb, #fff 28%, transparent);
    border-top-color: #fff;
    border-radius: 50%;
    animation: yoga-im-alltag-video-spin 0.75s linear infinite;
    pointer-events: none;
}

@keyframes yoga-im-alltag-video-spin {
    to {
        transform: rotate(360deg);
    }
}

.yoga-im-alltag-lightbox .page-ika-plyr,
.yoga-im-alltag-lightbox .plyr {
    width: 100%;
}

.yoga-im-alltag-lightbox-locked {
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 12px;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    box-sizing: border-box;
    position: relative;
}

.yoga-im-alltag-lightbox-locked::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: color-mix(in srgb, #000 52%, transparent);
}

.yoga-im-alltag-lightbox-locked-copy {
    position: relative;
    z-index: 1;
    margin: 0;
    max-width: 22rem;
    text-align: center;
    color: #fff;
}

.yoga-im-alltag-video-slot[hidden],
.yoga-im-alltag-play[hidden],
.yoga-im-alltag-poster[hidden] {
    display: none !important;
}

.yoga-im-alltag-video-slot .page-ika-video-frame {
    aspect-ratio: auto;
    height: 100%;
    border-radius: 0;
    box-shadow: none;
}

.yoga-im-alltag-video-slot,
.yoga-im-alltag-video-slot .page-ika-plyr,
.yoga-im-alltag-video-slot .plyr {
    position: absolute;
    inset: 0;
    height: 100%;
}

.yoga-im-alltag-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.yoga-im-alltag-title {
    margin: 0;
    font-size: clamp(1.35rem, 2vw, 1.65rem);
    min-width: 0;
}

.yoga-im-alltag-audio-download,
.yoga-im-alltag-audio-download.type-caption {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    flex-shrink: 0;
    margin-left: auto;
    text-decoration: none;
    color: var(--color-accent);
    transition: color 0.2s ease;
}

.yoga-im-alltag-audio-download:hover,
.yoga-im-alltag-audio-download:focus-visible {
    color: color-mix(in srgb, var(--color-accent) 72%, var(--color-text));
}

.yoga-im-alltag-audio-download__icon {
    display: block;
    flex-shrink: 0;
}

.yoga-im-alltag-audio-download--pending {
    pointer-events: none;
    cursor: default;
}

.page-yoga-im-alltag:not(.is-yoga-im-alltag-unlocked) .yoga-im-alltag-item--locked .yoga-im-alltag-audio-download {
    display: none;
}

.yoga-im-alltag-description {
    margin: 0;
}

.yoga-im-alltag-video--open .page-ika-video-frame {
    margin: 0;
}

@media (max-width: 768px) {
    main:has(.page-yoga-im-alltag) {
        overflow-x: clip;
        padding-left: max(0.85rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.85rem, env(safe-area-inset-right, 0px));
        box-sizing: border-box;
    }

    .page-yoga-im-alltag {
        --yoga-im-alltag-gap: var(--spacing-md);
        --yoga-im-alltag-stack-gap: 0.65rem;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        overflow-x: clip;
        box-sizing: border-box;
    }

    .page-yoga-im-alltag .type-headline-group,
    .page-yoga-im-alltag-intro,
    .yoga-im-alltag-intro-main,
    .yoga-im-alltag-intro-swap,
    .yoga-im-alltag-welcome,
    .yoga-im-alltag-grid,
    .yoga-im-alltag-item {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }

    .page-yoga-im-alltag.is-unlocking,
    .page-yoga-im-alltag.is-unlock-sequence,
    .page-yoga-im-alltag.is-welcome-sequencing {
        overflow-x: clip;
    }

    .yoga-im-alltag-type-ghost,
    .yoga-im-alltag-type-visible,
    .page-yoga-im-alltag-intro .lead-text,
    .page-yoga-im-alltag-intro .lead-text p,
    [data-yoga-im-alltag-subline] {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .page-yoga-im-alltag-intro,
    .page-yoga-im-alltag-intro.page-ika-lead.site-quote {
        margin-bottom: 0.65rem;
    }

    .yoga-im-alltag-grid {
        grid-template-columns: 1fr;
        gap: var(--yoga-im-alltag-gap);
        overflow-x: clip;
    }

    .yoga-im-alltag-title-row {
        flex-wrap: wrap;
        row-gap: 0.35rem;
    }

    .yoga-im-alltag-title {
        flex: 1 1 8rem;
        overflow-wrap: anywhere;
    }

    .yoga-im-alltag-audio-download {
        margin-left: 0;
    }

    .yoga-im-alltag-video-wrap {
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.1);
    }

    .yoga-im-alltag-video.is-activating .yoga-im-alltag-video-wrap {
        animation-name: yoga-im-alltag-wake-mobile;
    }

    .yoga-im-alltag-welcome-zip-link {
        max-width: 100%;
        white-space: normal;
        text-align: center;
    }

    .yoga-im-alltag-intro-actions {
        padding-top: 0.65rem;
    }

    .yoga-im-alltag-access-note {
        padding-top: 0.5rem;
    }

    .yoga-im-alltag-intro-actions__buttons {
        flex-direction: column;
        align-items: stretch;
    }

    .yoga-im-alltag-order-btn,
    .yoga-im-alltag-login-btn,
    .yoga-im-alltag-welcome-zip-link {
        width: 100%;
        justify-content: center;
        text-align: center;
        box-sizing: border-box;
    }

    .yoga-im-alltag-login-modal .yoga-im-alltag-unlock-row {
        flex-direction: column;
        align-items: stretch;
    }

    .yoga-im-alltag-login-modal .yoga-im-alltag-unlock-row input[type='password'] {
        width: 100%;
        flex: none;
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
    }

    .yoga-im-alltag-login-modal .yoga-im-alltag-unlock-btn {
        width: 100%;
        align-self: stretch;
        justify-content: center;
        text-align: center;
        box-sizing: border-box;
    }

    .yoga-im-alltag-play-icon {
        width: 3.1rem;
        height: 3.1rem;
    }

    /* Lightbox: Toolbar oben, Video + Text knapp darunter ohne Überlappung */
    .yoga-im-alltag-lightbox.media-lightbox {
        --yoga-lightbox-mobile-toolbar: calc(
            max(0.5rem, env(safe-area-inset-top, 0px)) + 2.75rem + 0.35rem
        );
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        padding:
            var(--yoga-lightbox-mobile-toolbar)
            0
            0;
        box-sizing: border-box;
    }

    .yoga-im-alltag-lightbox .media-lightbox__frame,
    .yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__frame {
        position: relative;
        z-index: 1;
        max-width: 100%;
        width: 100%;
        max-height: calc(100dvh - var(--yoga-lightbox-mobile-toolbar));
        height: calc(100dvh - var(--yoga-lightbox-mobile-toolbar));
        flex: 1 1 auto;
        min-height: 0;
        gap: 0;
        margin: 0;
    }

    .yoga-im-alltag-lightbox .media-lightbox__close {
        top: max(0.5rem, env(safe-area-inset-top, 0px));
        right: max(0.5rem, env(safe-area-inset-right, 0px));
        z-index: 12;
        width: 2.75rem;
        height: 2.75rem;
    }

    .yoga-im-alltag-lightbox .media-lightbox__nav {
        top: max(0.5rem, env(safe-area-inset-top, 0px));
        bottom: auto;
        transform: none;
        width: 2.75rem;
        height: 2.75rem;
        font-size: 1.35rem;
        z-index: 12;
    }

    .yoga-im-alltag-lightbox .media-lightbox__nav--prev {
        left: max(0.5rem, env(safe-area-inset-left, 0px));
        right: auto;
    }

    .yoga-im-alltag-lightbox .media-lightbox__nav--next {
        right: auto;
        left: calc(max(0.5rem, env(safe-area-inset-left, 0px)) + 2.75rem + 0.35rem);
    }

    .yoga-im-alltag-lightbox__layout {
        grid-template-columns: 1fr;
        grid-template-rows: auto minmax(0, 1fr);
        width: 100%;
        height: 100%;
        max-height: 100%;
        gap: 0;
        align-items: stretch;
        align-content: start;
    }

    .yoga-im-alltag-lightbox__media {
        display: flex;
        flex-direction: column;
        flex: 0 0 auto;
        min-height: 0;
        padding: 0;
    }

    .yoga-im-alltag-lightbox__media .media-lightbox__content {
        flex: 0 0 auto;
        min-height: 0;
        width: 100%;
        align-items: stretch;
        justify-content: flex-start;
    }

    .yoga-im-alltag-lightbox .yoga-im-alltag-lightbox-player,
    .yoga-im-alltag-lightbox .media-lightbox__content .page-ika-video-frame {
        width: 100%;
        max-width: 100%;
        max-height: min(56vw, calc(100dvh - var(--yoga-lightbox-mobile-toolbar) - 9rem));
        height: auto;
        aspect-ratio: 16 / 9;
        margin: 0;
    }

    .yoga-im-alltag-lightbox .media-lightbox__content video,
    .yoga-im-alltag-lightbox .page-ika-plyr,
    .yoga-im-alltag-lightbox .page-ika-plyr .plyr {
        width: 100%;
        max-height: none;
    }

    .yoga-im-alltag-lightbox .page-ika-plyr .plyr__control {
        min-width: 2.75rem;
        min-height: 2.75rem;
    }

    .yoga-im-alltag-lightbox .page-ika-plyr .plyr__controls {
        padding: 0.45rem 0.35rem 0.55rem;
    }

    .yoga-im-alltag-lightbox .page-ika-plyr .plyr__volume {
        display: none;
    }

    .yoga-im-alltag-lightbox__info {
        max-width: none;
        max-height: none;
        min-height: 0;
        overflow-y: auto;
        padding:
            0.5rem 1rem
            max(0.75rem, env(safe-area-inset-bottom, 0px));
        border-top: 1px solid rgba(255, 255, 255, 0.14);
        flex-shrink: 0;
        -webkit-overflow-scrolling: touch;
    }

    .yoga-im-alltag-lightbox__info-cols {
        grid-template-columns: 1fr;
    }

    .yoga-im-alltag-lightbox__info-cols:not(:has(.yoga-im-alltag-lightbox__practice:not([hidden]))) .yoga-im-alltag-lightbox__description {
        column-count: 1;
    }

    .yoga-im-alltag-lightbox__practice {
        margin-top: 0.35rem;
        padding-top: 0.75rem;
        padding-left: 0;
        border-left: 0;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
    }

    .yoga-im-alltag-lightbox-locked {
        max-height: min(56vw, calc(100dvh - var(--yoga-lightbox-mobile-toolbar) - 9rem));
    }
}

@media (max-width: 768px) and (orientation: portrait) {
    .yoga-im-alltag-lightbox__info {
        padding-top: 0.5rem;
    }
}

/* Vollbild: Lightbox-Container oder Plyr-Fallback */
.yoga-im-alltag-lightbox.media-lightbox:fullscreen,
.yoga-im-alltag-lightbox.media-lightbox.is-fullscreen,
body.yoga-im-alltag-video-fullscreen .yoga-im-alltag-lightbox.media-lightbox {
    padding: 0;
}

.yoga-im-alltag-lightbox.media-lightbox:fullscreen .yoga-im-alltag-lightbox__layout,
.yoga-im-alltag-lightbox.media-lightbox.is-fullscreen .yoga-im-alltag-lightbox__layout,
body.yoga-im-alltag-video-fullscreen .yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__layout {
    grid-template-rows: 1fr auto;
    max-height: none;
    height: 100%;
}

.yoga-im-alltag-lightbox.media-lightbox:fullscreen .yoga-im-alltag-lightbox__media,
.yoga-im-alltag-lightbox.media-lightbox.is-fullscreen .yoga-im-alltag-lightbox__media,
body.yoga-im-alltag-video-fullscreen .yoga-im-alltag-lightbox .yoga-im-alltag-lightbox__media {
    padding-top: max(2.85rem, env(safe-area-inset-top, 0px));
}

.yoga-im-alltag-lightbox.media-lightbox:fullscreen .yoga-im-alltag-lightbox-player,
.yoga-im-alltag-lightbox.media-lightbox:fullscreen .media-lightbox__content .page-ika-video-frame,
body.yoga-im-alltag-video-fullscreen .yoga-im-alltag-lightbox .yoga-im-alltag-lightbox-player,
body.yoga-im-alltag-video-fullscreen .yoga-im-alltag-lightbox .media-lightbox__content .page-ika-video-frame {
    max-height: calc(100dvh - 8rem);
}

.yoga-im-alltag-lightbox .plyr.plyr--fullscreen-fallback {
    position: fixed;
    inset: 0;
    z-index: 6000;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    border-radius: 0;
}

.yoga-im-alltag-lightbox .plyr.plyr--fullscreen-fallback video {
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
}

@media (prefers-reduced-motion: reduce) {
    .yoga-im-alltag-video.is-activating .yoga-im-alltag-video-wrap,
    .yoga-im-alltag-video.is-active .yoga-im-alltag-play:not([hidden]),
    .yoga-im-alltag-access.is-success .yoga-im-alltag-intro-actions__buttons {
        animation: none;
    }

    .page-yoga-im-alltag:not(.is-yoga-im-alltag-unlocked) .yoga-im-alltag-video--locked:not(.is-active) .yoga-im-alltag-video-wrap {
        transition: none;
    }

    .contact-form-modal,
    .contact-form-modal__dialog {
        transition: none;
    }

    .yoga-im-alltag-lightbox.media-lightbox,
    .yoga-im-alltag-lightbox__layout {
        transition: none !important;
    }

    .yoga-im-alltag-intro-swap.is-welcome-swap-active,
    .yoga-im-alltag-intro-swap__original,
    .yoga-im-alltag-intro-swap__welcome,
    .yoga-im-alltag-welcome-zip.is-welcome-zip-reveal,
    .yoga-im-alltag-intro-actions,
    .yoga-im-alltag-grid.is-grid-slide-active,
    .yoga-im-alltag-audio-list__item--zip.is-generating {
        transition: none !important;
        animation: none !important;
    }

    .yoga-im-alltag-audio-list__item--zip.is-generating {
        background: color-mix(in srgb, var(--color-accent) 18%, var(--color-bg));
    }

}

/* —— Kontaktformular Modal —— */
.contact-form-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 3vw, 2rem);
    isolation: isolate;
}

.contact-form-modal[hidden] {
    display: none !important;
}

body.admin-edit-page .contact-form-modal {
    z-index: 10050;
}

.contact-form-modal.is-open {
    background: color-mix(in srgb, #000 42%, transparent);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.contact-form-modal__backdrop {
    position: absolute;
    inset: 0;
    background: transparent;
    /* Klickfläche — Blur sitzt auf .contact-form-modal.is-open für schnelleres iOS-Compositing */
}

.contact-form-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 52rem);
    max-height: min(92vh, 920px);
    overflow: auto;
    padding: clamp(1.25rem, 3vw, 2rem);
    border-radius: 14px;
    background: var(--color-bg);
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.22);
    outline: none;
    opacity: 1;
    transform: none;
}

.contact-form-modal.is-open .contact-form-modal__dialog {
    animation: contact-form-modal-in 0.22s cubic-bezier(0.22, 1, 0.36, 1);
    animation-fill-mode: both;
}

.yoga-im-alltag-login-modal.is-open .contact-form-modal__dialog {
    animation-duration: 0.18s;
}

@keyframes contact-form-modal-in {
    from {
        opacity: 0;
        transform: translateY(8px) scale(0.99);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

body.contact-form-modal-open {
    overflow: hidden;
}

.contact-form-modal__close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-border) 55%, transparent);
    color: var(--color-text);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.contact-form-modal__close:hover,
.contact-form-modal__close:focus-visible {
    background: color-mix(in srgb, var(--color-accent) 24%, var(--color-bg));
}

.contact-form-modal__head {
    margin: 0 2rem 1rem 0;
}

.contact-form-modal__title {
    margin: 0 0 0.35rem;
    font-size: clamp(1.35rem, 2vw, 1.65rem);
}

.contact-form-modal__lead {
    margin: 0;
    color: var(--color-text-light);
}

.page-kontakt-form-wrap--modal {
    margin: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.page-kontakt-form-wrap--modal .page-kontakt-form-stage {
    min-height: 0;
}

.page-kontakt-form-wrap--modal .page-kontakt-form-panel--form {
    padding: 0;
}

.page-kontakt-form-wrap--modal .page-kontakt-form-aside {
    gap: 0.5rem;
}

.page-kontakt-form-wrap--modal .page-kontakt-form-field--checkbox label,
.page-kontakt-form-wrap--modal .page-kontakt-form-field--checkbox .page-kontakt-form-checkbox {
    padding: 0.28rem 0.1rem 0.28rem 0;
}

@media (max-width: 768px) {
    .contact-form-modal__dialog {
        max-height: 94vh;
    }

    .page-kontakt-form-wrap--modal .page-kontakt-form-layout {
        grid-template-columns: 1fr;
    }
}

/* —— Newsletter Bestätigung (Startseiten-Overlay) —— */
.newsletter-confirm-overlay {
    position: fixed;
    inset: 0;
    z-index: 1300;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 3vw, 2rem);
    box-sizing: border-box;
    opacity: 1;
    transition: opacity 0.6s ease;
}

.newsletter-confirm-overlay[hidden] {
    display: none !important;
}

.newsletter-confirm-overlay.is-fading {
    opacity: 0;
    pointer-events: none;
}

body.newsletter-confirm-overlay-open {
    overflow: hidden;
}

.newsletter-confirm-overlay__backdrop {
    position: absolute;
    inset: 0;
    background: color-mix(in srgb, #000 42%, transparent);
    backdrop-filter: blur(4px);
}

.newsletter-confirm-overlay__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 28rem);
    padding: clamp(1.25rem, 3vw, 1.75rem);
    border-radius: 14px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.22);
    text-align: center;
    transform: translateY(0);
    transition: transform 0.6s ease, opacity 0.6s ease;
}

.newsletter-confirm-overlay.is-fading .newsletter-confirm-overlay__dialog {
    transform: translateY(12px);
    opacity: 0.6;
}

.newsletter-confirm-overlay.is-visible .newsletter-confirm-overlay__dialog {
    animation: contact-form-modal-in 0.34s cubic-bezier(0.22, 1, 0.36, 1);
}

.newsletter-confirm-overlay__close {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    width: 2rem;
    height: 2rem;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: var(--color-text-light);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.newsletter-confirm-overlay__close:hover,
.newsletter-confirm-overlay__close:focus-visible {
    color: var(--color-accent);
}

.newsletter-confirm-overlay__title {
    margin: 0 0 0.75rem;
    color: var(--color-accent);
}

.newsletter-confirm-overlay__message {
    margin: 0;
    color: var(--color-text);
}

/* Bibliothek — Link-Sammlung */
.page-bibliothek-intro {
    margin-bottom: var(--spacing-lg);
    max-width: var(--layout-content-max);
}

.page-bibliothek-section {
    margin-bottom: var(--spacing-xl);
}

.page-bibliothek-section .page-ika-section-title {
    margin-bottom: var(--spacing-md);
}

.page-bibliothek-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 18rem), 1fr));
    gap: var(--spacing-md);
}

.page-bibliothek-card {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    overflow: hidden;
    background: var(--color-bg);
}

.page-bibliothek-card-media {
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: color-mix(in srgb, var(--color-accent) 6%, var(--color-border));
}

.page-bibliothek-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.35s ease;
}

.page-bibliothek-card-media:hover img,
.page-bibliothek-card-media:focus-visible img {
    transform: scale(1.03);
}

.page-bibliothek-card-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 0.45rem;
    padding: 1rem 1.1rem 1.15rem;
}

.page-bibliothek-card-kind {
    margin: 0;
}

.page-bibliothek-card-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.35;
    color: var(--color-accent);
}

.page-bibliothek-card-text {
    margin: 0;
    flex: 1;
    font-size: 0.92rem;
    line-height: 1.55;
}

.page-bibliothek-card-links {
    margin: 0.35rem 0 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.15rem 0.35rem;
}

.page-bibliothek-card-links-sep {
    color: var(--color-text-light);
    font-size: 0.85rem;
}

.page-bibliothek-card:not(:has(.page-bibliothek-card-media)) .page-bibliothek-card-body {
    padding-top: 1.15rem;
}

/* ===== IMPRESSUM / DATENSCHUTZ ===== */
.page-legal {
    max-width: var(--layout-content-max);
    display: flex;
    flex-direction: column;
    gap: var(--page-title-intro-gap);
}

.page-legal-section {
    padding-top: 0;
}

.page-legal-section--datenschutz {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.page-legal-section .page-ika-section-title {
    margin-top: var(--spacing-md);
    margin-bottom: var(--type-section-body-gap);
}

.page-legal-party {
    margin: 0 0 var(--spacing-md);
    padding: 0 0 0 1rem;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
}

.page-legal-party-kicker {
    margin: 0 0 0.85rem;
    color: var(--color-accent);
}

.page-legal-party-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem 1.5rem;
    margin: 0;
}

.page-legal-party-fact {
    margin: 0;
    min-width: 0;
}

.page-legal-party-fact dt {
    margin: 0 0 0.2rem;
    color: var(--color-text-light);
}

.page-legal-party-fact dd {
    margin: 0;
    max-width: none;
    font-family: var(--font-serif);
    font-size: 1rem;
    line-height: 1.45;
}

.page-legal-party-mail dd {
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.protected-email--text {
    display: inline;
    padding: 0;
    border: none;
    background: none;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 0.15em;
    cursor: pointer;
}

.protected-email--text:hover {
    color: var(--color-text);
}

.page-legal-block {
    margin-bottom: var(--spacing-md);
}

.page-legal-lead {
    margin-bottom: var(--spacing-sm);
}

.page-legal-lead + .page-legal-block {
    padding-top: var(--spacing-sm);
}

.page-legal-block:last-child {
    margin-bottom: 0;
}

.page-legal-subtitle {
    margin: 0 0 0.55rem;
    color: var(--color-accent);
}

.page-legal-lead .type-body:last-child {
    margin-bottom: 0;
}

.page-legal-list {
    margin: 0.5rem 0 0;
    padding: 0 0 0 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.page-legal-list li {
    margin: 0;
}

.page-legal-contact {
    padding: 0.85rem 1rem;
    border-left: 2px solid color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
    background: color-mix(in srgb, var(--color-accent) 5%, var(--color-bg));
}

.page-legal-updated {
    margin: var(--spacing-md) 0 0;
    color: var(--color-text-light);
}

.page-kontakt-form-checkbox a,
.page-newsletter-legal a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 0.12em;
}

.page-kontakt-form-checkbox a:hover,
.page-newsletter-legal a:hover {
    color: var(--color-accent);
}

.page-newsletter-legal a {
    color: var(--color-text-light);
}

.protected-email-noscript {
    display: block;
    margin-top: 0.35rem;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-light);
}

@media (max-width: 768px) {
    .page-bibliothek-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .page-legal-party-facts {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
}

/* ===== Admin Login ===== */
body.admin-login-page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    min-height: 100svh;
}

body.admin-login-page main {
    display: flex;
    flex: 1 1 auto;
    align-items: center;
    justify-content: center;
    min-height: 0;
    padding:
        clamp(1.5rem, 4vw, 3rem)
        max(var(--spacing-md), env(safe-area-inset-right, 0))
        max(clamp(1.5rem, 4vw, 3rem), env(safe-area-inset-bottom, 0))
        max(var(--spacing-md), env(safe-area-inset-left, 0));
    box-sizing: border-box;
}

.page-admin-login {
    width: min(100%, 26rem);
    margin: 0 auto;
}

.page-admin-login__inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(1rem, 2.5vw, 1.35rem);
    text-align: center;
}

.page-admin-login__greeting-wrap {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.85rem;
    transform-origin: center center;
}

.page-admin-login__flower {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    font-family: var(--font-mono-custom, 'JetBrains Mono', monospace);
    font-size: clamp(0.72rem, 2.2vw, 0.82rem);
    line-height: 1.15;
    letter-spacing: 0.02em;
    text-align: center;
    color: color-mix(in srgb, var(--color-accent) 82%, var(--color-text));
    white-space: pre;
    animation: admin-login-flower-in 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes admin-login-flower-in {
    from {
        opacity: 0;
        transform: translateY(6px) scale(0.94);
    }

    to {
        opacity: 1;
        transform: none;
    }
}

.page-admin-login__greeting-wrap.is-error .page-admin-login__flower {
    color: color-mix(in srgb, #b85c5c 75%, var(--color-text-light));
    opacity: 0.72;
}

.page-admin-login__greeting-wrap.is-shaking {
    animation: admin-login-shake 0.58s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}

@keyframes admin-login-shake {
    0%,
    100% {
        transform: translateX(0) rotate(0deg);
    }

    12% {
        transform: translateX(-9px) rotate(-0.7deg);
    }

    24% {
        transform: translateX(8px) rotate(0.6deg);
    }

    36% {
        transform: translateX(-6px) rotate(-0.4deg);
    }

    48% {
        transform: translateX(5px) rotate(0.35deg);
    }

    60% {
        transform: translateX(-3px) rotate(-0.2deg);
    }

    72% {
        transform: translateX(2px) rotate(0.1deg);
    }
}

.page-admin-login__greeting-wrap.is-error .page-admin-login__greeting-live {
    color: #9b2c2c;
}

.page-admin-login__greeting-stage {
    position: relative;
    width: 100%;
    min-width: 0;
}

.page-admin-login__greeting-sizer {
    margin: 0;
    visibility: hidden;
    user-select: none;
    pointer-events: none;
    text-align: center;
    white-space: pre-wrap;
}

.page-admin-login__greeting-live {
    position: absolute;
    inset: 0;
    margin: 0;
    text-align: center;
    transition: color 0.25s ease;
}

.page-admin-login__greeting-wrap.is-typing .page-admin-login__greeting-live::after {
    content: '';
    display: inline-block;
    width: 2px;
    height: 0.92em;
    margin-left: 0.12em;
    vertical-align: -0.08em;
    border-radius: 1px;
    background: var(--color-accent);
    animation: admin-login-cursor-blink 0.85s step-end infinite;
}

.page-admin-login__greeting-wrap.is-error.is-typing .page-admin-login__greeting-live::after {
    background: #b85c5c;
}

@keyframes admin-login-cursor-blink {
    0%,
    45% {
        opacity: 1;
    }

    50%,
    100% {
        opacity: 0;
    }
}

.page-admin-login__form {
    flex-shrink: 0;
    margin: 0;
}

.page-admin-login__row {
    flex-wrap: nowrap;
    align-items: stretch;
}

.page-admin-login__row input[type='password'] {
    flex: 1 1 0;
    min-height: 2.85rem;
    padding: 0.65rem 0.85rem;
    font-size: 0.9rem;
}

.page-admin-login__submit {
    min-height: 2.85rem;
    padding: 0.65rem 1.35rem;
    align-self: stretch;
}

.page-admin-login__submit:disabled,
.page-admin-login__row input[type='password']:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

@media (prefers-reduced-motion: reduce) {
    .page-admin-login__greeting-wrap.is-typing .page-admin-login__greeting-live::after {
        display: none;
    }

    .page-admin-login__greeting-wrap.is-shaking {
        animation: admin-login-shake-reduced 0.35s ease both;
    }

    @keyframes admin-login-shake-reduced {
        0%,
        100% {
            transform: none;
        }

        40% {
            transform: translateX(-3px);
        }

        70% {
            transform: translateX(3px);
        }
    }
}

@media (max-width: 520px) {
    body.admin-login-page main {
        padding-top: max(1rem, env(safe-area-inset-top, 0));
    }

    .page-admin-login {
        width: min(100%, 100%);
    }

    .page-admin-login__greeting-wrap {
        gap: 0.65rem;
        padding: 0 0.15rem;
    }

    .page-admin-login__flower {
        font-size: clamp(0.66rem, 3.1vw, 0.76rem);
        line-height: 1.1;
    }

    .page-admin-login__row {
        flex-direction: column;
        align-items: stretch;
    }

    .page-admin-login__row input[type='password'] {
        min-height: 3rem;
        font-size: 1rem;
    }

    .page-admin-login__submit {
        width: 100%;
        min-height: 3rem;
    }
}
