/* ═══════════════════════════════════════════════════════════
   41-ritual.css
   «Das Ritual» – Ophyr Zeremonie-Seite
   Mobile-First · Ophyr v40 Design System
   ═══════════════════════════════════════════════════════════ */

/* ─── Design Tokens ─── */
:root {
    --rit-gold: #c4a169;
    --rit-gold-light: #d4bc91;
    --rit-gold-dark: #a6854e;
    --rit-gold-glow: rgba(196, 161, 105, 0.12);
    --rit-bg: #0f0e0c;
    --rit-bg-card: #1a1816;
    --rit-bg-elevated: #1f1d1a;
    --rit-bg-warm: #16140f;
    --rit-text: rgba(255, 255, 255, 0.92);
    --rit-text-muted: rgba(255, 255, 255, 0.6);
    --rit-text-subtle: rgba(255, 255, 255, 0.4);
    --rit-border: rgba(196, 161, 105, 0.18);
    --rit-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ═══════════════════════════════════════════════════════════
   A-0: HEADLINE – Kosmologisches Zitat (H1)
   Positionierung exakt wie .store-value-section auf der Startseite
   ═══════════════════════════════════════════════════════════ */

/* Body-Override: dunkler Hintergrund verhindert helle Lücken zwischen Sektionen */
body.ritual-page {
    background-color: var(--rit-bg);
}

/* Globales main-padding entfernen – Hero-Video startet bündig an der Oberkante */
.ritual-page main:not(.hero):not(.ophyr-hero) {
    padding-top: 0;
}

.ritual-headline-section {
    background: #333333;
    padding: var(--section-padding) var(--container-padding);
    position: relative;
}

.ritual-headline-section::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

/* Dunkler Hintergrund: helle Textfarben für Kontrast */
.ritual-headline {
    color: var(--ivory, #f5f0e8);
    opacity: 1;
    line-height: 1.15;
    /* FIX: overflow-wrap:normal verhindert Wortbruch mitten im Wort
       (erbt sonst break-word von .legal-title → "VERSCHMELZE\nN").
       text-wrap:auto überschreibt das 'balance' aus .legal-title,
       das den Browser zwingt, Zeilen "auszugleichen" und dabei
       einzelne Buchstaben auf neue Zeilen verschiebt. */
    overflow-wrap: normal;
    word-break: keep-all;
    text-wrap: auto;
}

@media (max-width: 47.99rem) {
    .ritual-headline {
        font-size: calc(var(--fs-display) * 1.035) !important;
        text-align: center !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Dark-Mode-Overrides für Startseiten-Klassen im Ritual-Headline-Kontext */
.ritual-headline-section .store-highlight-statement {
    color: var(--ivory, #f5f0e8);
    border-left-color: var(--rit-gold);
}

.ritual-headline-section .news-body-text {
    font-family: var(--font-accent) !important;
    color: rgba(245, 240, 232, 0.8) !important;
    font-size: clamp(1.35rem, 3vw, 1.5rem) !important;
    font-weight: 300 !important;
    line-height: 1.7 !important;
    text-align: left !important;
    margin-top: 0 !important;
    margin-bottom: clamp(1.5rem, 3vw, 2.5rem) !important;
}

.ritual-headline-section .news-body-text strong {
    font-weight: 600 !important;
}

/* ═══════════════════════════════════════════════════════════
   A: HERO – «Der Moment»
   Fullscreen, cinematisch, meditativ
   ═══════════════════════════════════════════════════════════ */

.ritual-hero {
    position: relative;
    min-height: 100vh;
    min-height: 100svh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--rit-bg);
}

.ritual-hero__image {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.ritual-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.55;
    filter: saturate(0.6) contrast(1.15);
}

/* Gradient-Overlay: oben & unten ausblenden */
.ritual-hero__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
            rgba(8, 8, 8, 0.6) 0%,
            transparent 30%,
            transparent 60%,
            rgba(8, 8, 8, 0.95) 100%);
    pointer-events: none;
}

.ritual-hero__content {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 2rem 1.5rem;
}

.ritual-hero__overtitle {
    font-family: var(--font-accent);
    font-size: clamp(0.5rem, 1.6vw, 0.65rem);
    font-weight: 400;
    letter-spacing: 0.5em;
    text-transform: uppercase;
    color: var(--rit-gold);
    margin-bottom: 2rem;
    opacity: 0;
    animation: ritFadeUp 1.2s var(--rit-ease) 0.3s forwards;
}

.ritual-hero__title {
    font-family: var(--font-editorial);
    font-size: clamp(2.5rem, 10vw, 5rem);
    font-weight: 200;
    letter-spacing: 0.15em;
    color: var(--rit-text);
    text-transform: uppercase;
    margin: 0 0 1.5rem;
    opacity: 0;
    animation: ritFadeUp 1.4s var(--rit-ease) 0.6s forwards;
}

.ritual-hero__divider {
    width: 3rem;
    height: 1px;
    background: var(--rit-gold);
    margin: 0 auto 1.5rem;
    opacity: 0;
    animation: ritFadeUp 1s var(--rit-ease) 1s forwards;
}

.ritual-hero__subtitle {
    font-family: var(--font-editorial);
    font-size: clamp(0.95rem, 3vw, 1.3rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.7);
    max-width: 28rem;
    margin: 0 auto;
    letter-spacing: 0.02em;
    opacity: 0;
    animation: ritFadeUp 1.4s var(--rit-ease) 1.2s forwards;
}

/* Scroll-Indicator */
.ritual-hero__scroll {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    opacity: 0;
    animation: ritFadeUp 1s var(--rit-ease) 2s forwards;
}

.ritual-hero__scroll-line {
    width: 1px;
    height: 2.5rem;
    background: linear-gradient(to bottom, var(--rit-gold), transparent);
    animation: ritPulse 2.5s ease-in-out infinite;
}

/* ═══════════════════════════════════════════════════════════
   B: EINLEITUNG – «Das Versprechen»
   ═══════════════════════════════════════════════════════════ */

.ritual-intro {
    padding: clamp(5rem, 15vw, 9rem) clamp(1.5rem, 5vw, 3rem);
    background: linear-gradient(180deg, var(--rit-bg) 0%, var(--rit-bg-warm) 50%, var(--rit-bg) 100%);
    text-align: center;
}

.ritual-intro__ornament {
    display: block;
    width: clamp(8rem, 30vw, 12rem);
    height: 1.5rem;
    margin: 0 auto 3rem;
    opacity: 0.5;
}

.ritual-intro__text {
    font-family: var(--font-editorial);
    font-size: clamp(1.2rem, 4vw, 1.75rem);
    font-weight: 300;
    line-height: 1.9;
    color: var(--rit-text);
    max-width: 34rem;
    margin: 0 auto;
    letter-spacing: 0.02em;
}

.ritual-intro__text em {
    font-style: italic;
    color: var(--rit-gold-light);
}

/* ═══════════════════════════════════════════════════════════
   C: DIE FÜNF STUFEN – «Das Protokoll»
   ═══════════════════════════════════════════════════════════ */

.ritual-stages {
    background: linear-gradient(180deg, var(--rit-bg) 0%, var(--rit-bg-card) 15%, var(--rit-bg-card) 85%, var(--rit-bg) 100%);
    padding: 0 0 clamp(3rem, 8vw, 5rem);
    position: relative;
}

.ritual-stages::before,
.ritual-stages::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-stages::before {
    top: 0;
}

.ritual-stages::after {
    bottom: 0;
}

.ritual-stages__header {
    text-align: center;
    padding: clamp(3rem, 8vw, 5rem) 1.5rem clamp(2rem, 5vw, 3rem);
}

.ritual-stages__label {
    font-family: var(--font-accent);
    font-size: clamp(0.9rem, 2.4vw, 1.08rem);
    font-weight: 400;
    letter-spacing: 0.5em;
    text-transform: uppercase;
    color: var(--rit-gold);
    opacity: 0.75;
}

/* Einzelne Stufe */
.ritual-stage {
    position: relative;
    padding: clamp(3rem, 8vw, 5rem) 1.25rem clamp(3rem, 8vw, 5rem) 4.25rem;
    border-top: 1px solid var(--rit-border);
}

.ritual-stage__inner {
    max-width: 64rem;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 3rem);
    align-items: center;
}

/* Nummerierung — Edel-sichtbar, klar getrennt vom Titel */
.ritual-stage__number {
    display: block;
    font-family: var(--font-editorial, 'Cormorant Garamond', serif);
    font-style: italic;
    font-size: clamp(3.5rem, 10vw, 5.5rem);
    font-weight: 200;
    color: var(--rit-gold-dark, #a6854e);
    line-height: 1;
    letter-spacing: 0.05em;
    margin-bottom: 1.25rem;
    transition: color 0.8s var(--rit-ease), text-shadow 0.8s var(--rit-ease);
}

.ritual-stage__title {
    font-family: var(--font-accent);
    font-size: clamp(1.4rem, 4.5vw, 2rem);
    font-weight: 500;
    background: linear-gradient(135deg,
            var(--rit-gold) 0%,
            var(--rit-gold-light) 50%,
            var(--rit-gold) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin: 0 0 1.25rem;
    line-height: 1.25;
    filter: brightness(1.25);
}

.ritual-stage__subtitle {
    font-family: var(--font-accent);
    font-size: clamp(1.35rem, 3vw, 1.5rem);
    font-weight: 300;
    line-height: 1.7;
    color: rgba(245, 240, 232, 0.8);
    max-width: 30rem;
    letter-spacing: 0.025em;
    opacity: 0.96;
}

/* Edle Instruktions-Kachel */
.ritual-stage__instruction-card {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    background: linear-gradient(135deg, var(--rit-gold-light) 0%, var(--rit-gold) 50%, var(--rit-gold-dark) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(116, 87, 41, 0.2);
    border-top: 1px solid rgba(255, 255, 255, 0.45);
    border-radius: 8px;
    padding: 1.5rem 2rem; /* Spacious and airy */
    margin-bottom: 1.75rem;
    max-width: 34rem;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35); /* Premium depth */
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.8s cubic-bezier(0.16, 1, 0.3, 1),
                border-top-color 0.8s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.8s cubic-bezier(0.16, 1, 0.3, 1),
                background 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.ritual-stage__instruction-card:hover {
    transform: translate3d(0, -4px, 0);
    border-color: rgba(116, 87, 41, 0.4);
    border-top-color: rgba(255, 255, 255, 0.7);
    background: linear-gradient(135deg, var(--rit-gold-light) 0%, var(--rit-gold-light) 30%, var(--rit-gold) 100%);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5),
                0 0 30px rgba(196, 161, 105, 0.2);
}

.ritual-stage__instruction-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    color: #1a1610;
    flex-shrink: 0;
    transition: transform 0.4s var(--rit-ease);
}

.ritual-stage__instruction-card:hover .ritual-stage__instruction-icon {
    transform: scale(1.08);
}

.ritual-stage__instruction-icon svg {
    width: 2.25rem;
    height: 2.25rem;
    stroke: #1a1610;
    stroke-width: 1.35;
}

.ritual-stage__instruction-text {
    font-family: var(--font-accent);
    font-size: clamp(1.08rem, 2.4vw, 1.2rem);
    font-weight: 450;
    color: #1a1610;
    margin: 0;
    line-height: 1.7;
    letter-spacing: 0.03em;
    transition: color 0.8s var(--rit-ease);
}

.ritual-stage__instruction-text strong {
    color: inherit;
}

.ritual-stage__instruction-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(4rem, 10vw, 5.5rem);
    height: clamp(4rem, 10vw, 5.5rem);
    color: #1a1610;
    font-family: var(--font-accent, 'Montserrat', sans-serif);
    font-size: clamp(4rem, 10vw, 5.5rem);
    font-style: normal;
    font-weight: 300;
    line-height: 1;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    transition: transform 0.4s var(--rit-ease), color 0.8s var(--rit-ease);
}

.ritual-stage__instruction-card:hover .ritual-stage__instruction-number {
    transform: scale(1.08);
}


/* Bild in der Stufe */
.ritual-stage__image {
    position: relative;
    width: 100%;
    border-radius: 0.25rem;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    cursor: pointer;
}

/* Immersiver Zoom-Reveal & Click Interaction (120Hz/Zeitlupe)
   Bilder starten mit 30% Zoom (scale 1.3) und zoomen beim Scrollen sanft aus (scale 1.0).
   Klick auf den Bereich toggelt die Skalierung. */
.ritual-stage__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(0.5) contrast(1.1);
    transform: scale(1.3);
    transition: transform 5.5s cubic-bezier(0.12, 0.9, 0.2, 1), filter 1.5s var(--rit-ease);
}

/* Scroll Into View / Aktiviert: Bild zoomt auf Normalgröße zurück */
.ritual-stage__image.in-view img {
    transform: scale(1.0);
}

.ritual-stage:hover .ritual-stage__image img {
    filter: saturate(0.7) contrast(1.05);
}

/* Goldener Bild-Overlay */
.ritual-stage__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
            rgba(196, 161, 105, 0.06) 0%,
            transparent 60%);
    pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════
   D: PARALLAX-INTERLUDE (zwischen Stufen und Botschafterin)
   ═══════════════════════════════════════════════════════════ */

.ritual-interlude {
    position: relative;
    padding: clamp(3rem, 8vw, 5rem) 1.5rem;
    background: rgba(255, 255, 255, 0.40);
    text-align: center;
    overflow: hidden;
}

/* Subtiler atmosphärischer Gold-Glow im Zentrum */
.ritual-interlude--voices .voices-container::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 28rem;
    height: 28rem;
    border-radius: 50%;
    background: radial-gradient(circle,
            rgba(196, 161, 105, 0.06) 0%,
            rgba(196, 161, 105, 0.02) 40%,
            transparent 70%);
    pointer-events: none;
    z-index: 0;
    animation: ritGlowPulse 5s ease-in-out infinite;
}

.ritual-interlude::before,
.ritual-interlude::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-interlude::before {
    top: 0;
}

.ritual-interlude::after {
    bottom: 0;
}

/* ── Voices-Interlude Modifier ──
   Voices-Karussell im Interlude-Kontext:
   Grössere Schrift (übernommen von der ehemaligen Interlude-Quote),
   Atmosphärisches Layout, GPU-optimiert. */

.ritual-interlude--voices .voices-carousel {
    max-width: 42rem;
    height: 16rem;
}

.ritual-interlude--voices .voices-container {
    height: 100%;
}

.ritual-interlude--voices .voices-text {
    font-size: clamp(1.4rem, 5.5vw, 2.25rem);
    font-weight: 200;
    line-height: 1.7;
    letter-spacing: 0.04em;
    max-width: 42rem;
    color: #ffffff;
    opacity: 1;
}

.ritual-interlude--voices .voices-slide.is-active .voices-text {
    letter-spacing: 0.03em;
}

.ritual-interlude--voices .voices-slide.is-leaving .voices-text {
    letter-spacing: 0.08em;
}

.ritual-interlude--voices .voices-dots {
    display: none;
}

/* ── Voices Chevron-Navigation (prev/next) ── */
.voices-nav {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 25;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 50%;
    padding: 0;
    border: none;
    background: transparent;
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    -webkit-tap-highlight-color: transparent;
    transition: opacity 0.4s ease;
    opacity: 0.5;
}

.voices-nav:hover {
    opacity: 1;
}

.voices-nav--prev {
    top: -1.5rem;
}

.voices-nav--next {
    bottom: -1.5rem;
}

/* Doppel-Chevron Icon – identisch mit Scroll-Top-Design */
.voices-nav__icon {
    width: 1.5rem;
    height: 1.5rem;
    stroke: var(--rit-gold, #c4a169);
    stroke-width: 2.5;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 0 0.2rem rgba(196, 161, 105, 0.3));
    transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1);
}

/* Prev: nach links zeigend */
.voices-nav--prev .voices-nav__icon {
    transform: rotate(-90deg);
}

.voices-nav--prev:hover .voices-nav__icon {
    transform: rotate(-90deg) translateY(0.1rem);
}

/* Next: nach rechts zeigend */
.voices-nav--next .voices-nav__icon {
    transform: rotate(-90deg);
}

.voices-nav--next:hover .voices-nav__icon {
    transform: rotate(-90deg) translateY(0.1rem);
}

/* Active/Touch Feedback */
.voices-nav:active {
    opacity: 0.7;
    transform: translateX(-50%) scale(0.88);
    transition-duration: 0.12s;
}

/* ═══════════════════════════════════════════════════════════
   E: MARKENBOTSCHAFTERIN – «Ihr Ritual»
   ═══════════════════════════════════════════════════════════ */

.ritual-ambassador {
    position: relative;
    padding: clamp(5rem, 12vw, 8rem) clamp(1.5rem, 4vw, 2.5rem);
    background: linear-gradient(180deg,
            var(--rit-bg) 0%,
            var(--rit-bg-elevated) 20%,
            var(--rit-bg-elevated) 80%,
            var(--rit-bg) 100%);
    overflow: hidden;
}

.ritual-ambassador::before,
.ritual-ambassador::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-ambassador::before {
    top: 0;
}

.ritual-ambassador::after {
    bottom: 0;
}

.ritual-ambassador__inner {
    max-width: 44rem;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(2rem, 5vw, 3rem);
    text-align: center;
}

.ritual-ambassador__overtitle {
    font-family: var(--font-accent);
    font-size: clamp(0.55rem, 1.6vw, 0.7rem);
    font-weight: 400;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--rit-gold);
    opacity: 0.85;
}

.ritual-ambassador__portrait {
    width: clamp(14rem, 45vw, 20rem);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow:
        0 2rem 5rem rgba(0, 0, 0, 0.5),
        0 0 0 1px rgba(196, 161, 105, 0.1);
}

.ritual-ambassador__portrait img {
    width: 100%;
    height: auto;
    display: block;
    filter: contrast(1.06) brightness(1.02);
}

.ritual-ambassador__quote {
    font-family: var(--font-editorial);
    font-size: clamp(1.15rem, 4vw, 1.55rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.7;
    color: rgba(253, 252, 248, 0.92);
    max-width: 30rem;
    letter-spacing: 0.01em;
}

.ritual-ambassador__sig {
    font-family: var(--font-accent);
    font-size: clamp(0.75rem, 1.9vw, 0.9rem);
    font-weight: 400;
    letter-spacing: 0.25em;
    color: var(--rit-gold);
    opacity: 0.8;
    margin: 0 0 0.3rem;
}

.ritual-ambassador__role {
    font-family: var(--font-accent);
    font-size: clamp(0.55rem, 1.4vw, 0.65rem);
    font-weight: 300;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

/* CTA-Button innerhalb der Ambassador-Section */
.ritual-ambassador__cta {
    margin-top: clamp(1.5rem, 4vw, 2.5rem);
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, #d4b87a 0%, #c4a169 40%, #b8935a 100%);
    color: #1a1610;
    border: 1px solid rgba(160, 130, 75, 0.35);
    border-radius: 0;
    transition: background 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        border-color 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.ritual-ambassador__cta::after {
    display: none;
}

.ritual-ambassador__cta:hover {
    background: linear-gradient(160deg, #dfc68c 0%, #d0ad75 40%, #c4a169 100%);
    color: #12100c;
    border-color: rgba(180, 150, 90, 0.5);
    box-shadow: 0 0.25rem 1.5rem rgba(196, 161, 105, 0.25),
        0 0 3rem rgba(196, 161, 105, 0.1);
}

/* ═══════════════════════════════════════════════════════════
   F: STIMMEN – Edles Statement-Carousel
   Gleiche Cinematic-Choreografie wie Paracelsus,
   aber als eigenständige Sektion mit mehr Raum.
   ═══════════════════════════════════════════════════════════ */

.ritual-voices {
    padding: clamp(6rem, 14vw, 10rem) clamp(1.5rem, 4vw, 2.5rem);
    background: linear-gradient(180deg, var(--rit-bg) 0%, var(--rit-bg-warm) 50%, var(--rit-bg) 100%);
    text-align: center;
    position: relative;
}

.ritual-voices::before,
.ritual-voices::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-voices::before {
    top: 0;
}

.ritual-voices::after {
    bottom: 0;
}

.ritual-voices__header {
    font-family: var(--font-accent);
    font-size: clamp(0.55rem, 1.5vw, 0.65rem);
    font-weight: 400;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--rit-gold);
    margin-bottom: clamp(3rem, 8vw, 5rem);
    opacity: 0.8;
}

/* ── Voices Carousel Container ── */
.voices-carousel {
    position: relative;
    max-width: 38rem;
    margin: 0 auto;
    min-height: clamp(4rem, 12vw, 7rem);
    cursor: pointer;
    overflow: visible;
}

/* Grid-Stack für überlagerte Slides */
.voices-container {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    align-items: center;
    justify-items: center;
    min-height: clamp(3rem, 10vw, 5rem);
    position: relative;
}

/* Subtiler Gold-Aura-Puls bei Reveal */
.voices-container::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, rgba(196, 161, 105, 0.04), transparent 70%);
    opacity: 0;
    transition: opacity 1.2s ease;
    pointer-events: none;
    z-index: 0;
}

.voices-carousel.is-revealing .voices-container::before {
    opacity: 1;
}

/* ── Slide States ── */
.voices-slide {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    z-index: 2;
    padding: clamp(0.75rem, 2vw, 1.25rem);

    /* Cinematic Dolly Zoom: Gross + Unscharf → Normal + Scharf */
    opacity: 0;
    transform: scale(1.15) translate3d(0, 0, 0);
    filter: blur(14px);
    clip-path: inset(0 0 100% 0);

    transition:
        opacity 1.4s cubic-bezier(0.16, 1, 0.3, 1),
        transform 2s cubic-bezier(0.22, 1, 0.36, 1),
        filter 1.8s cubic-bezier(0.16, 1, 0.3, 1) 0.15s,
        clip-path 1.6s cubic-bezier(0.77, 0, 0.175, 1);

}

/* Aktiv: Kristallklar, Normalgrösse */
.voices-slide.is-active {
    opacity: 1;
    transform: scale(1) translate3d(0, 0, 0);
    filter: blur(0);
    clip-path: inset(0 0 0 0);
}

/* Leaving: Wächst leicht und verschwindet */
.voices-slide.is-leaving {
    opacity: 0;
    transform: scale(1.08) translate3d(0, 0, 0);
    filter: blur(10px);
    clip-path: inset(0 0 0 0);
    transition-duration: 1.4s;
    transition-delay: 0s;
}

/* ── Typografie ── */
.voices-text {
    font-family: var(--font-editorial);
    font-size: clamp(1.15rem, 3.5vw, 1.5rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.9;
    color: #ffffff;
    margin: 0;
    letter-spacing: 0.02em;
    max-width: 32rem;

    /* Letter-Spacing Animation */
    transition: letter-spacing 2s cubic-bezier(0.22, 1, 0.36, 1);
}

.voices-slide.is-active .voices-text {
    letter-spacing: 0.01em;
}

.voices-slide.is-leaving .voices-text {
    letter-spacing: 0.06em;
}

/* ── Dot Navigation ── */
.voices-dots {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-top: clamp(1.5rem, 3vw, 2rem);
    position: relative;
    z-index: 20;
    padding: 0.5rem 0;
}

.voices-dot {
    width: 0.4rem;
    height: 0.4rem;
    min-width: 0.4rem;
    min-height: 0.4rem;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.35);
    padding: 0;
    margin: 0;
    cursor: pointer;
    transition: background-color 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        width 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        height 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    position: relative;
    display: block;
    box-sizing: border-box;
}

/* Vergrösserter Touch-Bereich */
.voices-dot::before {
    content: '';
    position: absolute;
    inset: -0.625rem;
}

.voices-dot:hover {
    background: rgba(255, 255, 255, 0.65);
}

/* Aktiver Dot */
.voices-dot.is-active {
    width: 0.5rem;
    height: 0.5rem;
    min-width: 0.5rem;
    min-height: 0.5rem;
    background: var(--rit-gold, #c4a169);
    box-shadow:
        0 0 0.4rem rgba(196, 161, 105, 0.35),
        0 0 0.8rem rgba(196, 161, 105, 0.12);
}

.voices-dot.is-active:hover {
    background: var(--rit-gold, #c4a169);
}

/* ── Pause-State ── */
.voices-carousel.is-paused .voices-dot.is-active {
    animation: voicesDotPulse 2.5s cubic-bezier(0.37, 0, 0.63, 1) infinite;
}

@keyframes voicesDotPulse {

    0%,
    100% {
        box-shadow:
            0 0 0.3rem rgba(196, 161, 105, 0.25),
            0 0 0.6rem rgba(196, 161, 105, 0.08);
    }

    50% {
        box-shadow:
            0 0 0.5rem rgba(196, 161, 105, 0.45),
            0 0 0.9rem rgba(196, 161, 105, 0.18);
    }
}

/* ── Responsive ── */
@media (min-width: 48rem) {
    .voices-text {
        font-size: clamp(1.35rem, 2.5vw, 1.65rem);
    }
}

@media (max-width: 30rem) {
    .voices-dots {
        gap: 0.5rem;
    }
}

/* ═══════════════════════════════════════════════════════════
   G-PRE: CTA – «ZUM GOLD» vor Empfehlung
   ═══════════════════════════════════════════════════════════ */

.ritual-gold-cta {
    padding: clamp(3rem, 8vw, 5rem) 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background: linear-gradient(180deg,
            var(--rit-bg) 0%,
            var(--rit-bg-warm, #0e0d0b) 50%,
            var(--rit-bg) 100%);
}

.ritual-gold-cta::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-gold-cta__btn {
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 3.8rem;
    font-family: var(--font-accent);
    font-size: var(--fs-button);
    font-weight: 500;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    text-decoration: none;
    background: var(--gold);
    color: var(--black);
    border: none;
    border-radius: 0;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(196, 161, 105, 0.15);
    transition:
        background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
        letter-spacing 0.4s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

@media (max-width: 47.99rem) {
    .ritual-gold-cta__btn {
        height: 3.5rem;
    }
}

.ritual-gold-cta__btn::after {
    content: "";
    position: absolute;
    top: 0;
    left: -150%;
    width: 200%;
    height: 100%;
    background: linear-gradient(90deg,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, 0) 30%,
            rgba(255, 255, 255, 0.15) 45%,
            rgba(255, 255, 255, 0.3) 50%,
            rgba(255, 255, 255, 0.15) 55%,
            rgba(255, 255, 255, 0) 70%,
            rgba(255, 255, 255, 0) 100%);
    transform: skewX(-25deg) translate3d(0, 0, 0);
    animation: sovereign-liquid-sweep 8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
    z-index: 1;
    pointer-events: none;
}

.ritual-gold-cta__btn:hover {
    background: var(--gold-dark);
    color: var(--white);
    letter-spacing: 0.3em;
    box-shadow: 0 4px 15px rgba(196, 161, 105, 0.15);
    transform: none;
}

.ritual-gold-cta__btn:active {
    transform: scale(0.98) translateZ(0);
}

@keyframes sovereign-liquid-sweep {
    0% {
        transform: translateX(-100%) skewX(-25deg) translate3d(0, 0, 0);
        opacity: 0;
    }
    15% {
        opacity: 1;
    }
    45% {
        opacity: 1;
    }
    60% {
        transform: translateX(150%) skewX(-25deg) translate3d(0, 0, 0);
        opacity: 0;
    }
    100% {
        transform: translateX(150%) skewX(-25deg) translate3d(0, 0, 0);
        opacity: 0;
    }
}

/* ═══════════════════════════════════════════════════════════
   G: DETAILS – Akkordeon-Hinweise
   ═══════════════════════════════════════════════════════════ */

.ritual-details {
    padding: clamp(3rem, 8vw, 5rem) clamp(1.25rem, 4vw, 2rem);
    background: var(--rit-bg-card);
    position: relative;
}

.ritual-details::before,
.ritual-details::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-details::before {
    top: 0;
}

.ritual-details::after {
    bottom: 0;
}

.ritual-details__header {
    text-align: center;
    margin-bottom: clamp(2rem, 5vw, 3rem);
}

.ritual-details__label {
    font-family: var(--font-accent);
    font-size: clamp(0.55rem, 1.5vw, 0.65rem);
    font-weight: 400;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--rit-gold);
    opacity: 0.8;
}

.ritual-details__grid {
    max-width: 42rem;
    margin: 0 auto;
}

.ritual-detail {
    border-top: 1px solid var(--rit-border);
    padding: clamp(1.25rem, 3vw, 1.75rem) 0;
    transition: background 0.4s ease;
}

.ritual-detail.is-open {
    background: linear-gradient(90deg,
            transparent 0%,
            rgba(196, 161, 105, 0.03) 50%,
            transparent 100%);
}

.ritual-detail:last-child {
    border-bottom: 1px solid var(--rit-border);
}

.ritual-detail__title {
    font-family: var(--font-accent);
    font-size: clamp(0.7rem, 2vw, 0.8rem);
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--rit-text);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    -webkit-tap-highlight-color: transparent;
}

.ritual-detail__chevron {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    stroke: var(--rit-gold);
    stroke-width: 1.5;
    fill: none;
    transition: transform 0.4s var(--rit-ease);
}

.ritual-detail.is-open .ritual-detail__chevron {
    transform: rotate(180deg);
}

.ritual-detail__body {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.5s var(--rit-ease);
}

.ritual-detail.is-open .ritual-detail__body {
    grid-template-rows: 1fr;
}

.ritual-detail__content {
    overflow: hidden;
}

.ritual-detail__text {
    font-family: var(--font-primary);
    font-size: clamp(0.85rem, 2.5vw, 0.95rem);
    font-weight: 300;
    line-height: 1.7;
    color: var(--rit-text-muted);
    padding-top: 1rem;
}

/* ═══════════════════════════════════════════════════════════
   H: CTA – «Beginnen Sie Ihr Ritual»
   ═══════════════════════════════════════════════════════════ */

.ritual-cta {
    padding: clamp(5rem, 14vw, 9rem) 1.5rem;
    background: linear-gradient(180deg,
            var(--rit-bg) 0%,
            #0b0a09 50%,
            var(--rit-bg) 100%);
    text-align: center;
    position: relative;
}

.ritual-cta::before,
.ritual-cta::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-cta::before {
    top: 0;
}

.ritual-cta::after {
    bottom: 0;
}

.ritual-cta__quote {
    font-family: var(--font-editorial);
    font-size: clamp(1.3rem, 5vw, 2rem);
    font-weight: 200;
    font-style: italic;
    color: var(--rit-text);
    margin-bottom: 2rem;
    letter-spacing: 0.03em;
}

.ritual-cta__divider {
    width: 3rem;
    height: 1px;
    background: var(--rit-gold);
    margin: 0 auto 2rem;
    opacity: 0.5;
}

/* CTA-Button: Gefüllter Gold-Pill (identisch mit ZUM GOLD) */
.ritual-cta .btn-primary {
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, #d4b87a 0%, #c4a169 40%, #b8935a 100%);
    color: #1a1610;
    border: 1px solid rgba(160, 130, 75, 0.35);
    border-radius: 0;
    transition: background 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        color 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        border-color 0.6s cubic-bezier(0.16, 1, 0.3, 1),
        box-shadow 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.ritual-cta .btn-primary::after {
    display: none;
}

.ritual-cta .btn-primary:hover {
    background: linear-gradient(160deg, #dfc68c 0%, #d0ad75 40%, #c4a169 100%);
    color: #12100c;
    border-color: rgba(180, 150, 90, 0.5);
    box-shadow: 0 0.25rem 1.5rem rgba(196, 161, 105, 0.25),
        0 0 3rem rgba(196, 161, 105, 0.1);
}

/* ═══════════════════════════════════════════════════════════
   ANIMATIONEN
   ═══════════════════════════════════════════════════════════ */

@keyframes ritFadeUp {
    from {
        opacity: 0;
        transform: translateY(1.5rem);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ritPulse {

    0%,
    100% {
        opacity: 0.3;
    }

    50% {
        opacity: 0.8;
    }
}

@keyframes ritGoldShimmer {

    0%,
    100% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }
}

@keyframes ritGlowPulse {

    0%,
    100% {
        opacity: 0.5;
        transform: translate(-50%, -50%) scale(1);
    }

    50% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1.1);
    }
}

@keyframes ritBtnShimmer {
    0% {
        left: -100%;
    }

    60%,
    100% {
        left: 200%;
    }
}



/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {

    .ritual-hero__overtitle,
    .ritual-hero__title,
    .ritual-hero__divider,
    .ritual-hero__subtitle,
    .ritual-hero__scroll {
        animation: none;
        opacity: 1;
    }

    .ritual-hero__scroll-line {
        animation: none;
        opacity: 0.5;
    }

    .ritual-stage__number {
        animation: none;
    }

    .ritual-stage__image img {
        transition: none;
    }

    .ritual-voice {
        transition: none;
    }

    .ritual-interlude--voices .voices-container::before {
        animation: none;
    }

    .ritual-cta .btn-primary::after {
        animation: none;
    }


}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE: Tablet (ab 48em)
   ═══════════════════════════════════════════════════════════ */

@media (min-width: 48em) {

    .ritual-stage {
        padding: clamp(3rem, 8vw, 5rem) clamp(1.5rem, 4vw, 3rem);
    }

    .ritual-stage__inner {
        grid-template-columns: 1fr;
        gap: clamp(2.5rem, 6vw, 4rem);
        max-width: 44rem;
        margin: 0 auto;
    }

    .ritual-stage__instruction-card,
    .ritual-stage__subtitle {
        max-width: 100%;
    }

    .ritual-stage__image {
        aspect-ratio: 1 / 1;
    }

    /* Ambassador bleibt column (untereinander) auf allen Viewports */

    .ritual-voices__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE: Desktop (ab 64em) – Voices 3-Spalten
   ═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE: Desktop (ab 64em)
   ═══════════════════════════════════════════════════════════ */

@media (min-width: 64em) {

    .ritual-stage__inner {
        gap: 5rem;
    }

    /* ── Desktop: Perfekte vertikale Zentrierung der weissen Sätze ── */
    .ritual-stage__text {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }

    .ritual-stage__title {
        font-size: 2.2rem;
        letter-spacing: 0.2em;
        margin-bottom: 2rem;
    }

    .ritual-stage__instruction-card {
        margin-bottom: 2rem;
    }

    .ritual-stage__subtitle {
        margin-top: 0;
        margin-bottom: 0;
    }

    .ritual-stage__number {
        font-size: 6.5rem;
    }

    .ritual-ambassador__portrait {
        width: 24rem;
    }

    .ritual-ambassador__quote {
        font-size: 1.6rem;
    }

    .ritual-interlude--voices .voices-text {
        font-size: 2.75rem;
    }
}

/* ═══════════════════════════════════════════════════════════
   SCROLL PROGRESS BAR & ACTIVE STATES
   ═══════════════════════════════════════════════════════════ */

/* ── Vertical Scroll Progress ── */
.ritual-stages__progress-container {
    position: absolute;
    top: 12rem;
    bottom: 8rem;
    left: 2rem;
    width: 2px;
    background: rgba(196, 161, 105, 0.1);
    z-index: 5;
    pointer-events: none;
}

.ritual-stages__progress-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, var(--rit-gold-dark) 0%, var(--rit-gold) 50%, var(--rit-gold-light) 100%);
    transform: scaleY(0);
    transform-origin: top center;
    box-shadow: 0 0 10px rgba(196, 161, 105, 0.5);
    will-change: transform;
}

.ritual-stage__progress-indicator {
    position: absolute;
    left: 2rem;
    top: 4.5rem;
    /* Aligns with the large number on mobile */
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 50%;
    background: var(--rit-bg-card);
    border: 2px solid var(--rit-border);
    z-index: 10;
    transform: translate(-50%, -50%) scale(0.8);
    transition: background-color 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.6s cubic-bezier(0.22, 1, 0.36, 1);
    box-shadow: 0 0 0 rgba(196, 161, 105, 0);
    pointer-events: none;
}

.ritual-stage__progress-indicator.is-active {
    background: var(--rit-gold);
    border-color: var(--rit-gold-light);
    transform: translate(-50%, -50%) scale(1.1);
    box-shadow: 0 0 12px var(--rit-gold);
}

/* Active Step Glow State */
.ritual-stage.is-stage-active .ritual-stage__number {
    color: var(--rit-gold);
    text-shadow: 0 0 15px rgba(196, 161, 105, 0.35);
    transition: color 0.8s var(--rit-ease), text-shadow 0.8s var(--rit-ease);
}

.ritual-stage.is-stage-active .ritual-stage__title {
    background: linear-gradient(135deg,
            var(--rit-gold-light) 0%,
            #ffffff 50%,
            var(--rit-gold-light) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ═══════════════════════════════════════════════════════════
   I: PERSÖNLICHE BERATUNG – «Die Synergie»
   Minimalistisch, wissenschaftlich fundiert, edel
   ═══════════════════════════════════════════════════════════ */

.ritual-consulting {
    padding: clamp(5rem, 12vw, 8rem) clamp(1.5rem, 5vw, 3rem);
    background: linear-gradient(180deg, var(--rit-bg) 0%, var(--rit-bg-warm) 100%);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.ritual-consulting::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg,
            transparent 5%,
            rgba(196, 161, 105, 0.3) 25%,
            rgba(196, 161, 105, 0.5) 50%,
            rgba(196, 161, 105, 0.3) 75%,
            transparent 95%);
}

.ritual-consulting__inner {
    max-width: 46rem;
    margin: 0 auto;
    border: 1px solid var(--rit-border);
    background: rgba(26, 24, 22, 0.4);
    padding: clamp(3rem, 8vw, 5rem) clamp(2rem, 6vw, 4rem);
    border-radius: 0.5rem;
    box-shadow:
        0 2rem 4rem rgba(0, 0, 0, 0.4),
        inset 0 0 20px rgba(196, 161, 105, 0.03);
    backdrop-filter: blur(10px);
}

.ritual-consulting__label {
    font-family: var(--font-accent);
    font-size: clamp(0.55rem, 1.5vw, 0.65rem);
    font-weight: 400;
    letter-spacing: 0.4em;
    text-transform: uppercase;
    color: var(--rit-gold);
    margin-bottom: 1.5rem;
    opacity: 0.85;
}

.ritual-consulting__title {
    font-family: var(--font-editorial);
    font-size: clamp(1.75rem, 6vw, 2.75rem);
    font-weight: 200;
    letter-spacing: 0.08em;
    color: var(--rit-text);
    text-transform: uppercase;
    margin: 0 0 1.5rem;
    line-height: 1.2;
}

.ritual-consulting__divider {
    width: 3.5rem;
    height: 1px;
    background: var(--rit-gold);
    margin: 0 auto 2rem;
    opacity: 0.6;
}

.ritual-consulting__text {
    font-family: var(--font-primary);
    font-size: clamp(0.9rem, 2.8vw, 1.05rem);
    font-weight: 300;
    line-height: 1.85;
    color: var(--rit-text-muted);
    max-width: 34rem;
    margin: 0 auto 3rem;
    letter-spacing: 0.015em;
}

.ritual-consulting__cta {
    display: inline-block;
    position: relative;
    overflow: hidden;
    background: transparent;
    color: var(--rit-gold-light);
    border: 1px solid var(--rit-gold-dark);
    border-radius: 0;
    padding: 1.1rem 2.8rem;
    font-size: 0.75rem;
    font-family: var(--font-accent);
    letter-spacing: 0.25em;
    font-weight: 400;
    text-transform: uppercase;
    transition: background 0.6s var(--rit-ease),
        color 0.6s var(--rit-ease),
        border-color 0.6s var(--rit-ease),
        box-shadow 0.6s var(--rit-ease);
    box-shadow: 0 0 0 rgba(196, 161, 105, 0);
    text-decoration: none;
}

.ritual-consulting__cta:hover {
    background: linear-gradient(160deg, #d4b87a 0%, #c4a169 40%, #b8935a 100%);
    color: #1a1610;
    border-color: var(--rit-gold-light);
    box-shadow: 0 0.5rem 2rem rgba(196, 161, 105, 0.2),
        0 0 4rem rgba(196, 161, 105, 0.05);
}

/* ── Tablet / Desktop Responsive Progress ── */
@media (min-width: 48em) {
    .ritual-stages__progress-container {
        left: calc(50% - 24rem);
        transform: translateX(-50%);
    }

    .ritual-stage__progress-indicator {
        left: calc(50% - 24rem);
        top: 4.5rem;
    }
}

/* Hilfsklassen für Schriftstärken im Ritual-Protokoll, um Inline-CSS zu vermeiden */
.font-weight-800 {
    font-weight: 800 !important;
}

.font-weight-900 {
    font-weight: 900 !important;
}