/* =============================================================================
   AuraHarmony — Nocturnal Resonance Design System
   Phase 1: Foundation
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Self-hosted Fonts (DSGVO-konform — kein externer Google-Fonts-Request)
   Lizenz: SIL Open Font License — siehe assets/fonts/*-LICENSE.txt
   font-display: swap — Fallback-Font wird sofort gerendert, dann nahtlos getauscht
   unicode-range: Browser holt nur das Subset, das die Seite wirklich braucht
   ----------------------------------------------------------------------------- */

/* Inter — Body Font */
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/inter-latin-400.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/inter-latin-ext-400.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/inter-latin-500.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/inter-latin-ext-500.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/inter-latin-600.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/inter-latin-ext-600.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Manrope — Display Font */
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/manrope-latin-400.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/manrope-latin-ext-400.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/manrope-latin-500.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('../fonts/manrope-latin-ext-500.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/manrope-latin-600.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('../fonts/manrope-latin-ext-600.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('../fonts/manrope-latin-700.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Manrope';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('../fonts/manrope-latin-ext-700.woff2') format('woff2');
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* -----------------------------------------------------------------------------
   Design Tokens (CSS Custom Properties)
   ----------------------------------------------------------------------------- */
:root {
    /* Surfaces (aus DESIGN.md) */
    --ah-surface:                  #11131b;
    --ah-surface-bright:           #373941;
    --ah-surface-container-lowest: #0c0e15;
    --ah-surface-container-low:    #191b23;
    --ah-surface-container:        #1d1f27;
    --ah-surface-container-high:   #282a32;
    --ah-surface-container-highest:#33343d;

    /* Text */
    --ah-on-surface:           #e1e1ed;
    --ah-on-surface-variant:   #ccc3d8;
    --ah-on-surface-muted:     #958da1;

    /* Primary (Soft Violet) */
    --ah-primary:              #d1bcff;
    --ah-primary-container:    #8a4fff;
    --ah-on-primary:           #3d008f;
    --ah-on-primary-container: #ffffff;

    /* Secondary (Subtle Indigo) */
    --ah-secondary:            #bac3ff;
    --ah-secondary-container:  #2c3ea3;

    /* Tertiary (Luminous Cyan) — für aktive Frequenzen */
    --ah-tertiary:             #00dbe7;
    --ah-tertiary-container:   #00838a;

    /* Outlines */
    --ah-outline:              #958da1;
    --ah-outline-variant:      #4a4455;

    /* Gradients */
    --ah-gradient-primary:     linear-gradient(135deg, #8a4fff 0%, #5800c8 100%);
    --ah-gradient-glow:        radial-gradient(circle, rgba(138, 79, 255, 0.25) 0%, transparent 70%);

    /* Spacing-Skala (8px-Raster) */
    --ah-space-1:  8px;
    --ah-space-2: 16px;
    --ah-space-3: 24px;
    --ah-space-4: 32px;
    --ah-space-5: 40px;
    --ah-space-6: 48px;
    --ah-space-8: 64px;
    --ah-space-10: 80px;
    --ah-space-12: 96px;

    /* Radien */
    --ah-radius-sm:   4px;
    --ah-radius:      8px;
    --ah-radius-md:  12px;
    --ah-radius-lg:  16px;
    --ah-radius-xl:  24px;
    --ah-radius-pill: 9999px;

    /* Schriftarten */
    --ah-font-display: 'Manrope', system-ui, -apple-system, sans-serif;
    --ah-font-body:    'Inter', system-ui, -apple-system, sans-serif;

    /* Effekte */
    --ah-blur:        20px;
    --ah-shadow-glow: 0 8px 24px rgba(138, 79, 255, 0.20);
    --ah-shadow-card: 0 4px 24px rgba(0, 0, 0, 0.4);

    /* Layout */
    --ah-container-max: 1200px;
    --ah-nav-height:    72px;
}

/* -----------------------------------------------------------------------------
   Reset / Base
   ----------------------------------------------------------------------------- */
* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: var(--ah-nav-height);
}

body {
    margin: 0;
    font-family: var(--ah-font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--ah-on-surface);
    background-color: var(--ah-surface);
    background-image:
        radial-gradient(ellipse at top left,  rgba(138, 79, 255, 0.06) 0%, transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(0, 219, 231, 0.04) 0%, transparent 50%);
    background-attachment: fixed;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

a {
    color: var(--ah-primary);
    text-decoration: none;
    transition: color 0.15s ease;
}

a:hover {
    color: var(--ah-tertiary);
}

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

main {
    min-height: 60vh;
    padding-top: var(--ah-nav-height);
}

/* -----------------------------------------------------------------------------
   Typografie
   ----------------------------------------------------------------------------- */
.ah-display {
    font-family: var(--ah-font-display);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 var(--ah-space-3);
    color: var(--ah-on-surface);
}

.ah-h1 {
    font-family: var(--ah-font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.015em;
    margin: 0 0 var(--ah-space-3);
}

.ah-h2 {
    font-family: var(--ah-font-display);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: -0.01em;
    margin: 0 0 var(--ah-space-2);
}

.ah-eyebrow {
    display: inline-block;
    font-family: var(--ah-font-body);
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--ah-primary);
    margin-bottom: var(--ah-space-3);
    position: relative;
    padding-left: 3rem;
}

.ah-eyebrow::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 2.25rem;
    height: 1px;
    background: var(--ah-primary);
}

.ah-lead {
    font-size: 1.125rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-4);
    max-width: 56ch;
}

/* -----------------------------------------------------------------------------
   Container & Sections
   ----------------------------------------------------------------------------- */
.container {
    width: 100%;
    max-width: var(--ah-container-max);
    margin: 0 auto;
    padding: 0 var(--ah-space-3);
}

.ah-section {
    padding: var(--ah-space-10) 0;
}

.ah-section--hero {
    padding-top: var(--ah-space-8);
    padding-bottom: var(--ah-space-12);
    position: relative;
}

.ah-section--centered {
    padding: var(--ah-space-12) 0;
    text-align: center;
}

.ah-section--legal {
    padding: var(--ah-space-8) 0;
    max-width: 800px;
    margin: 0 auto;
}

/* -----------------------------------------------------------------------------
   Navigation
   ----------------------------------------------------------------------------- */
.ah-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--ah-nav-height);
    background: rgba(17, 19, 27, 0.7);
    backdrop-filter: blur(var(--ah-blur));
    -webkit-backdrop-filter: blur(var(--ah-blur));
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    z-index: 1000;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.ah-nav.is-scrolled {
    background: rgba(17, 19, 27, 0.92);
    border-bottom-color: rgba(255, 255, 255, 0.10);
}

/*
 * Der Bootstrap-`.container` innerhalb der Nav hat keine eigene Höhe.
 * Damit align-items: center auf .ah-nav__inner greift, muss die Höhe
 * über die Container-Kette nach unten propagieren.
 */
.ah-nav > .container {
    height: 100%;
}

.ah-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    gap: var(--ah-space-3);
}

.ah-nav__brand {
    display: flex;
    align-items: center;
    gap: var(--ah-space-1);
    color: var(--ah-on-surface);
    font-family: var(--ah-font-display);
    font-weight: 700;
    font-size: 1.125rem;
    letter-spacing: -0.01em;
}

.ah-nav__brand:hover {
    color: var(--ah-on-surface);
}

.ah-nav__brand-mark {
    color: var(--ah-primary);
    display: inline-flex;
}

.ah-nav__menu {
    display: flex;
    align-items: center;
    gap: var(--ah-space-4);
    flex: 1;
    justify-content: flex-end;
}

.ah-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: var(--ah-space-3);
    align-items: center;
}

.ah-nav__link {
    color: var(--ah-on-surface-variant);
    font-size: 0.9375rem;
    font-weight: 500;
    padding: var(--ah-space-1) 0;
    position: relative;
    transition: color 0.15s ease;
}

.ah-nav__link::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--ah-primary);
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.2s ease;
}

.ah-nav__link:hover,
.ah-nav__link.is-active,
.ah-nav__link.is-section-active {
    color: var(--ah-on-surface);
}

.ah-nav__link:hover::after,
.ah-nav__link.is-active::after,
.ah-nav__link.is-section-active::after {
    transform: scaleX(1);
}

.ah-nav__link.is-section-active::after {
    background: var(--ah-tertiary);
}

@media (prefers-reduced-motion: reduce) {
    .ah-nav__link::after { transition: none; }
}

.ah-nav__actions {
    display: flex;
    align-items: center;
    gap: var(--ah-space-2);
}

.ah-nav__toggle {
    display: none;
    background: transparent;
    border: 0;
    width: 40px;
    height: 40px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 4px;
    cursor: pointer;
}

.ah-nav__toggle span {
    width: 22px;
    height: 2px;
    background: var(--ah-on-surface);
    border-radius: 1px;
    transition: transform 0.2s ease;
}

@media (max-width: 991px) {
    .ah-nav__toggle {
        display: flex;
    }
    .ah-nav__menu {
        position: absolute;
        top: var(--ah-nav-height);
        left: 0;
        right: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        background: var(--ah-surface-container);
        border-bottom: 1px solid var(--ah-outline-variant);
        padding: var(--ah-space-2);
        display: none;
    }
    .ah-nav__menu.is-open {
        display: flex;
    }
    .ah-nav__list {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
    }
    .ah-nav__link {
        padding: var(--ah-space-2);
        display: block;
    }
    .ah-nav__actions {
        padding: var(--ah-space-2);
        justify-content: space-between;
        border-top: 1px solid var(--ah-outline-variant);
        margin-top: var(--ah-space-2);
    }
}

/* -----------------------------------------------------------------------------
   Sprachwechsler — Bootstrap-frei
   ----------------------------------------------------------------------------- */
.ah-lang {
    position: relative;
}

.ah-lang__toggle {
    background: transparent;
    border: 1px solid var(--ah-outline-variant);
    color: var(--ah-on-surface-variant);
    border-radius: var(--ah-radius-pill);
    padding: 0.4rem 0.85rem;
    font-size: 0.8125rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease;
}

.ah-lang__toggle:hover {
    border-color: var(--ah-primary);
    color: var(--ah-on-surface);
}

.ah-lang__caret {
    font-size: 0.7rem;
    opacity: 0.7;
    transition: transform 0.2s ease;
}

.ah-lang__toggle[aria-expanded="true"] .ah-lang__caret {
    transform: rotate(180deg);
}

.ah-lang__menu {
    position: absolute;
    top: calc(100% + 0.4rem);
    right: 0;
    min-width: 160px;
    background: var(--ah-surface-container-high);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius);
    padding: 0.4rem;
    box-shadow: var(--ah-shadow-card);
    list-style: none;
    margin: 0;
    z-index: 100;
    display: none;
}

.ah-lang.is-open .ah-lang__menu {
    display: block;
}

.ah-lang__menu li {
    list-style: none;
}

.ah-lang__item {
    display: block;
    color: var(--ah-on-surface-variant);
    border-radius: var(--ah-radius-sm);
    padding: 0.5rem 0.85rem;
    font-size: 0.875rem;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.ah-lang__item:hover {
    background: var(--ah-surface-container-highest);
    color: var(--ah-on-surface);
}

.ah-lang__item.is-active {
    background: rgba(209, 188, 255, 0.10);
    color: var(--ah-primary);
}

@media (prefers-reduced-motion: reduce) {
    .ah-lang__caret { transition: none; }
}

/* -----------------------------------------------------------------------------
   Buttons
   ----------------------------------------------------------------------------- */
.ah-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.5rem;
    border-radius: var(--ah-radius-pill);
    font-family: var(--ah-font-body);
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1;
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
    text-decoration: none;
    white-space: nowrap;
}

.ah-btn--primary {
    background: var(--ah-gradient-primary);
    color: #fff;
    box-shadow: var(--ah-shadow-glow);
}

.ah-btn--primary:hover {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 12px 32px rgba(138, 79, 255, 0.35);
}

.ah-btn--ghost {
    background: transparent;
    color: var(--ah-on-surface);
    border-color: var(--ah-outline-variant);
}

.ah-btn--ghost:hover {
    color: var(--ah-on-surface);
    border-color: var(--ah-primary);
    background: rgba(209, 188, 255, 0.05);
}

.ah-btn--sm {
    padding: 0.55rem 1rem;
    font-size: 0.8125rem;
}

/* -----------------------------------------------------------------------------
   Hero-Stub (Phase 1 — wird in Phase 2 ersetzt)
   ----------------------------------------------------------------------------- */
.ah-hero-stub {
    padding: var(--ah-space-8) 0;
    max-width: 720px;
}

.ah-hero-stub__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ah-space-2);
    margin-top: var(--ah-space-4);
}

.ah-price-note {
    margin-top: var(--ah-space-3);
    color: var(--ah-tertiary);
    font-size: 0.875rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

/* -----------------------------------------------------------------------------
   Status-Box (Phase 1 Debug — wird in Phase 2 entfernt)
   ----------------------------------------------------------------------------- */
.ah-status {
    margin-top: var(--ah-space-6);
    padding: var(--ah-space-3) var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    max-width: 720px;
}

.ah-status__title {
    color: var(--ah-tertiary);
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-2);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ah-status__list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--ah-space-2);
    font-size: 0.875rem;
    color: var(--ah-on-surface-variant);
}

.ah-status__list li {
    padding: 0.25rem 0;
}

.ah-status__list code {
    background: var(--ah-surface-container-high);
    padding: 0.15rem 0.4rem;
    border-radius: var(--ah-radius-sm);
    font-size: 0.8125rem;
    color: var(--ah-primary);
}

.ah-status__hint {
    font-size: 0.8125rem;
    color: var(--ah-on-surface-muted);
    margin: 0;
}

/* -----------------------------------------------------------------------------
   404
   ----------------------------------------------------------------------------- */
.ah-404 {
    text-align: center;
    max-width: 520px;
    margin: 0 auto;
}

.ah-404__code {
    font-family: var(--ah-font-display);
    font-size: clamp(5rem, 12vw, 8rem);
    font-weight: 700;
    line-height: 1;
    background: var(--ah-gradient-primary);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: var(--ah-space-3);
}

/* -----------------------------------------------------------------------------
   Legal-Content
   ----------------------------------------------------------------------------- */
.ah-legal-content h2 {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin-top: var(--ah-space-5);
    margin-bottom: var(--ah-space-2);
}

.ah-legal-content p {
    color: var(--ah-on-surface-variant);
}

.ah-todo {
    margin-top: var(--ah-space-5);
    padding: var(--ah-space-2);
    background: rgba(255, 180, 171, 0.08);
    border-left: 3px solid #ffb4ab;
    border-radius: var(--ah-radius-sm);
    font-size: 0.875rem;
}

/* -----------------------------------------------------------------------------
   Footer
   ----------------------------------------------------------------------------- */
.ah-footer {
    margin-top: var(--ah-space-12);
    padding: var(--ah-space-8) 0 var(--ah-space-4);
    background: var(--ah-surface-container-lowest);
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-footer__top {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--ah-space-6);
    margin-bottom: var(--ah-space-6);
}

@media (max-width: 768px) {
    .ah-footer__top {
        grid-template-columns: 1fr;
    }
}

.ah-footer__logo {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ah-on-surface);
    display: inline-block;
    margin-bottom: var(--ah-space-2);
}

.ah-footer__tagline {
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-2);
    max-width: 320px;
}

.ah-footer__made {
    color: var(--ah-on-surface-muted);
    font-size: 0.875rem;
    margin: 0;
}

.ah-footer__cols {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ah-space-4);
}

@media (max-width: 768px) {
    .ah-footer__cols {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ah-footer__col-title {
    font-family: var(--ah-font-display);
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ah-on-surface-muted);
    margin: 0 0 var(--ah-space-2);
}

.ah-footer__links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ah-footer__links li {
    color: var(--ah-on-surface-variant);
    font-size: 0.875rem;
    line-height: 1.8;
}

.ah-footer__links a {
    color: var(--ah-on-surface-variant);
}

.ah-footer__links a:hover {
    color: var(--ah-primary);
}

.ah-footer__social {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ah-footer__social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-pill);
    color: var(--ah-on-surface-variant);
    font-size: 1rem;
    transition: all 0.2s ease;
}

.ah-footer__social a:hover {
    border-color: var(--ah-primary);
    color: var(--ah-primary);
}

.ah-footer__bottom {
    padding-top: var(--ah-space-3);
    border-top: 1px solid var(--ah-outline-variant);
    color: var(--ah-on-surface-muted);
    font-size: 0.8125rem;
}

.ah-footer__bottom p {
    margin: 0;
}

/* =============================================================================
   PHASE 2 — Hero
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Hero — Wrapper
   ----------------------------------------------------------------------------- */
.ah-hero {
    position: relative;
    padding: var(--ah-space-6) 0 var(--ah-space-8);
    overflow: hidden;
    isolation: isolate;
}

@media (min-width: 992px) {
    .ah-hero {
        padding: var(--ah-space-8) 0 var(--ah-space-10);
    }
}

/* -----------------------------------------------------------------------------
   Hero — Hintergrund (Glow-Layers, Sterne, Wellen-SVG)
   ----------------------------------------------------------------------------- */
.ah-hero__background {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
}

.ah-hero__glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(120px);
    opacity: 0.6;
}

.ah-hero__glow--purple {
    width: 700px;
    height: 700px;
    top: -150px;
    right: -100px;
    background: radial-gradient(circle, rgba(138, 79, 255, 0.45) 0%, transparent 70%);
    animation: ah-glow-pulse 12s ease-in-out infinite;
}

.ah-hero__glow--cyan {
    width: 500px;
    height: 500px;
    bottom: -100px;
    left: -150px;
    background: radial-gradient(circle, rgba(0, 219, 231, 0.20) 0%, transparent 70%);
    animation: ah-glow-pulse 14s ease-in-out infinite reverse;
}

@keyframes ah-glow-pulse {
    0%, 100% { transform: scale(1)   translate(0, 0); opacity: 0.5; }
    50%      { transform: scale(1.1) translate(20px, -10px); opacity: 0.7; }
}

/* Sterne als CSS-Pattern (extrem leichtgewichtig) */
.ah-hero__stars {
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(1px 1px at 20% 30%,  rgba(255,255,255,0.6),  transparent),
        radial-gradient(1px 1px at 60% 70%,  rgba(255,255,255,0.4),  transparent),
        radial-gradient(1px 1px at 80% 20%,  rgba(255,255,255,0.5),  transparent),
        radial-gradient(1px 1px at 30% 80%,  rgba(255,255,255,0.3),  transparent),
        radial-gradient(1px 1px at 90% 60%,  rgba(255,255,255,0.5),  transparent),
        radial-gradient(1px 1px at 50% 15%,  rgba(255,255,255,0.4),  transparent),
        radial-gradient(1px 1px at 15% 55%,  rgba(255,255,255,0.4),  transparent),
        radial-gradient(1px 1px at 75% 90%,  rgba(255,255,255,0.3),  transparent);
    opacity: 0.5;
}

/* Wellen-SVG */
.ah-hero__waves {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0.7;
}

.ah-hero__wave-path {
    transform-origin: center;
}

.ah-hero__wave-path--1 { animation: ah-wave-flow 8s ease-in-out infinite; }
.ah-hero__wave-path--2 { animation: ah-wave-flow 10s ease-in-out infinite reverse; }
.ah-hero__wave-path--3 { animation: ah-wave-flow 12s ease-in-out infinite; }

@keyframes ah-wave-flow {
    0%, 100% { transform: translateY(0)    scaleY(1); }
    50%      { transform: translateY(-15px) scaleY(1.2); }
}

/* -----------------------------------------------------------------------------
   Hero — Grid-Layout
   ----------------------------------------------------------------------------- */
.ah-hero__grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: var(--ah-space-6);
    align-items: center;
    padding-top: var(--ah-space-4);
}

@media (max-width: 991px) {
    .ah-hero__grid {
        grid-template-columns: 1fr;
        gap: var(--ah-space-6);
        text-align: center;
    }
}

/* -----------------------------------------------------------------------------
   Hero — Content (links)
   ----------------------------------------------------------------------------- */
.ah-hero__content {
    animation: ah-fade-up 0.7s ease-out both;
}

.ah-hero__eyebrow {
    margin-bottom: var(--ah-space-3);
}

@media (max-width: 991px) {
    .ah-hero__eyebrow {
        padding-left: 3rem;
    }
}

.ah-hero__headline {
    font-family: var(--ah-font-display);
    font-size: clamp(2.75rem, 6vw, 5rem);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.025em;
    margin: 0 0 var(--ah-space-3);
    color: var(--ah-on-surface);
}

.ah-hero__headline-line {
    display: block;
}

.ah-hero__headline-line--accent {
    background: linear-gradient(135deg, #d1bcff 0%, #8a4fff 50%, #00dbe7 100%);
    background-size: 200% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: ah-gradient-shift 8s ease-in-out infinite;
}

@keyframes ah-gradient-shift {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

.ah-hero__subline {
    font-size: 1.0625rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-4);
    max-width: 56ch;
}

@media (max-width: 991px) {
    .ah-hero__subline {
        margin-left: auto;
        margin-right: auto;
    }
}

.ah-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ah-space-2);
    margin-bottom: var(--ah-space-3);
}

@media (max-width: 991px) {
    .ah-hero__cta {
        justify-content: center;
    }
}

.ah-hero__price-note {
    margin: 0 0 var(--ah-space-5);
    color: var(--ah-tertiary);
    font-size: 0.875rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

@media (max-width: 991px) {
    .ah-hero__price-note {
        justify-content: center;
        display: flex;
    }
}

/* -----------------------------------------------------------------------------
   Hero — Feature-Pills
   ----------------------------------------------------------------------------- */
.ah-hero__features {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
    max-width: 560px;
}

@media (max-width: 991px) {
    .ah-hero__features {
        margin-left: auto;
        margin-right: auto;
    }
}

@media (max-width: 575px) {
    .ah-hero__features {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ah-hero__feature {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 0.85rem;
    border-radius: var(--ah-radius);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--ah-outline-variant);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: var(--ah-on-surface-variant);
    font-size: 0.8125rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.ah-hero__feature:hover {
    border-color: var(--ah-primary);
    background: rgba(209, 188, 255, 0.05);
    color: var(--ah-on-surface);
    transform: translateY(-1px);
}

.ah-hero__feature i {
    color: var(--ah-primary);
    font-size: 0.95rem;
}

/* -----------------------------------------------------------------------------
   Hero — Phone (rechts)
   ----------------------------------------------------------------------------- */
.ah-hero__visual {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    animation: ah-fade-up 0.8s 0.15s ease-out both;
}

.ah-hero__phone-wrap {
    position: relative;
    width: 100%;
    max-width: 400px;
    margin-right: var(--ah-space-3);
}

@media (max-width: 991px) {
    .ah-hero__phone-wrap {
        margin-right: 0;
        max-width: 360px;
    }
}

.ah-hero__phone-glow {
    position: absolute;
    inset: -10%;
    background: radial-gradient(
        ellipse at center,
        rgba(138, 79, 255, 0.4) 0%,
        rgba(138, 79, 255, 0.15) 30%,
        transparent 60%
    );
    filter: blur(60px);
    z-index: 0;
    animation: ah-phone-glow-pulse 6s ease-in-out infinite;
}

@keyframes ah-phone-glow-pulse {
    0%, 100% { opacity: 0.7; transform: scale(1); }
    50%      { opacity: 1;   transform: scale(1.05); }
}

.ah-hero__phone {
    position: relative;
    z-index: 1;
    width: 100%;
    height: auto;
    filter: drop-shadow(0 30px 60px rgba(0, 0, 0, 0.5));
    animation: ah-phone-float 6s ease-in-out infinite;
}

@keyframes ah-phone-float {
    0%, 100% { transform: translateY(0)    rotate(0deg); }
    50%      { transform: translateY(-12px) rotate(0.5deg); }
}

/* -----------------------------------------------------------------------------
   Hero — Floating Pills um das Phone
   ----------------------------------------------------------------------------- */
.ah-hero__pill {
    position: absolute;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.95rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(29, 31, 39, 0.85);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(209, 188, 255, 0.25);
    color: var(--ah-on-surface);
    font-size: 0.8125rem;
    font-weight: 600;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3),
                0 0 20px rgba(138, 79, 255, 0.15);
    white-space: nowrap;
}

.ah-hero__pill i {
    color: var(--ah-primary);
    font-size: 0.95rem;
}

.ah-hero__pill--1 {
    top: 8%;
    right: -5%;
    animation: ah-pill-float-1 7s ease-in-out infinite;
}

.ah-hero__pill--2 {
    top: 42%;
    left: -10%;
    animation: ah-pill-float-2 8s ease-in-out infinite;
}

.ah-hero__pill--2 i {
    color: var(--ah-tertiary);
}

.ah-hero__pill--3 {
    bottom: 20%;
    right: -3%;
    animation: ah-pill-float-3 6.5s ease-in-out infinite;
}

@keyframes ah-pill-float-1 {
    0%, 100% { transform: translate(0, 0); }
    50%      { transform: translate(-6px, -10px); }
}

@keyframes ah-pill-float-2 {
    0%, 100% { transform: translate(0, 0); }
    50%      { transform: translate(8px, 12px); }
}

@keyframes ah-pill-float-3 {
    0%, 100% { transform: translate(0, 0); }
    50%      { transform: translate(-8px, 8px); }
}

@media (max-width: 575px) {
    .ah-hero__pill { font-size: 0.75rem; padding: 0.4rem 0.75rem; }
    .ah-hero__pill--1 { right: -5%; }
    .ah-hero__pill--2 { left: -8%; }
    .ah-hero__pill--3 { right: -3%; }
}

/* -----------------------------------------------------------------------------
   Hero — Stat-Bar
   ----------------------------------------------------------------------------- */
.ah-hero__statbar {
    margin-top: var(--ah-space-8);
    padding: var(--ah-space-3) var(--ah-space-4);
    border-radius: var(--ah-radius-lg);
    background: rgba(29, 31, 39, 0.6);
    border: 1px solid var(--ah-outline-variant);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    display: grid;
    grid-template-columns: 1.2fr 2fr;
    align-items: center;
    gap: var(--ah-space-4);
    animation: ah-fade-up 0.8s 0.3s ease-out both;
}

@media (max-width: 991px) {
    .ah-hero__statbar {
        grid-template-columns: 1fr;
        gap: var(--ah-space-3);
        padding: var(--ah-space-3);
    }
}

.ah-hero__quote {
    display: flex;
    align-items: center;
    gap: var(--ah-space-2);
}

.ah-hero__quote-icon {
    flex-shrink: 0;
    color: var(--ah-primary);
    display: inline-flex;
}

.ah-hero__quote-text p {
    font-family: var(--ah-font-display);
    font-style: italic;
    font-size: 0.9375rem;
    line-height: 1.4;
    color: var(--ah-on-surface);
    margin: 0;
}

.ah-hero__quote-author {
    font-family: var(--ah-font-body);
    font-style: normal;
    font-size: 0.75rem;
    color: var(--ah-on-surface-muted);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.ah-hero__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

@media (max-width: 575px) {
    .ah-hero__stats {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--ah-space-2);
    }
}

.ah-hero__stat {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.ah-hero__stat i {
    color: var(--ah-primary);
    font-size: 1.5rem;
    flex-shrink: 0;
}

.ah-hero__stat strong {
    display: block;
    font-family: var(--ah-font-display);
    font-size: 1.375rem;
    font-weight: 600;
    line-height: 1;
    color: var(--ah-on-surface);
    margin-bottom: 0.2rem;
}

.ah-hero__stat span {
    font-size: 0.75rem;
    color: var(--ah-on-surface-muted);
    letter-spacing: 0.02em;
}

@media (max-width: 575px) {
    .ah-hero__stat strong { font-size: 1.1rem; }
    .ah-hero__stat span { font-size: 0.7rem; }
    .ah-hero__stat i { font-size: 1.2rem; }
    .ah-hero__stat { gap: 0.5rem; }
}

/* -----------------------------------------------------------------------------
   Hero — Entrance-Animation
   ----------------------------------------------------------------------------- */
@keyframes ah-fade-up {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Reduzierte Animationen respektieren */
@media (prefers-reduced-motion: reduce) {
    .ah-hero__glow--purple,
    .ah-hero__glow--cyan,
    .ah-hero__wave-path--1,
    .ah-hero__wave-path--2,
    .ah-hero__wave-path--3,
    .ah-hero__phone-glow,
    .ah-hero__phone,
    .ah-hero__pill--1,
    .ah-hero__pill--2,
    .ah-hero__pill--3,
    .ah-hero__headline-line--accent,
    .ah-hero__content,
    .ah-hero__visual,
    .ah-hero__statbar {
        animation: none !important;
    }
    .ah-hero__content,
    .ah-hero__visual,
    .ah-hero__statbar {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* -----------------------------------------------------------------------------
   Placeholder für nächste Sektionen
   ----------------------------------------------------------------------------- */
.ah-section--placeholder {
    padding: var(--ah-space-8) 0;
    text-align: center;
    border-top: 1px solid var(--ah-outline-variant);
    margin-top: var(--ah-space-6);
}

.ah-placeholder {
    color: var(--ah-on-surface-muted);
    font-size: 0.9375rem;
    margin: 0;
}

.ah-placeholder i {
    display: block;
    font-size: 1.75rem;
    color: var(--ah-primary);
    margin-bottom: var(--ah-space-1);
}

/* =============================================================================
   PHASE 3 — Sections 2-11
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Section Header (geteilte Komponente)
   ----------------------------------------------------------------------------- */
.ah-section-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--ah-space-8);
}

.ah-section-header .ah-eyebrow {
    padding-left: 3rem;
    padding-right: 3rem;
}

.ah-section-header .ah-eyebrow::before,
.ah-section-header .ah-eyebrow::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 2.25rem;
    height: 1px;
    background: var(--ah-primary);
}

.ah-section-header .ah-eyebrow::before { left: 0; }
.ah-section-header .ah-eyebrow::after  { right: 0; }

.ah-eyebrow--centered {
    padding-left: 3rem;
    padding-right: 3rem;
}

.ah-eyebrow--centered::before,
.ah-eyebrow--centered::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 2.25rem;
    height: 1px;
    background: var(--ah-primary);
}
.ah-eyebrow--centered::before { left: 0; }
.ah-eyebrow--centered::after  { right: 0; }

.ah-section-headline {
    font-family: var(--ah-font-display);
    font-size: clamp(1.75rem, 3.5vw, 2.75rem);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 var(--ah-space-2);
    color: var(--ah-on-surface);
}

.ah-section-subline {
    font-size: 1.0625rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

/* Allgemeine Sektion-Padding-Anpassung */
.ah-section {
    padding: var(--ah-space-10) 0;
    position: relative;
}

@media (max-width: 768px) {
    .ah-section { padding: var(--ah-space-8) 0; }
    .ah-section-header { margin-bottom: var(--ah-space-6); }
}

/* -----------------------------------------------------------------------------
   Section 2 — Three Steps
   ----------------------------------------------------------------------------- */
.ah-section--steps {
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
    counter-reset: steps;
    position: relative;
}

@media (max-width: 768px) {
    .ah-steps { grid-template-columns: 1fr; gap: var(--ah-space-4); }
}

/* Verbindungslinie zwischen Schritten (nur Desktop) */
.ah-steps::before {
    content: '';
    position: absolute;
    top: 60px;
    left: 16.66%;
    right: 16.66%;
    height: 1px;
    background: linear-gradient(to right,
        transparent 0%,
        var(--ah-primary) 20%,
        var(--ah-primary) 80%,
        transparent 100%);
    opacity: 0.3;
    z-index: 0;
}

@media (max-width: 768px) {
    .ah-steps::before { display: none; }
}

.ah-step {
    position: relative;
    z-index: 1;
    padding: var(--ah-space-3);
    text-align: center;
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-step:hover {
    transform: translateY(-4px);
    border-color: var(--ah-primary);
}

.ah-step__number {
    font-family: var(--ah-font-display);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--ah-primary);
    margin-bottom: var(--ah-space-2);
}

.ah-step__icon {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--ah-space-2);
    border-radius: 50%;
    background: var(--ah-gradient-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.5rem;
    box-shadow: 0 8px 24px rgba(138, 79, 255, 0.3);
}

.ah-step__title {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-step__description {
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

/* -----------------------------------------------------------------------------
   Section 3 — Use Cases
   ----------------------------------------------------------------------------- */
.ah-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

@media (max-width: 991px) { .ah-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .ah-cards { grid-template-columns: 1fr; } }

.ah-card {
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.ah-card:hover {
    transform: translateY(-4px);
    border-color: var(--ah-primary);
    background: var(--ah-surface-container-high);
}

.ah-card__icon {
    width: 48px;
    height: 48px;
    border-radius: var(--ah-radius);
    background: rgba(209, 188, 255, 0.1);
    border: 1px solid rgba(209, 188, 255, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ah-primary);
    font-size: 1.4rem;
    margin-bottom: var(--ah-space-2);
}

.ah-card__title {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-card__description {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-2);
}

.ah-card__tag {
    display: inline-block;
    padding: 0.25rem 0.65rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(0, 219, 231, 0.1);
    border: 1px solid rgba(0, 219, 231, 0.25);
    color: var(--ah-tertiary);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

/* -----------------------------------------------------------------------------
   Section 4 — Frequency Library
   ----------------------------------------------------------------------------- */
.ah-section--library {
    background:
        radial-gradient(ellipse at top, rgba(138, 79, 255, 0.06) 0%, transparent 50%),
        var(--ah-surface);
}

.ah-library-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

@media (max-width: 991px) { .ah-library-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .ah-library-grid { grid-template-columns: 1fr; } }

.ah-library-card {
    position: relative;
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    overflow: hidden;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-library-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.15;
    transition: opacity 0.3s ease;
}

.ah-library-card--primary::before  { background: var(--ah-primary); }
.ah-library-card--tertiary::before { background: var(--ah-tertiary); }

.ah-library-card:hover {
    transform: translateY(-4px);
}

.ah-library-card:hover::before { opacity: 0.3; }

.ah-library-card--primary:hover  { border-color: var(--ah-primary); }
.ah-library-card--tertiary:hover { border-color: var(--ah-tertiary); }

.ah-library-card__icon {
    position: relative;
    width: 56px;
    height: 56px;
    border-radius: var(--ah-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: var(--ah-space-3);
}

.ah-library-card--primary .ah-library-card__icon {
    background: rgba(209, 188, 255, 0.1);
    border: 1px solid rgba(209, 188, 255, 0.25);
    color: var(--ah-primary);
}

.ah-library-card--tertiary .ah-library-card__icon {
    background: rgba(0, 219, 231, 0.1);
    border: 1px solid rgba(0, 219, 231, 0.25);
    color: var(--ah-tertiary);
}

.ah-library-card__count {
    position: relative;
    font-family: var(--ah-font-body);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ah-on-surface-muted);
    margin-bottom: var(--ah-space-1);
}

.ah-library-card__title {
    position: relative;
    font-family: var(--ah-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-library-card__description {
    position: relative;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

/* -----------------------------------------------------------------------------
   Section 5 — App Tour
   ----------------------------------------------------------------------------- */
.ah-section--app-tour {
    background:
        radial-gradient(ellipse at center top, rgba(138, 79, 255, 0.05) 0%, transparent 50%),
        var(--ah-surface);
}

.ah-app-tour {
    display: flex;
    flex-direction: column;
    gap: var(--ah-space-12);
}

@media (max-width: 768px) {
    .ah-app-tour { gap: var(--ah-space-8); }
}

/* Eine Zeile = ein Tour-Item: Phone + Text nebeneinander */
.ah-app-tour__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ah-space-6);
    align-items: center;
}

@media (max-width: 768px) {
    .ah-app-tour__row {
        grid-template-columns: 1fr;
        gap: var(--ah-space-3);
    }
}

/* Reverse-Modifier: Phone rechts statt links (alternierend) */
.ah-app-tour__row--reverse .ah-app-tour__visual {
    order: 2;
}

@media (max-width: 768px) {
    /* Auf Mobile immer Phone oben — order zurücksetzen */
    .ah-app-tour__row--reverse .ah-app-tour__visual { order: 0; }
}

.ah-app-tour__visual {
    display: flex;
    justify-content: center;
}

.ah-app-tour__content {
    display: flex;
    flex-direction: column;
    gap: var(--ah-space-2);
}

.ah-app-tour__step {
    font-family: var(--ah-font-display);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--ah-primary);
    margin-bottom: 0.4rem;
}

.ah-app-tour__title {
    font-family: var(--ah-font-display);
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.02em;
    margin: 0;
    color: var(--ah-on-surface);
}

.ah-app-tour__description {
    font-size: 1.0625rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0;
    max-width: 460px;
}

.ah-app-tour__tags {
    list-style: none;
    margin: var(--ah-space-2) 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ah-app-tour__tags li {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(0, 219, 231, 0.08);
    border: 1px solid rgba(0, 219, 231, 0.22);
    color: var(--ah-tertiary);
    font-size: 0.8125rem;
    font-weight: 500;
}

/* -----------------------------------------------------------------------------
   Phone-Frame Komponente
   Wraps any 9:19.5 image in an iPhone-like bezel with subtle violet glow.
   ----------------------------------------------------------------------------- */
.ah-phone-frame {
    position: relative;
    width: 100%;
    max-width: 280px;
    aspect-ratio: 9 / 19.5;
    background: linear-gradient(145deg, #2c2c30 0%, #1a1a1c 100%);
    border-radius: 38px;
    padding: 8px;
    box-shadow:
        0 0 0 1.5px rgba(255, 255, 255, 0.04) inset,
        0 30px 60px rgba(0, 0, 0, 0.45),
        0 12px 30px rgba(138, 79, 255, 0.18);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ah-app-tour__row:hover .ah-phone-frame {
    transform: translateY(-4px);
    box-shadow:
        0 0 0 1.5px rgba(255, 255, 255, 0.06) inset,
        0 36px 70px rgba(0, 0, 0, 0.5),
        0 16px 36px rgba(138, 79, 255, 0.28);
}

.ah-phone-frame__screen {
    width: 100%;
    height: 100%;
    border-radius: 30px;
    overflow: hidden;
    background: #000;
    position: relative;
}

.ah-phone-frame__screen picture,
.ah-phone-frame__screen img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (max-width: 575px) {
    .ah-phone-frame {
        max-width: 240px;
        border-radius: 32px;
        padding: 6px;
    }
    .ah-phone-frame__screen { border-radius: 26px; }
}

@media (prefers-reduced-motion: reduce) {
    .ah-phone-frame { transition: none; }
    .ah-app-tour__row:hover .ah-phone-frame { transform: none; }
}


/* -----------------------------------------------------------------------------
   Section 6 — Interactive Audio Demo
   ----------------------------------------------------------------------------- */
.ah-section--demo {
    background:
        radial-gradient(ellipse at center, rgba(0, 219, 231, 0.05) 0%, transparent 60%),
        var(--ah-surface-container-lowest);
    border-top: 1px solid var(--ah-outline-variant);
    border-bottom: 1px solid var(--ah-outline-variant);
}

.ah-demo {
    max-width: 880px;
    margin: 0 auto;
    padding: var(--ah-space-5);
    border-radius: var(--ah-radius-xl);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

@media (max-width: 575px) {
    .ah-demo { padding: var(--ah-space-3); }
}

.ah-demo__visual {
    position: relative;
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container-lowest);
    border: 1px solid var(--ah-outline-variant);
    padding: var(--ah-space-3);
    margin-bottom: var(--ah-space-4);
    overflow: hidden;
}

.ah-demo__canvas {
    display: block;
    width: 100%;
    height: 160px;
}

.ah-demo__display {
    position: absolute;
    bottom: var(--ah-space-3);
    left: var(--ah-space-3);
    right: var(--ah-space-3);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    pointer-events: none;
}

.ah-demo__status {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(17, 19, 27, 0.8);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid var(--ah-outline-variant);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--ah-on-surface-muted);
}

.ah-demo__status[data-state="playing"] {
    color: var(--ah-tertiary);
    border-color: rgba(0, 219, 231, 0.4);
}

.ah-demo__status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--ah-on-surface-muted);
}

.ah-demo__status[data-state="playing"] .ah-demo__status-dot {
    background: var(--ah-tertiary);
    animation: ah-demo-pulse 1.4s ease-in-out infinite;
    box-shadow: 0 0 8px var(--ah-tertiary);
}

@keyframes ah-demo-pulse {
    0%, 100% { opacity: 0.4; }
    50%      { opacity: 1; }
}

.ah-demo__current {
    text-align: right;
    font-family: var(--ah-font-display);
}

.ah-demo__current-hz {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ah-on-surface);
    line-height: 1;
}

.ah-demo__current-label {
    font-size: 0.75rem;
    color: var(--ah-on-surface-muted);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.ah-demo__frequencies {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
    margin-bottom: var(--ah-space-4);
}

@media (max-width: 575px) {
    .ah-demo__frequencies { grid-template-columns: repeat(2, 1fr); }
}

.ah-demo-freq {
    text-align: left;
    padding: var(--ah-space-2);
    border-radius: var(--ah-radius);
    background: var(--ah-surface-container-high);
    border: 1px solid var(--ah-outline-variant);
    color: var(--ah-on-surface-variant);
    cursor: pointer;
    transition: all 0.2s ease;
}

.ah-demo-freq:hover {
    border-color: var(--ah-primary);
    transform: translateY(-2px);
}

.ah-demo-freq[aria-selected="true"] {
    background: linear-gradient(135deg, rgba(138, 79, 255, 0.2) 0%, rgba(0, 219, 231, 0.1) 100%);
    border-color: var(--ah-primary);
    box-shadow: 0 0 24px rgba(138, 79, 255, 0.2);
}

.ah-demo-freq__hz {
    display: block;
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ah-on-surface);
    line-height: 1;
    margin-bottom: 0.2rem;
}

.ah-demo-freq__hz span {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--ah-on-surface-muted);
    margin-left: 0.2rem;
}

.ah-demo-freq__label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--ah-primary);
    margin-bottom: 0.1rem;
}

.ah-demo-freq[aria-selected="true"] .ah-demo-freq__label { color: var(--ah-tertiary); }

.ah-demo-freq__desc {
    display: block;
    font-size: 0.75rem;
    color: var(--ah-on-surface-muted);
    line-height: 1.4;
}

.ah-demo__controls {
    display: flex;
    align-items: center;
    gap: var(--ah-space-3);
    padding: var(--ah-space-2) var(--ah-space-3);
    background: var(--ah-surface-container-lowest);
    border-radius: var(--ah-radius-pill);
    border: 1px solid var(--ah-outline-variant);
}

.ah-demo__play {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--ah-gradient-primary);
    border: 0;
    color: #fff;
    font-size: 1.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.2s ease;
    box-shadow: 0 4px 16px rgba(138, 79, 255, 0.3);
    flex-shrink: 0;
    position: relative;
}

.ah-demo__play:hover {
    transform: scale(1.05);
    box-shadow: 0 8px 24px rgba(138, 79, 255, 0.45);
}

.ah-demo__play .bi-pause-fill { display: none; }
.ah-demo__play.is-playing .bi-play-fill { display: none; }
.ah-demo__play.is-playing .bi-pause-fill { display: block; }

.ah-demo__volume {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.ah-demo__volume-label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--ah-on-surface-variant);
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.ah-demo__volume-label i { color: var(--ah-primary); }

.ah-demo__volume-slider {
    flex: 1;
    height: 4px;
    background: var(--ah-surface-container-high);
    border-radius: 2px;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

.ah-demo__volume-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--ah-primary);
    box-shadow: 0 0 8px rgba(209, 188, 255, 0.5);
    cursor: pointer;
}

.ah-demo__volume-slider::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--ah-primary);
    border: 0;
    box-shadow: 0 0 8px rgba(209, 188, 255, 0.5);
    cursor: pointer;
}

.ah-demo__tip {
    margin: var(--ah-space-3) 0 0;
    text-align: center;
    font-size: 0.8125rem;
    color: var(--ah-on-surface-muted);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    justify-content: center;
}

.ah-demo__tip i { color: var(--ah-tertiary); }

/* -----------------------------------------------------------------------------
   Section 7 — Pricing
   ----------------------------------------------------------------------------- */
.ah-pricing-savings {
    text-align: center;
    margin-bottom: var(--ah-space-6);
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-xl);
    background:
        radial-gradient(ellipse at center, rgba(0, 219, 231, 0.1) 0%, transparent 70%),
        var(--ah-surface-container);
    border: 1px solid rgba(0, 219, 231, 0.25);
}

.ah-pricing-savings__label {
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--ah-tertiary);
    margin-bottom: 0.5rem;
}

.ah-pricing-savings__value {
    font-family: var(--ah-font-display);
    font-size: clamp(2.5rem, 6vw, 4rem);
    font-weight: 700;
    line-height: 1;
    background: linear-gradient(135deg, #d1bcff 0%, #00dbe7 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 0.5rem;
}

.ah-pricing-savings__note {
    font-size: 0.9375rem;
    color: var(--ah-on-surface-variant);
    max-width: 480px;
    margin: 0 auto;
}

.ah-pricing-table {
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    overflow: hidden;
}

.ah-pricing-table__head,
.ah-pricing-table__row {
    display: grid;
    grid-template-columns: 2fr 1.2fr 1fr 1fr;
    align-items: center;
}

.ah-pricing-table__head {
    background: var(--ah-surface-container-high);
    border-bottom: 1px solid var(--ah-outline-variant);
}

.ah-pricing-table__head > div,
.ah-pricing-table__row > div {
    padding: var(--ah-space-2) var(--ah-space-3);
    text-align: center;
}

.ah-pricing-table__head > div:first-child,
.ah-pricing-table__row > div:first-child {
    text-align: left;
    color: var(--ah-on-surface-variant);
    font-size: 0.9375rem;
}

.ah-pricing-table__col--us {
    position: relative;
    background: rgba(138, 79, 255, 0.06);
}

.ah-pricing-table__head .ah-pricing-table__col--us {
    background: rgba(138, 79, 255, 0.12);
}

.ah-pricing-table__brand {
    font-family: var(--ah-font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--ah-on-surface);
    display: block;
}

.ah-pricing-table__col--us .ah-pricing-table__brand {
    color: var(--ah-primary);
}

.ah-pricing-table__badge {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: var(--ah-radius-pill);
    background: var(--ah-gradient-primary);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.4rem;
}

.ah-pricing-table__row {
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-pricing__check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(0, 219, 231, 0.15);
    color: var(--ah-tertiary);
    font-size: 0.95rem;
}

.ah-pricing__cross {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.04);
    color: var(--ah-on-surface-muted);
    font-size: 0.95rem;
}

.ah-pricing__limit {
    color: var(--ah-on-surface-muted);
    font-weight: 600;
}

.ah-pricing-table__col strong {
    font-family: var(--ah-font-display);
    font-size: 1.0625rem;
    color: var(--ah-on-surface);
}

.ah-pricing-table__col--us strong { color: var(--ah-primary); }

@media (max-width: 768px) {
    .ah-pricing-table__head { display: none; }

    .ah-pricing-table__row {
        grid-template-columns: 1fr;
        gap: 0;
        padding: var(--ah-space-2) 0;
    }

    .ah-pricing-table__row > div {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0.5rem var(--ah-space-3);
        text-align: right;
    }

    .ah-pricing-table__row > div:first-child {
        font-weight: 600;
        color: var(--ah-on-surface);
        background: var(--ah-surface-container-high);
        padding: 0.6rem var(--ah-space-3);
    }

    .ah-pricing-table__row > div[data-label]::before {
        content: attr(data-label);
        font-size: 0.8125rem;
        color: var(--ah-on-surface-muted);
        font-weight: 500;
    }
}

.ah-pricing-cta {
    text-align: center;
    margin-top: var(--ah-space-6);
}

/* -----------------------------------------------------------------------------
   Section 8 — Privacy
   ----------------------------------------------------------------------------- */
.ah-privacy-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

@media (max-width: 991px) { .ah-privacy-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .ah-privacy-grid { grid-template-columns: 1fr; } }

.ah-privacy-card {
    padding: var(--ah-space-3);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    transition: border-color 0.2s ease, transform 0.2s ease;
}

.ah-privacy-card:hover {
    border-color: var(--ah-tertiary);
    transform: translateY(-2px);
}

.ah-privacy-card__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--ah-radius);
    background: rgba(0, 219, 231, 0.1);
    border: 1px solid rgba(0, 219, 231, 0.2);
    color: var(--ah-tertiary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    margin-bottom: var(--ah-space-2);
}

.ah-privacy-card__title {
    font-family: var(--ah-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--ah-on-surface);
}

.ah-privacy-card__description {
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

/* -----------------------------------------------------------------------------
   Section 9 — Testimonials
   ----------------------------------------------------------------------------- */
.ah-testimonials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

@media (max-width: 991px) { .ah-testimonials { grid-template-columns: 1fr; } }

.ah-testimonial {
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
}

.ah-testimonial__rating {
    display: flex;
    gap: 0.2rem;
    margin-bottom: var(--ah-space-2);
    color: #ffd966;
    font-size: 0.95rem;
}

.ah-testimonial__rating .is-empty { color: var(--ah-outline-variant); }

.ah-testimonial__quote {
    font-family: var(--ah-font-display);
    font-style: italic;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--ah-on-surface);
    margin: 0 0 var(--ah-space-3);
    border-left: 0;
    padding-left: 0;
}

.ah-testimonial__author {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding-top: var(--ah-space-2);
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-testimonial__author strong {
    font-family: var(--ah-font-display);
    font-size: 0.9375rem;
    color: var(--ah-on-surface);
}

.ah-testimonial__author span {
    font-size: 0.8125rem;
    color: var(--ah-on-surface-muted);
}

/* -----------------------------------------------------------------------------
   Section 10 — FAQ
   ----------------------------------------------------------------------------- */
.ah-faq {
    max-width: 780px;
    margin: 0 auto;
}

.ah-faq__item {
    border-bottom: 1px solid var(--ah-outline-variant);
    transition: background 0.15s ease;
}

.ah-faq__item:first-child { border-top: 1px solid var(--ah-outline-variant); }

.ah-faq__question {
    list-style: none;
    cursor: pointer;
    padding: var(--ah-space-3) 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ah-space-2);
    font-family: var(--ah-font-display);
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--ah-on-surface);
}

.ah-faq__question::-webkit-details-marker { display: none; }

.ah-faq__question:hover { color: var(--ah-primary); }

.ah-faq__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--ah-surface-container-high);
    border: 1px solid var(--ah-outline-variant);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, background 0.2s ease;
    color: var(--ah-on-surface-variant);
    font-size: 0.95rem;
}

.ah-faq__item[open] .ah-faq__icon {
    transform: rotate(45deg);
    background: var(--ah-primary);
    color: #fff;
    border-color: var(--ah-primary);
}

.ah-faq__answer {
    padding: 0 0 var(--ah-space-3);
}

.ah-faq__answer p {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--ah-on-surface-variant);
    margin: 0;
    max-width: 700px;
}

/* -----------------------------------------------------------------------------
   Section 11 — Final CTA
   ----------------------------------------------------------------------------- */
.ah-section--final-cta {
    padding: var(--ah-space-12) 0;
    background:
        radial-gradient(ellipse at center, rgba(138, 79, 255, 0.12) 0%, transparent 60%),
        var(--ah-surface-container-lowest);
    text-align: center;
}

.ah-final-cta {
    max-width: 720px;
    margin: 0 auto;
}

.ah-final-cta__headline {
    font-family: var(--ah-font-display);
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.025em;
    margin: var(--ah-space-2) 0 var(--ah-space-2);
    color: var(--ah-on-surface);
}

.ah-final-cta__subline {
    font-size: 1.125rem;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-5);
}

.ah-final-cta__badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ah-space-2);
    justify-content: center;
    margin-bottom: var(--ah-space-3);
}

.ah-store-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.7rem 1.2rem;
    border-radius: var(--ah-radius);
    background: #000;
    border: 1px solid var(--ah-outline-variant);
    color: #fff;
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-store-badge:hover {
    color: #fff;
    transform: translateY(-2px);
    border-color: var(--ah-primary);
}

.ah-store-badge i {
    font-size: 1.75rem;
}

.ah-store-badge__small {
    display: block;
    font-size: 0.6875rem;
    line-height: 1;
    color: rgba(255,255,255,0.7);
    margin-bottom: 0.15rem;
}

.ah-store-badge__big {
    display: block;
    font-family: var(--ah-font-display);
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1;
}

.ah-final-cta__trust {
    margin: 0;
    font-size: 0.875rem;
    color: var(--ah-on-surface-muted);
}

/* -----------------------------------------------------------------------------
   Reduced Motion overrides für alle neuen Sektionen
   ----------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .ah-step,
    .ah-card,
    .ah-library-card,
    .ah-privacy-card,
    .ah-demo-freq,
    .ah-demo__play,
    .ah-store-badge {
        transition: none !important;
    }
    .ah-step:hover,
    .ah-card:hover,
    .ah-library-card:hover,
    .ah-privacy-card:hover,
    .ah-store-badge:hover {
        transform: none !important;
    }
}

/* =============================================================================
   PHASE 4 — Blog
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Section-Headline kleinere Variante (für Related)
   ----------------------------------------------------------------------------- */
.ah-section-headline--small {
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin-bottom: var(--ah-space-4);
}

/* -----------------------------------------------------------------------------
   Blog Filter Nav
   ----------------------------------------------------------------------------- */
.ah-blog-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    margin-bottom: var(--ah-space-6);
    padding: var(--ah-space-1);
    background: var(--ah-surface-container-lowest);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-pill);
    max-width: max-content;
    margin-left: auto;
    margin-right: auto;
}

.ah-blog-filter__item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 1.1rem;
    border-radius: var(--ah-radius-pill);
    color: var(--ah-on-surface-variant);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.ah-blog-filter__item:hover {
    color: var(--ah-on-surface);
    background: rgba(255, 255, 255, 0.04);
}

.ah-blog-filter__item.is-active {
    background: var(--ah-primary);
    color: #1a0d33;
}

.ah-blog-filter__count {
    display: inline-block;
    min-width: 1.5rem;
    padding: 0.1rem 0.5rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(255, 255, 255, 0.08);
    font-size: 0.75rem;
    font-weight: 700;
    text-align: center;
}

.ah-blog-filter__item.is-active .ah-blog-filter__count {
    background: rgba(26, 13, 51, 0.25);
}

/* -----------------------------------------------------------------------------
   Blog Grid + Cards
   ----------------------------------------------------------------------------- */
.ah-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-4);
}

@media (max-width: 991px) { .ah-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .ah-blog-grid { grid-template-columns: 1fr; } }

.ah-blog-card {
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    overflow: hidden;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-blog-card:hover {
    transform: translateY(-4px);
    border-color: var(--ah-primary);
}

.ah-blog-card__link {
    display: block;
    color: inherit;
    text-decoration: none;
    height: 100%;
}

.ah-blog-card__image {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--ah-surface-container-high);
}

.ah-blog-card__image img,
.ah-blog-card__image svg {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.ah-blog-card:hover .ah-blog-card__image img,
.ah-blog-card:hover .ah-blog-card__image svg {
    transform: scale(1.05);
}

.ah-blog-card__image--placeholder svg { display: block; }

.ah-blog-card__body {
    padding: var(--ah-space-3);
}

.ah-blog-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ah-space-1);
    margin-bottom: var(--ah-space-2);
    font-size: 0.75rem;
    color: var(--ah-on-surface-muted);
}

.ah-blog-card__category {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(0, 219, 231, 0.1);
    border: 1px solid rgba(0, 219, 231, 0.25);
    color: var(--ah-tertiary);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    font-size: 0.6875rem;
}

.ah-blog-card__time {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.ah-blog-card__time i { font-size: 0.85rem; }

.ah-blog-card__title {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.25;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
    transition: color 0.15s ease;
}

.ah-blog-card:hover .ah-blog-card__title {
    color: var(--ah-primary);
}

.ah-blog-card__excerpt {
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-2);

    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ah-blog-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--ah-space-2);
    border-top: 1px solid var(--ah-outline-variant);
    font-size: 0.8125rem;
    color: var(--ah-on-surface-muted);
}

.ah-blog-card__fallback {
    display: inline-block;
    padding: 0.1rem 0.45rem;
    border-radius: var(--ah-radius-sm);
    background: rgba(255, 255, 255, 0.06);
    color: var(--ah-on-surface-muted);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    cursor: help;
}

/* Featured Card: erstes Item auf voller Breite (nur Desktop) */
@media (min-width: 992px) {
    .ah-blog-card--featured {
        grid-column: span 3;
    }
    .ah-blog-card--featured .ah-blog-card__link {
        display: grid;
        grid-template-columns: 1.2fr 1fr;
        gap: 0;
    }
    .ah-blog-card--featured .ah-blog-card__image {
        aspect-ratio: auto;
        height: 100%;
        min-height: 280px;
    }
    .ah-blog-card--featured .ah-blog-card__body {
        padding: var(--ah-space-5);
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .ah-blog-card--featured .ah-blog-card__title {
        font-size: 1.75rem;
        margin-bottom: var(--ah-space-2);
    }
    .ah-blog-card--featured .ah-blog-card__excerpt {
        -webkit-line-clamp: 4;
        line-clamp: 4;
        font-size: 1rem;
    }
}

.ah-blog-empty {
    text-align: center;
    padding: var(--ah-space-6) 0;
    color: var(--ah-on-surface-muted);
    font-size: 1rem;
}

/* -----------------------------------------------------------------------------
   Blog Post Detail
   ----------------------------------------------------------------------------- */
.ah-section--blog-post {
    padding-top: var(--ah-space-6);
}

.ah-blog-post {
    max-width: 760px;
    margin: 0 auto;
}

.ah-blog-post__back {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0;
    color: var(--ah-on-surface-variant);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 500;
    margin-bottom: var(--ah-space-3);
    transition: color 0.15s ease, transform 0.15s ease;
}

.ah-blog-post__back:hover {
    color: var(--ah-primary);
    transform: translateX(-2px);
}

.ah-blog-post__fallback-notice {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: var(--ah-space-2) var(--ah-space-3);
    border-radius: var(--ah-radius);
    background: rgba(0, 219, 231, 0.08);
    border: 1px solid rgba(0, 219, 231, 0.25);
    color: var(--ah-tertiary);
    font-size: 0.875rem;
    margin-bottom: var(--ah-space-4);
}

.ah-blog-post__header { margin-bottom: var(--ah-space-4); }

.ah-blog-post__meta {
    display: flex;
    align-items: center;
    gap: var(--ah-space-2);
    margin-bottom: var(--ah-space-2);
    flex-wrap: wrap;
}

.ah-blog-post__category {
    display: inline-block;
    padding: 0.3rem 0.85rem;
    border-radius: var(--ah-radius-pill);
    background: rgba(0, 219, 231, 0.1);
    border: 1px solid rgba(0, 219, 231, 0.3);
    color: var(--ah-tertiary);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.15s ease;
}

.ah-blog-post__category:hover {
    background: rgba(0, 219, 231, 0.18);
}

.ah-blog-post__time {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--ah-on-surface-muted);
    font-size: 0.875rem;
}

.ah-blog-post__title {
    font-family: var(--ah-font-display);
    font-size: clamp(2rem, 5vw, 3.25rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 var(--ah-space-2);
    color: var(--ah-on-surface);
}

.ah-blog-post__byline {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--ah-on-surface-muted);
    font-size: 0.9375rem;
    flex-wrap: wrap;
}

.ah-blog-post__byline strong { color: var(--ah-on-surface); }

.ah-blog-post__hero {
    margin: 0 0 var(--ah-space-5);
    border-radius: var(--ah-radius-lg);
    overflow: hidden;
}

.ah-blog-post__hero img {
    width: 100%;
    height: auto;
    display: block;
}

/* Markdown-rendered content */
.ah-blog-post__content {
    font-size: 1.0625rem;
    line-height: 1.75;
    color: var(--ah-on-surface);
}

.ah-blog-post__content > * + * { margin-top: var(--ah-space-3); }
.ah-blog-post__content > * { max-width: 100%; }

.ah-blog-post__content h2,
.ah-blog-post__content h3,
.ah-blog-post__content h4 {
    font-family: var(--ah-font-display);
    font-weight: 600;
    line-height: 1.25;
    color: var(--ah-on-surface);
    margin-top: var(--ah-space-5);
    margin-bottom: var(--ah-space-1);
    scroll-margin-top: calc(var(--ah-nav-height) + 16px);
}

.ah-blog-post__content h2 { font-size: 1.75rem; letter-spacing: -0.015em; }
.ah-blog-post__content h3 { font-size: 1.375rem; }
.ah-blog-post__content h4 { font-size: 1.125rem; }

.ah-blog-post__content p {
    color: var(--ah-on-surface);
    margin: 0;
}

.ah-blog-post__content a {
    color: var(--ah-primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color 0.15s ease;
}

.ah-blog-post__content a:hover {
    color: var(--ah-tertiary);
}

.ah-blog-post__content strong { color: var(--ah-on-surface); font-weight: 600; }
.ah-blog-post__content em { font-style: italic; color: var(--ah-on-surface); }

.ah-blog-post__content ul,
.ah-blog-post__content ol {
    padding-left: 1.4rem;
    color: var(--ah-on-surface);
}

.ah-blog-post__content li + li { margin-top: 0.4rem; }
.ah-blog-post__content li::marker { color: var(--ah-primary); }

.ah-blog-post__content blockquote {
    margin: var(--ah-space-3) 0;
    padding: var(--ah-space-3) var(--ah-space-4);
    border-left: 3px solid var(--ah-primary);
    background: var(--ah-surface-container);
    border-radius: 0 var(--ah-radius) var(--ah-radius) 0;
    font-family: var(--ah-font-display);
    font-style: italic;
    color: var(--ah-on-surface);
}

.ah-blog-post__content blockquote p { margin: 0; }

.ah-blog-post__content code {
    font-family: ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace;
    font-size: 0.875em;
    padding: 0.15rem 0.4rem;
    border-radius: var(--ah-radius-sm);
    background: var(--ah-surface-container-high);
    border: 1px solid var(--ah-outline-variant);
    color: var(--ah-tertiary);
}

.ah-blog-post__content pre {
    margin: var(--ah-space-3) 0;
    padding: var(--ah-space-3);
    border-radius: var(--ah-radius);
    background: var(--ah-surface-container-lowest);
    border: 1px solid var(--ah-outline-variant);
    overflow-x: auto;
    font-size: 0.875rem;
    line-height: 1.6;
}

.ah-blog-post__content pre code {
    background: transparent;
    border: 0;
    padding: 0;
    color: var(--ah-on-surface);
    font-size: inherit;
}

.ah-blog-post__content hr {
    margin: var(--ah-space-5) 0;
    border: 0;
    height: 1px;
    background: var(--ah-outline-variant);
}

.ah-blog-post__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--ah-radius);
    margin: var(--ah-space-3) 0;
}

.ah-blog-post__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: var(--ah-space-5);
    padding-top: var(--ah-space-3);
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-blog-post__tag {
    display: inline-block;
    padding: 0.35rem 0.7rem;
    border-radius: var(--ah-radius-pill);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    color: var(--ah-on-surface-muted);
    font-size: 0.8125rem;
}

.ah-section--blog-related {
    background: var(--ah-surface-container-lowest);
    border-top: 1px solid var(--ah-outline-variant);
}

@media (prefers-reduced-motion: reduce) {
    .ah-blog-card,
    .ah-blog-card__image img,
    .ah-blog-card__image svg,
    .ah-blog-post__back {
        transition: none !important;
    }
    .ah-blog-card:hover,
    .ah-blog-post__back:hover {
        transform: none !important;
    }
}

/* =============================================================================
   PHASE 5 — Support, Legal Pages
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Support — Contact Card oben
   ----------------------------------------------------------------------------- */
.ah-support-contact {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--ah-space-3);
    align-items: center;
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-xl);
    background:
        radial-gradient(ellipse at top right, rgba(138, 79, 255, 0.10) 0%, transparent 60%),
        var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    margin-bottom: var(--ah-space-6);
}

@media (max-width: 768px) {
    .ah-support-contact {
        grid-template-columns: 1fr;
        text-align: center;
    }
}

.ah-support-contact__icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--ah-gradient-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.6rem;
    box-shadow: 0 8px 24px rgba(138, 79, 255, 0.3);
}

@media (max-width: 768px) {
    .ah-support-contact__icon { margin: 0 auto; }
}

.ah-support-contact__title {
    font-family: var(--ah-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 0.4rem;
    color: var(--ah-on-surface);
}

.ah-support-contact__text {
    margin: 0 0 0.5rem;
    color: var(--ah-on-surface-variant);
    font-size: 1rem;
}

.ah-support-contact__meta {
    margin: 0;
    color: var(--ah-tertiary);
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

@media (max-width: 768px) {
    .ah-support-contact__meta { justify-content: center; }
}

.ah-support-contact__action {
    display: flex;
    align-items: center;
}

@media (max-width: 768px) {
    .ah-support-contact__action { justify-content: center; }
}

/* -----------------------------------------------------------------------------
   Support — Categories
   ----------------------------------------------------------------------------- */
.ah-support__categories-title {
    font-family: var(--ah-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-3);
    color: var(--ah-on-surface);
}

.ah-support-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ah-space-3);
    margin-bottom: var(--ah-space-6);
}

@media (max-width: 768px) {
    .ah-support-grid { grid-template-columns: 1fr; }
}

.ah-support-card {
    padding: var(--ah-space-4);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    transition: border-color 0.2s ease, transform 0.2s ease;
}

.ah-support-card:hover {
    border-color: var(--ah-primary);
    transform: translateY(-2px);
}

.ah-support-card__icon {
    width: 48px;
    height: 48px;
    border-radius: var(--ah-radius);
    background: rgba(209, 188, 255, 0.10);
    border: 1px solid rgba(209, 188, 255, 0.25);
    color: var(--ah-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    margin-bottom: var(--ah-space-2);
}

.ah-support-card__title {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 0.4rem;
    color: var(--ah-on-surface);
}

.ah-support-card__description {
    margin: 0 0 var(--ah-space-2);
    color: var(--ah-on-surface-variant);
    font-size: 0.9375rem;
    line-height: 1.55;
}

.ah-support-card__items {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ah-support-card__items li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.4rem 0;
    color: var(--ah-on-surface-variant);
    font-size: 0.9375rem;
    line-height: 1.45;
}

.ah-support-card__items li i {
    color: var(--ah-tertiary);
    flex-shrink: 0;
    margin-top: 0.2rem;
    font-size: 0.95rem;
}

/* "Nichts gefunden" — sanfte Aufforderung */
.ah-support-cantfind {
    text-align: center;
    padding: var(--ah-space-5);
    border-radius: var(--ah-radius-lg);
    background: var(--ah-surface-container-lowest);
    border: 1px solid var(--ah-outline-variant);
}

.ah-support-cantfind h2 {
    font-family: var(--ah-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--ah-on-surface);
}

.ah-support-cantfind p {
    margin: 0 0 var(--ah-space-2);
    color: var(--ah-on-surface-variant);
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
}

/* -----------------------------------------------------------------------------
   Legal Pages (Impressum, Datenschutz, AGB)
   ----------------------------------------------------------------------------- */
.ah-section--legal {
    padding-top: var(--ah-space-6);
}

.ah-legal-page {
    max-width: 760px;
    margin: 0 auto;
}

.ah-legal-page__header {
    margin-bottom: var(--ah-space-5);
    padding-bottom: var(--ah-space-3);
    border-bottom: 1px solid var(--ah-outline-variant);
}

.ah-legal-page__title {
    font-family: var(--ah-font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0;
    color: var(--ah-on-surface);
}

.ah-legal-page__content {
    color: var(--ah-on-surface-variant);
    font-size: 1rem;
    line-height: 1.7;
}

.ah-legal-page__content > * + * { margin-top: var(--ah-space-3); }

.ah-legal-page__content h2 {
    font-family: var(--ah-font-display);
    font-size: 1.375rem;
    font-weight: 600;
    color: var(--ah-on-surface);
    margin-top: var(--ah-space-5);
    margin-bottom: var(--ah-space-1);
}

.ah-legal-page__content h3 {
    font-family: var(--ah-font-display);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ah-on-surface);
    margin-top: var(--ah-space-3);
    margin-bottom: 0.4rem;
}

.ah-legal-page__content p { margin: 0; }

.ah-legal-page__content a {
    color: var(--ah-primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.ah-legal-page__content a:hover {
    color: var(--ah-tertiary);
}

.ah-legal-page__content strong {
    color: var(--ah-on-surface);
    font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
    .ah-support-card { transition: none; }
    .ah-support-card:hover { transform: none; }
}

/* =============================================================================
   PHASE 7 — Landing-Page  /{lang}/app/
   Conversion-fokussierte Variante. Eigene Klassen unter .ah-lp-*.
   Re-use von Tokens und Hilfsklassen aus dem bestehenden Design-System.
   ============================================================================= */


/* -----------------------------------------------------------------------------
   LP Hero — Two-Column-Layout: Text links, Phone-Slider rechts
   ----------------------------------------------------------------------------- */
.ah-lp-hero {
    position: relative;
    padding: var(--ah-space-8) 0;
    overflow: hidden;
}

.ah-lp-hero__background {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.ah-lp-hero__glow {
    position: absolute;
    width: 60vw;
    max-width: 700px;
    aspect-ratio: 1;
    border-radius: 50%;
    filter: blur(120px);
    opacity: 0.55;
}

.ah-lp-hero__glow--purple {
    background: radial-gradient(circle, rgba(138, 79, 255, 0.45) 0%, transparent 70%);
    top: -10%;
    left: -10%;
}

.ah-lp-hero__glow--cyan {
    background: radial-gradient(circle, rgba(0, 219, 231, 0.30) 0%, transparent 70%);
    bottom: -20%;
    right: -10%;
}

.ah-lp-hero__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
    gap: var(--ah-space-6);
    align-items: center;
}

.ah-lp-hero__col--text {
    display: flex;
    flex-direction: column;
    gap: var(--ah-space-3);
    /* zusätzlich nach unten Luft, damit Slider und Text auf gleicher Achse stehen */
    padding: var(--ah-space-2) 0;
}

/* --- Text-Spalte ----------------------------------------------------------- */
.ah-lp-hero__eyebrow {
    margin-bottom: 0;
    align-self: flex-start;
}

.ah-lp-hero__headline {
    font-family: var(--ah-font-display);
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.025em;
    margin: 0;
    color: var(--ah-on-surface);
    background: linear-gradient(135deg, #ffffff 0%, var(--ah-primary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.ah-lp-hero__subline {
    font-size: clamp(1.0625rem, 1.6vw, 1.1875rem);
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

.ah-lp-hero__rating {
    display: inline-flex;
    align-items: center;
    gap: var(--ah-space-1);
    margin: 0;
    color: var(--ah-on-surface-muted);
    font-size: 0.9375rem;
}

.ah-lp-hero__stars {
    display: inline-flex;
    gap: 2px;
    color: #ffc857;
    font-size: 0.875rem;
}

.ah-lp-hero__rating-text {
    color: var(--ah-on-surface-variant);
}

.ah-lp-hero__bullets {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ah-space-1) var(--ah-space-3);
    list-style: none;
    padding: var(--ah-space-3);
    margin: 0;
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
}

@media (max-width: 575px) {
    .ah-lp-hero__bullets {
        grid-template-columns: 1fr;
    }
}

.ah-lp-hero__bullet {
    display: flex;
    align-items: center;
    gap: var(--ah-space-1);
    color: var(--ah-on-surface);
    font-size: 0.9375rem;
    line-height: 1.4;
}

.ah-lp-hero__bullet i {
    color: var(--ah-tertiary);
    font-size: 1.125rem;
    flex-shrink: 0;
}

.ah-lp-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ah-space-2);
    margin: 0;
}

.ah-lp-hero__trust {
    display: inline-flex;
    align-items: center;
    gap: var(--ah-space-1);
    color: var(--ah-on-surface-muted);
    font-size: 0.875rem;
    margin: 0;
}

.ah-lp-hero__trust i {
    color: var(--ah-primary);
}

/* --- Mobile/Tablet: Text-Block zentrieren ---------------------------------- */
/* WICHTIG: Diese Media-Query muss NACH den Basis-Definitionen oben stehen,
   damit gleich-spezifische Selektoren (z.B. .ah-lp-hero__eyebrow) korrekt
   überschrieben werden. CSS-Cascade: bei gleicher Specificity gewinnt der
   später deklarierte Selektor. */
@media (max-width: 991px) {
    .ah-lp-hero__grid {
        grid-template-columns: 1fr;
        gap: var(--ah-space-5);
    }
    /* Konsistent zu den anderen Sektion-Headern: zentrierter Text-Block.
       Reihenfolge entspricht der DOM-Reihenfolge: erst Headline+Bullets+CTA,
       dann Slider. */
    .ah-lp-hero__col--text {
        text-align: center;
    }
    /* inline-flex-Elemente (Eyebrow, Rating, Trust-Line) müssen explizit
       per align-self zentriert werden — text-align:center auf einem
       Flex-Container wirkt nicht auf die Position der Flex-Items selbst,
       nur auf deren inneren Text. */
    .ah-lp-hero__eyebrow,
    .ah-lp-hero__rating,
    .ah-lp-hero__trust {
        align-self: center;
    }
    .ah-lp-hero__cta {
        justify-content: center;
    }
    /* Bullets-Box auf Mobile/Tablet schmaler ziehen und zentrieren —
       sonst wirken die linksbündigen Items in einer 100%-Box "verloren". */
    .ah-lp-hero__bullets {
        max-width: 480px;
        margin-left: auto;
        margin-right: auto;
        text-align: left; /* Items selbst bleiben linksbündig (Icon→Text) */
    }
}

/* -----------------------------------------------------------------------------
   Phone Slider — CSS-Scroll-Snap-basiert
   - Native Swipe-Gesten auf Touch-Devices
   - JS in main.js übernimmt Auto-Advance, Dots, IntersectionObserver
   ----------------------------------------------------------------------------- */
.ah-phone-slider {
    --slides-visible: 3;
    position: relative;
    width: 100%;
}

@media (max-width: 991px) {
    .ah-phone-slider { --slides-visible: 2; max-width: 640px; margin: 0 auto; }
}

@media (max-width: 575px) {
    .ah-phone-slider { --slides-visible: 1; max-width: 320px; }
}

.ah-phone-slider__track {
    display: flex;
    gap: var(--ah-space-2);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    padding: var(--ah-space-2) 0 var(--ah-space-3);
    /* Scrollbar verstecken */
    scrollbar-width: none;
}
.ah-phone-slider__track::-webkit-scrollbar { display: none; }

.ah-phone-slider__slide {
    flex: 0 0 calc(
        (100% - (var(--slides-visible) - 1) * var(--ah-space-2))
        / var(--slides-visible)
    );
    scroll-snap-align: start;
    scroll-snap-stop: always;
    border-radius: var(--ah-radius-lg);
    overflow: hidden;
    box-shadow:
        0 12px 40px rgba(0, 0, 0, 0.4),
        0 0 0 1px var(--ah-outline-variant);
    background: var(--ah-surface-container);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.ah-phone-slider__slide.is-active {
    box-shadow:
        0 20px 60px rgba(138, 79, 255, 0.30),
        0 0 0 1px rgba(209, 188, 255, 0.30);
}

.ah-phone-slider__slide img {
    display: block;
    width: 100%;
    height: auto;
}

/* Dots-Pagination */
.ah-phone-slider__dots {
    display: flex;
    justify-content: center;
    gap: var(--ah-space-1);
    margin-top: var(--ah-space-2);
}

.ah-phone-slider__dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    background: var(--ah-outline-variant);
    border-radius: 50%;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, width 0.2s ease;
}

.ah-phone-slider__dot:hover {
    background: var(--ah-on-surface-variant);
}

.ah-phone-slider__dot.is-active {
    background: var(--ah-primary);
    width: 24px;
    border-radius: 4px;
}

.ah-phone-slider__dot:focus-visible {
    outline: 2px solid var(--ah-primary);
    outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .ah-phone-slider__track { scroll-behavior: auto; }
    .ah-phone-slider__slide { transition: none; }
    .ah-phone-slider__dot   { transition: none; }
}

/* -----------------------------------------------------------------------------
   LP Section-Wrapper (alternierende Hintergründe für visuellen Rhythmus)
   ----------------------------------------------------------------------------- */
.ah-section--lp {
    border-top: 1px solid var(--ah-outline-variant);
}

/* Jede zweite LP-Section bekommt einen sehr dezent kontrastierenden Hintergrund. */
.ah-section--lp-personas,
.ah-section--lp-privacy,
.ah-section--lp-faq {
    background: linear-gradient(180deg,
        transparent 0%,
        rgba(29, 31, 39, 0.4) 50%,
        transparent 100%);
}

/* -----------------------------------------------------------------------------
   LP Steps (3 Schritte) — kompakter als Hauptseite, ohne riesige Step-Nummern
   ----------------------------------------------------------------------------- */
.ah-lp-steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-4);
}

.ah-lp-step {
    position: relative;
    padding: var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-lp-step:hover {
    transform: translateY(-4px);
    border-color: var(--ah-primary);
}

.ah-lp-step__number {
    font-family: var(--ah-font-display);
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--ah-primary);
    letter-spacing: 0.1em;
    margin-bottom: var(--ah-space-2);
}

.ah-lp-step__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--ah-gradient-primary);
    border-radius: var(--ah-radius);
    margin-bottom: var(--ah-space-2);
    color: var(--ah-on-primary-container);
    font-size: 1.25rem;
}

.ah-lp-step__title {
    font-family: var(--ah-font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-lp-step__description {
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

@media (max-width: 768px) {
    .ah-lp-steps { grid-template-columns: 1fr; gap: var(--ah-space-3); }
}

/* -----------------------------------------------------------------------------
   LP Personas (4 Zielgruppen)
   ----------------------------------------------------------------------------- */
.ah-lp-personas__lead {
    max-width: 760px;
    margin: 0 auto var(--ah-space-6);
    text-align: center;
    color: var(--ah-on-surface-variant);
    font-size: 1.0625rem;
    line-height: 1.7;
}

.ah-lp-personas {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ah-space-3);
}

.ah-lp-persona {
    padding: var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-lp-persona:hover {
    transform: translateY(-4px);
    border-color: var(--ah-tertiary);
}

.ah-lp-persona__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: rgba(0, 219, 231, 0.12);
    border: 1px solid rgba(0, 219, 231, 0.3);
    border-radius: var(--ah-radius);
    color: var(--ah-tertiary);
    font-size: 1.125rem;
    margin-bottom: var(--ah-space-2);
}

.ah-lp-persona__title {
    font-family: var(--ah-font-display);
    font-size: 1.1875rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-lp-persona__description {
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

@media (max-width: 768px) {
    .ah-lp-personas { grid-template-columns: 1fr; }
}

/* -----------------------------------------------------------------------------
   LP Categories (6 Frequenz-Kategorien)
   ----------------------------------------------------------------------------- */
.ah-lp-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

.ah-lp-category {
    padding: var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.ah-lp-category:hover {
    transform: translateY(-4px);
    border-color: var(--ah-primary);
    box-shadow: var(--ah-shadow-glow);
}

.ah-lp-category__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--ah-gradient-primary);
    border-radius: var(--ah-radius);
    color: var(--ah-on-primary-container);
    font-size: 1.375rem;
    margin-bottom: var(--ah-space-2);
}

.ah-lp-category__title {
    font-family: var(--ah-font-display);
    font-size: 1.1875rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-lp-category__description {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

@media (max-width: 991px) {
    .ah-lp-categories { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575px) {
    .ah-lp-categories { grid-template-columns: 1fr; }
}

/* -----------------------------------------------------------------------------
   LP Mid-CTA (zwischen Categories und Privacy)
   ----------------------------------------------------------------------------- */
.ah-section--lp-mid-cta {
    padding: var(--ah-space-10) 0;
    background:
        radial-gradient(ellipse at center, rgba(138, 79, 255, 0.12) 0%, transparent 70%),
        var(--ah-surface);
    border-top: 1px solid var(--ah-outline-variant);
    border-bottom: 1px solid var(--ah-outline-variant);
}

.ah-lp-mid-cta {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}

.ah-lp-mid-cta__headline {
    font-family: var(--ah-font-display);
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: var(--ah-space-2) 0 var(--ah-space-2);
    color: var(--ah-on-surface);
}

.ah-lp-mid-cta__text {
    font-size: 1.0625rem;
    line-height: 1.7;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-4);
}

.ah-lp-mid-cta__btn {
    gap: var(--ah-space-1);
}

/* -----------------------------------------------------------------------------
   LP Privacy (6 Aspekte)
   ----------------------------------------------------------------------------- */
.ah-lp-privacy {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

.ah-lp-privacy__card {
    padding: var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    text-align: center;
    transition: border-color 0.2s ease;
}

.ah-lp-privacy__card:hover {
    border-color: var(--ah-tertiary);
}

.ah-lp-privacy__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    margin: 0 auto var(--ah-space-2);
    background: rgba(0, 219, 231, 0.12);
    border: 1px solid rgba(0, 219, 231, 0.3);
    border-radius: var(--ah-radius-pill);
    color: var(--ah-tertiary);
    font-size: 1.25rem;
}

.ah-lp-privacy__title {
    font-family: var(--ah-font-display);
    font-size: 1.0625rem;
    font-weight: 600;
    margin: 0 0 var(--ah-space-1);
    color: var(--ah-on-surface);
}

.ah-lp-privacy__description {
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--ah-on-surface-variant);
    margin: 0;
}

@media (max-width: 991px) {
    .ah-lp-privacy { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575px) {
    .ah-lp-privacy { grid-template-columns: 1fr; }
}

/* -----------------------------------------------------------------------------
   LP Stats (4 Werte als kompakte Box)
   ----------------------------------------------------------------------------- */
.ah-section--lp-stats {
    padding: var(--ah-space-8) 0;
}

.ah-lp-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ah-space-3);
    padding: var(--ah-space-5);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-xl);
    box-shadow: var(--ah-shadow-card);
}

.ah-lp-stat {
    text-align: center;
    padding: 0 var(--ah-space-2);
    border-right: 1px solid var(--ah-outline-variant);
}

.ah-lp-stat:last-child { border-right: none; }

.ah-lp-stat__value {
    font-family: var(--ah-font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1;
    color: var(--ah-primary);
    margin-bottom: var(--ah-space-1);
    display: inline-flex;
    align-items: baseline;
    gap: 0.1em;
}

.ah-lp-stat__suffix {
    font-size: 0.6em;
    color: var(--ah-tertiary);
}

.ah-lp-stat__label {
    font-size: 0.875rem;
    color: var(--ah-on-surface-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

@media (max-width: 768px) {
    .ah-lp-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ah-space-3);
        padding: var(--ah-space-3);
    }
    .ah-lp-stat { border-right: none; }
    .ah-lp-stat:nth-child(odd) { border-right: 1px solid var(--ah-outline-variant); }
    .ah-lp-stat:nth-child(-n+2) { border-bottom: 1px solid var(--ah-outline-variant); padding-bottom: var(--ah-space-2); }
    .ah-lp-stat:nth-child(n+3) { padding-top: var(--ah-space-2); }
}

@media (max-width: 480px) {
    .ah-lp-stats { grid-template-columns: 1fr; }
    .ah-lp-stat { border-right: none !important; border-bottom: 1px solid var(--ah-outline-variant); padding: var(--ah-space-2) 0; }
    .ah-lp-stat:last-child { border-bottom: none; }
}

/* -----------------------------------------------------------------------------
   LP Testimonials (9 Stück, masonry-artig)
   ----------------------------------------------------------------------------- */
.ah-lp-testimonials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ah-space-3);
}

.ah-lp-testimonial {
    padding: var(--ah-space-4);
    background: var(--ah-surface-container);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-lg);
    display: flex;
    flex-direction: column;
    gap: var(--ah-space-2);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.ah-lp-testimonial:hover {
    transform: translateY(-2px);
    border-color: var(--ah-primary);
}

.ah-lp-testimonial__rating {
    display: flex;
    gap: 2px;
    color: #ffc857;
    font-size: 0.875rem;
}

.ah-lp-testimonial__rating .is-empty {
    color: var(--ah-outline-variant);
}

.ah-lp-testimonial__quote {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--ah-on-surface);
    font-style: italic;
    flex-grow: 1;
}

.ah-lp-testimonial__author {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-style: normal;
    margin-top: auto;
}

.ah-lp-testimonial__author strong {
    color: var(--ah-on-surface);
    font-weight: 600;
    font-size: 0.9375rem;
}

.ah-lp-testimonial__author span {
    color: var(--ah-on-surface-muted);
    font-size: 0.8125rem;
}

@media (max-width: 991px) {
    .ah-lp-testimonials { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575px) {
    .ah-lp-testimonials { grid-template-columns: 1fr; }
}

/* -----------------------------------------------------------------------------
   LP Final-CTA (am Seitenende, mit beiden Stores + Anchor zurück nach oben)
   ----------------------------------------------------------------------------- */
.ah-section--lp-final-cta {
    padding: var(--ah-space-10) 0 var(--ah-space-12);
    background:
        radial-gradient(ellipse at top, rgba(0, 219, 231, 0.08) 0%, transparent 60%),
        radial-gradient(ellipse at bottom, rgba(138, 79, 255, 0.12) 0%, transparent 60%),
        var(--ah-surface);
    border-top: 1px solid var(--ah-outline-variant);
}

.ah-lp-final-cta {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}

.ah-lp-final-cta__headline {
    font-family: var(--ah-font-display);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: var(--ah-space-2) 0 var(--ah-space-2);
    color: var(--ah-on-surface);
}

.ah-lp-final-cta__text {
    font-size: 1.0625rem;
    line-height: 1.7;
    color: var(--ah-on-surface-variant);
    margin: 0 0 var(--ah-space-5);
}

.ah-lp-final-cta__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--ah-space-2);
    margin-bottom: var(--ah-space-3);
}

.ah-lp-final-cta__trust {
    color: var(--ah-on-surface-muted);
    font-size: 0.9375rem;
    margin: 0 0 var(--ah-space-4);
}

.ah-lp-final-cta__back {
    display: inline-flex;
    align-items: center;
    gap: var(--ah-space-1);
    padding: var(--ah-space-1) var(--ah-space-3);
    color: var(--ah-on-surface-variant);
    border: 1px solid var(--ah-outline-variant);
    border-radius: var(--ah-radius-pill);
    font-size: 0.875rem;
    transition: border-color 0.2s ease, color 0.2s ease;
}

.ah-lp-final-cta__back:hover {
    border-color: var(--ah-tertiary);
    color: var(--ah-tertiary);
}

/* -----------------------------------------------------------------------------
   Reduced-Motion-Override für die LP
   ----------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .ah-lp-step,
    .ah-lp-persona,
    .ah-lp-category,
    .ah-lp-privacy__card,
    .ah-lp-testimonial {
        transition: none;
    }
    .ah-lp-step:hover,
    .ah-lp-persona:hover,
    .ah-lp-category:hover,
    .ah-lp-testimonial:hover {
        transform: none;
    }
}

/* -----------------------------------------------------------------------------
   LP Nav-Variante (reduziert: nur Logo + Sprache + ein CTA)
   ----------------------------------------------------------------------------- */
.ah-nav--landing .ah-nav__menu--landing {
    display: flex;
    align-items: center;
    margin-left: auto;
    /* immer sichtbar, kein collapse-Verhalten */
    position: static;
    transform: none;
    background: transparent;
    padding: 0;
    box-shadow: none;
    width: auto;
}

.ah-nav--landing .ah-nav__menu--landing .ah-nav__actions {
    display: flex;
    align-items: center;
    gap: var(--ah-space-2);
}

@media (max-width: 575px) {
    /* Auf sehr kleinen Screens: Logo-Text ausblenden, damit Sprache + CTA Platz haben */
    .ah-nav--landing .ah-nav__brand-text {
        display: none;
    }
    .ah-nav--landing .ah-nav__menu--landing .ah-nav__actions {
        gap: var(--ah-space-1);
    }
}
