/* --- KOLONEO SECTIONS: 100% THEME SYNC (TT5 OPTIMIZED) --- */

:root {
    /* 1. KERN-FARBEN (Wasserfall-System für TT5) */
    --ks-base: var(--wp--preset--color--base, var(--wp--preset--color--background, #ffffff));
    --ks-contrast: var(--wp--preset--color--contrast, var(--wp--preset--color--foreground, #000000));
    
    /* Zieht die Akzentfarbe (meist accent-1 oder accent-4 in TT5) */
    --ks-primary: var(--wp--preset--color--accent-1, var(--wp--preset--color--accent-4, var(--wp--preset--color--primary, #00FF9D)));
    
    /* Perfektes Grau! Mischt 65% Textfarbe mit 35% Hintergrundfarbe für 100% Lesbarkeit */
    --ks-secondary: color-mix(in srgb, var(--ks-contrast) 65%, var(--ks-base));
    
    /* 2. DYNAMISCHE FLÄCHEN */
    --ks-bg-surface: color-mix(in srgb, var(--ks-contrast) 4%, var(--ks-base));
    --ks-border: color-mix(in srgb, var(--ks-contrast) 12%, var(--ks-base));
    
    /* Angepasster Karten-Verlauf */
    --ks-gradient-card: linear-gradient(145deg, var(--ks-bg-surface) 0%, color-mix(in srgb, var(--ks-primary) 6%, var(--ks-base)) 100%);
    
    /* 3. RADIAN & SCHATTEN */
    --ks-raw-radius: var(--ks-synced-radius, var(--wp--custom--border-radius, var(--wp--preset--spacing--40, 12px)));
    --ks-radius: min(var(--ks-raw-radius), 28px);
    
    --ks-shadow-base: var(--wp--preset--shadow--natural, 0 8px 24px rgba(0,0,0,0.06));
    --ks-glow-hover: 0 10px 40px color-mix(in srgb, var(--ks-primary) 20%, transparent);
    --ks-glow-pricing: 0 0 50px color-mix(in srgb, var(--ks-primary) 25%, transparent);

    /* 4. ABSTÄNDE */
    --ks-gap-cards: var(--wp--preset--spacing--30, 1.5rem); 
    --ks-gap-sections: var(--wp--preset--spacing--40, 2rem);
}

/* --- BASE & LAYOUT --- */
.ks-block {
    margin-top: clamp(3rem, 6vw, 6rem) !important;
    margin-bottom: clamp(3rem, 6vw, 6rem) !important;
    color: var(--ks-contrast); 
    font-family: var(--wp--preset--font-family--body, inherit);
}

.ks-block h1, .ks-block h2, .ks-block h3, .ks-block h4 {
    color: var(--ks-contrast);
    font-family: var(--wp--preset--font-family--heading, inherit);
}

.ks-text-center { text-align: center; }
.ks-text-accent { color: var(--ks-primary) !important; }
.ks-text-muted { color: var(--ks-secondary) !important; }
.ks-text-small { font-size: 0.85rem; }

.ks-mb-small { margin-bottom: 1rem; }
.ks-mb-medium { margin-bottom: 2rem; }
.ks-mb-large { margin-bottom: 3rem; }
.ks-mt-small { margin-top: 1rem; }
.ks-mt-medium { margin-top: 2rem; }
.ks-mt-large { margin-top: 3rem; }

/* Grids */
.ks-grid { display: grid; gap: var(--ks-gap-sections); }
.ks-grid-2 { grid-template-columns: 1fr; }
.ks-grid-3 { grid-template-columns: 1fr; }
.ks-grid-4 { grid-template-columns: 1fr; }
.ks-bento-grid { grid-template-columns: 1fr; gap: var(--ks-gap-cards); } 
.ks-align-center { align-items: center; }

@media (min-width: 768px) {
    .ks-grid-2 { grid-template-columns: 1fr 1fr; }
    .ks-grid-3 { grid-template-columns: repeat(3, 1fr); }
    .ks-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .ks-bento-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
}

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

/* --- CARDS & SURFACES --- */
.ks-card, .ks-pricing-card, .ks-support-box {
    border-radius: var(--ks-radius);
    background: var(--ks-gradient-card);
    border: 1px solid var(--ks-border);
    position: relative;
    overflow: hidden;
}

.ks-card::before, .ks-pricing-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; width: 100%; height: 1px;
    background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--ks-primary) 30%, transparent), transparent);
}

.ks-card {
    padding: clamp(1.5rem, 3vw, 2.5rem);
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.4s ease, border-color 0.4s ease;
}

.ks-card-hover:hover, .ks-card-bento:hover {
    transform: translateY(-6px);
    box-shadow: var(--ks-glow-hover);
    border-color: color-mix(in srgb, var(--ks-primary) 60%, transparent);
}

.ks-bento-title {
    color: var(--ks-primary) !important;
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 0.75rem;
    font-size: 1.25rem;
}

/* --- SECTIONS (Bestehende) --- */

.ks-block.ks-hero {
    margin-top: 0 !important; 
    padding-top: 2rem !important; 
    position: relative;
    z-index: 1;
}

.ks-hero::before {
    content: '';
    position: absolute;
    top: 40%; left: 50%;
    transform: translate(-50%, -50%);
    width: min(800px, 100%); aspect-ratio: 1;
    background: radial-gradient(circle, color-mix(in srgb, var(--ks-primary) 18%, transparent) 0%, transparent 60%);
    filter: blur(60px);
    z-index: -1;
    pointer-events: none;
}

.ks-hero h1 {
    margin-top: 0 !important; 
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.1;
    font-weight: 800;
}

.ks-hero .ks-subtext {
    font-size: clamp(1.1rem, 2vw, 1.25rem);
    max-width: 700px;
    margin: 1.5rem auto 2.5rem auto;
    color: var(--ks-secondary); 
}

.ks-step-number {
    font-size: 3.5rem;
    font-weight: 800;
    color: color-mix(in srgb, var(--ks-primary) 25%, transparent); 
    margin-bottom: 0.5rem;
    line-height: 1;
}

/* --- USP SECTION (Hover-Effekt & Bild-Layout) --- */
.ks-block.ks-usp.ks-bg-gradient {
    /* Wir machen den Verlauf 200% breit, um ihn sanft animieren zu können */
    background: linear-gradient(135deg, var(--ks-base) 0%, color-mix(in srgb, var(--ks-primary) 15%, var(--ks-base)) 50%, var(--ks-base) 100%);
    background-size: 200% 200%;
    background-position: 0% 50%;
    transition: background-position 0.8s ease-in-out;
    padding: clamp(4rem, 8vw, 6rem) clamp(1.5rem, 3vw, 3rem);
    border-top: 1px solid color-mix(in srgb, var(--ks-primary) 20%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--ks-primary) 20%, transparent);
    position: relative;
}

/* Der Hover-Effekt verschiebt den Hintergrundverlauf flüssig */
.ks-block.ks-usp.ks-bg-gradient:hover {
    background-position: 100% 50%;
}

/* Das Layout für unser neues Bild */
.ks-usp-visual {
    aspect-ratio: 4/3;
    width: 100%;
    
    /* FIX 1: Hintergrund entfernen, damit die Sektion durchscheint */
    background: transparent; 
    
    border-radius: var(--ks-radius);
    
    /* FIX 2: Den eckigen Kasten-Schatten entfernen (sieht bei freigestellten PNGs sonst seltsam aus) */
    box-shadow: none; 
    
    overflow: hidden;
    display: block;
    opacity: 1;
}

.ks-usp-visual img {
    width: 100%;
    height: 100%;
    
    /* FIX 1: Zurück auf 'cover'. So füllt das Bild die Box randlos aus und wird zugeschnitten! */
    object-fit: cover; 
    
    /* FIX 2: Radius direkt auf das Bild anwenden (Wichtig für Safari iOS) */
    border-radius: var(--ks-radius); 
    
    display: block;
}

.ks-pricing-card {
    max-width: 480px;
    margin: 0 auto;
    padding: clamp(2.5rem, 5vw, 4rem);
    border: 2px solid var(--ks-primary); 
    box-shadow: var(--ks-glow-pricing);
    background: linear-gradient(180deg, var(--ks-bg-surface) 0%, color-mix(in srgb, var(--ks-primary) 15%, var(--ks-base)) 100%);
}

.ks-pricing-card .ks-price {
    font-size: clamp(3.5rem, 8vw, 5rem);
    font-weight: 800;
    line-height: 1;
    color: var(--ks-contrast);
}

ul.ks-benefits-list {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 2.5rem 0 !important;
    text-align: left;
}

ul.ks-benefits-list li {
    list-style: none !important;
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 15px;
    font-size: 1.1rem;
    color: var(--ks-contrast) !important;
}

ul.ks-benefits-list li::before {
    content: '✓';
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: color-mix(in srgb, var(--ks-primary) 15%, transparent);
    color: var(--ks-primary);
    border-radius: 50%;
    font-weight: bold;
    font-size: 0.85rem;
    flex-shrink: 0;
}

/* --- KONTAKT ANSPRECHPARTNER BOX (Visitenkarten-Layout) --- */
.ks-support-box {
    background: var(--ks-bg-surface);
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    padding: clamp(2rem, 4vw, 3rem);
    display: flex;
    flex-direction: column;
    /* FIX: Setzt den gesamten Inhalt der Box nach oben (nicht mehr zentriert) */
    justify-content: flex-start; 
}

/* Das neue Layout für Avatar und Text nebeneinander */
.ks-support-profile {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.ks-support-avatar {
    width: 80px; 
    height: 80px;
    /* FIX: Margin nach unten entfernt, da das Bild nun links steht */
    margin-bottom: 0; 
    border-radius: var(--ks-radius);
    overflow: hidden;
    box-shadow: var(--ks-shadow-base);
    background: var(--ks-base);
    display: block;
    /* FIX: Verhindert, dass das Bild gestaucht wird, wenn der Name sehr lang ist */
    flex-shrink: 0; 
}

.ks-support-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ks-support-info {
    display: flex;
    flex-direction: column;
    justify-content: center; /* Unterstützt die vertikale Zentrierung */
    gap: 0.15rem; /* Ein winziger, kontrollierter Abstand zwischen Rolle und Name */
}

.ks-support-role {
    /* FIX: Setzt alle Theme-Abstände auf 0 */
    margin: 0 !important; 
    font-size: 0.85rem;
    text-transform: uppercase; 
    letter-spacing: 0.5px;
    line-height: 1.2;
}

.ks-support-name {
    /* FIX: Löscht den heimlichen margin-top des h3-Tags */
    margin: 0 !important; 
    font-size: 1.4rem;
    line-height: 1.2;
}

.ks-support-links {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
    border-top: 1px solid color-mix(in srgb, var(--ks-border) 60%, transparent);
    padding-top: 1.5rem;
}

.ks-support-link-item {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--ks-contrast);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s ease;
    /* FIX: Erlaubt superlangen E-Mail-Adressen den Zeilenumbruch auf schmalen Handys */
    word-break: break-word; 
}

.ks-support-link-item:hover {
    color: var(--ks-primary);
}

/* Das Icon-Layout */
.ks-support-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: color-mix(in srgb, var(--ks-primary) 15%, transparent);
    border-radius: 50%;
    color: var(--ks-primary); 
    transition: all 0.2s ease;
    /* FIX: Verhindert strengstens, dass der Browser das Icon oval quetscht! */
    flex-shrink: 0; 
}

/* Ein cooler Hover-Effekt (Invertiert die Farben!) */
.ks-support-link-item:hover .ks-support-icon {
    background: var(--ks-primary);
    color: var(--ks-base); 
}

/* --- FIX: Smartes Layout für extrem schmale Bildschirme (< 480px) --- */
@media (max-width: 480px) {
    .ks-support-profile {
        flex-direction: column; /* Avatar und Name untereinander statt nebeneinander */
        text-align: center; /* Text zentrieren */
        gap: 0.75rem;
    }
    .ks-support-avatar {
        margin: 0 auto; /* Avatar in der Mitte zentrieren */
    }
}

/* ==================================================
    NEUE SEKTIONEN (INTERAKTIV & THEME-SYNC & AUTO-CROP)
    ================================================== */

/* --- 1. HERO SLIDER (Responsive & Multiline) --- */
.ks-slider-window { 
    display: inline-block; 
    vertical-align: bottom; 
    margin-bottom: -0.1em;
}
.ks-slider-list { 
    display: inline-grid; 
    padding: 0; 
    margin: 0; 
    align-items: center; 
}
.ks-slider-list > span { 
    grid-area: 1 / 1; 
    display: block; 
    padding-left: 5px; 
    color: var(--ks-primary); 
    white-space: normal; /* Erlaubt mehrzeiligen Text auf Mobile! */
    text-align: center;
    opacity: 0;
    transform: translateY(15px);
}

/* Dynamische Animationen für 1 bis 6 Wörter */
.ks-slider-count-1 > span { opacity: 1; transform: translateY(0); } /* Keine Animation für 1 Wort */

.ks-slider-count-2 > span { animation: ksFade2 6.25s infinite; }
.ks-slider-count-2 > span:nth-child(1) { animation-delay: 0s; }
.ks-slider-count-2 > span:nth-child(2) { animation-delay: 3.125s; }
@keyframes ksFade2 {
    0% { opacity: 0; transform: translateY(15px); }
    6%, 44% { opacity: 1; transform: translateY(0); }
    50%, 100% { opacity: 0; transform: translateY(-15px); }
}

.ks-slider-count-3 > span { animation: ksFade3 9.375s infinite; }
.ks-slider-count-3 > span:nth-child(1) { animation-delay: 0s; }
.ks-slider-count-3 > span:nth-child(2) { animation-delay: 3.125s; }
.ks-slider-count-3 > span:nth-child(3) { animation-delay: 6.25s; }
@keyframes ksFade3 {
    0% { opacity: 0; transform: translateY(15px); }
    4%, 29% { opacity: 1; transform: translateY(0); }
    33%, 100% { opacity: 0; transform: translateY(-15px); }
}

.ks-slider-count-4 > span { animation: ksFade4 12.5s infinite; }
.ks-slider-count-4 > span:nth-child(1) { animation-delay: 0s; }
.ks-slider-count-4 > span:nth-child(2) { animation-delay: 3.125s; }
.ks-slider-count-4 > span:nth-child(3) { animation-delay: 6.25s; }
.ks-slider-count-4 > span:nth-child(4) { animation-delay: 9.375s; }
@keyframes ksFade4 {
    0% { opacity: 0; transform: translateY(15px); }
    3%, 22% { opacity: 1; transform: translateY(0); }
    25%, 100% { opacity: 0; transform: translateY(-15px); }
}

.ks-slider-count-5 > span { animation: ksFade5 15.625s infinite; }
.ks-slider-count-5 > span:nth-child(1) { animation-delay: 0s; }
.ks-slider-count-5 > span:nth-child(2) { animation-delay: 3.125s; }
.ks-slider-count-5 > span:nth-child(3) { animation-delay: 6.25s; }
.ks-slider-count-5 > span:nth-child(4) { animation-delay: 9.375s; }
.ks-slider-count-5 > span:nth-child(5) { animation-delay: 12.5s; }
@keyframes ksFade5 {
    0% { opacity: 0; transform: translateY(15px); }
    2.5%, 17.5% { opacity: 1; transform: translateY(0); }
    20%, 100% { opacity: 0; transform: translateY(-15px); }
}

.ks-slider-count-6 > span { animation: ksFade6 18.75s infinite; }
.ks-slider-count-6 > span:nth-child(1) { animation-delay: 0s; }
.ks-slider-count-6 > span:nth-child(2) { animation-delay: 3.125s; }
.ks-slider-count-6 > span:nth-child(3) { animation-delay: 6.25s; }
.ks-slider-count-6 > span:nth-child(4) { animation-delay: 9.375s; }
.ks-slider-count-6 > span:nth-child(5) { animation-delay: 12.5s; }
.ks-slider-count-6 > span:nth-child(6) { animation-delay: 15.625s; }
@keyframes ksFade6 {
    0% { opacity: 0; transform: translateY(15px); }
    2%, 14% { opacity: 1; transform: translateY(0); }
    16.6%, 100% { opacity: 0; transform: translateY(-15px); }
}

/* Editor Overrides für leichtere Text-Bearbeitung der animierten Headlines */
.ks-is-editor.ks-slider-window .ks-slider-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 1rem;
}
.ks-is-editor.ks-slider-window .ks-slider-list > span {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    border: 1px dashed var(--ks-primary);
    border-radius: 4px;
    padding: 0.2rem 0.5rem;
    padding-right: 35px; /* Platz für den X-Button */
}
.ks-is-editor.ks-slider-window .ks-add-item-btn { margin-top: 10px; }


/* --- 2. REVIEWS (Responsive Popover Layout) --- */
.ks-reviews-wrapper { 
    max-width: 1000px; 
    margin: 0 auto; 
    overflow-x: clip; /* FIX: Verhindert den horizontalen Scroll! */
    padding: 0.5rem; 
}

/* Flex-Grid zentriert die Items vollautomatisch, egal wie viele Platz haben */
.ks-reviews-grid { 
    display: flex; 
    flex-wrap: wrap; 
    justify-content: center; 
    gap: 3rem 2rem; 
    margin-top: 3rem; 
}

/* z-index: 1 stellt sicher, dass offene Popovers immer über geschlossenen liegen */
.ks-review-item { 
    position: relative; 
    display: flex; 
    align-items: center; 
    gap: 15px; 
    width: 300px; 
    max-width: 100%;
    z-index: 1; 
}
.ks-review-item.is-open { z-index: 10; }

/* Auto-Crop Avatar quadratisch */
.ks-review-avatar-wrap { 
    width: 70px; height: 70px; border-radius: var(--ks-radius); overflow: hidden; 
    box-shadow: var(--ks-shadow-base); border: 2px solid var(--ks-border); flex-shrink: 0; background: var(--ks-bg-surface); 
}
.ks-review-avatar-wrap img { width: 100%; height: 100%; object-fit: cover; }

.ks-review-meta h4 { font-size: 1rem; margin: 0 0 2px 0; line-height: 1.2; }
.ks-review-stars { color: var(--ks-primary); font-size: 0.8rem; margin-bottom: 6px; letter-spacing: 2px; }
.ks-review-btn { background: var(--ks-bg-surface); border: 1px solid var(--ks-border); color: var(--ks-contrast); font-size: 0.75rem; padding: 4px 12px; border-radius: 50px; cursor: pointer; transition: 0.2s; font-weight: 600; outline: none; }
.ks-review-btn:hover { border-color: var(--ks-primary); color: var(--ks-primary); }

/* Popover Logic - Desktop (Öffnet nach oben) */
.ks-review-popover { 
    position: absolute; bottom: calc(100% + 15px); left: 50%; transform: translateX(-50%) translateY(10px); 
    background: var(--ks-base); border: 1px solid var(--ks-border); padding: 1.5rem; border-radius: var(--ks-radius); 
    /* FIX: box-shadow entfernt und max-width von 320px auf 280px reduziert, damit es in die Clip-Box passt */
    box-shadow: none; width: max-content; max-width: 280px; font-size: 0.95rem; color: var(--ks-contrast); 
    opacity: 0; visibility: hidden; transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); pointer-events: none; text-align: left; 
}
.ks-review-item.is-open .ks-review-popover { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); pointer-events: auto; }

/* Pfeil für Desktop-Popover */
.ks-review-popover::after {
    content: ''; position: absolute; bottom: -6px; left: 50%; transform: translateX(-50%) rotate(45deg);
    width: 12px; height: 12px; background: var(--ks-base); border-bottom: 1px solid var(--ks-border); border-right: 1px solid var(--ks-border);
}

/* Editor Overrides (Dauerhaft sichtbar & editierbar) */
.ks-is-editor .ks-review-popover { 
    position: relative; bottom: auto; left: auto; transform: none; opacity: 1; visibility: visible; width: 100%; 
    margin-top: 15px; border: 1px dashed var(--ks-border); box-shadow: none; background: transparent; pointer-events: auto;
}
.ks-is-editor .ks-review-popover::after { display: none; }

/* Tablet & Mobile Layout Adjustments (Zig-Zag Chat-Layout) */
@media (max-width: 740px) {
    /* Ab Tablet erzwingen wir eine Spalte für den links/rechts Verlauf */
    .ks-reviews-grid { flex-direction: column; align-items: stretch; gap: 2.5rem; }
    
    /* Basis-Größe: Etwas schmaler, damit sie wirklich links und rechts am Rand kleben */
    .ks-review-item { width: 85%; max-width: 450px; }

    /* UNGERADE (1, 3, 5...): Linksbündig */
    .ks-review-item:nth-child(odd) { align-self: flex-start; }
    .ks-review-item:not(.ks-is-editor):nth-child(odd) .ks-review-popover { left: 0; transform: translateY(-10px); bottom: auto; top: calc(100% + 15px); width: max-content; max-width: calc(100vw - 2rem); }
    .ks-review-item:not(.ks-is-editor):nth-child(odd).is-open .ks-review-popover { transform: translateY(0); }
    .ks-review-item:nth-child(odd) .ks-review-popover::after { bottom: auto; top: -6px; border-bottom: none; border-right: none; border-top: 1px solid var(--ks-border); border-left: 1px solid var(--ks-border); left: 35px; }

    /* GERADE (2, 4...): Rechtsbündig & gespiegelt (Avatar ist rechts!) */
    .ks-review-item:nth-child(even) { align-self: flex-end; flex-direction: row-reverse; text-align: right; }
    /* Popover für die rechten Elemente ausrichten, aber den Text darin lesbar linksbündig lassen */
    .ks-review-item:not(.ks-is-editor):nth-child(even) .ks-review-popover { right: 0; left: auto; transform: translateY(-10px); bottom: auto; top: calc(100% + 15px); width: max-content; max-width: calc(100vw - 2rem); text-align: left; }
    .ks-review-item:not(.ks-is-editor):nth-child(even).is-open .ks-review-popover { transform: translateY(0); }
    /* Pfeil für rechte Kacheln exakt über den nun rechten Avatar setzen */
    .ks-review-item:nth-child(even) .ks-review-popover::after { bottom: auto; top: -6px; border-bottom: none; border-right: none; border-top: 1px solid var(--ks-border); border-left: 1px solid var(--ks-border); left: auto; right: 35px; }
}

@media (max-width: 640px) {
    /* 1. Die Kachel nimmt 100% der Theme-Breite ein. (Der Zig-Zag bleibt durch das Flex-Layout bestehen!) */
    .ks-review-item { 
        width: 100%; 
        max-width: 100%; 
    }

    /* 2. Das Popover füllt nun exakt die 100% Kachelbreite – kein Überstehen mehr! */
    .ks-review-item:not(.ks-is-editor):nth-child(odd) .ks-review-popover,
    .ks-review-item:not(.ks-is-editor):nth-child(even) .ks-review-popover {
        width: 100%; 
        max-width: 100%;
        left: 0;
        right: auto;
        box-sizing: border-box; /* Stellt sicher, dass das Padding nicht addiert wird */
    }

    /* 3. Die Pfeile sitzen exakt über der Mitte des Avatars (70px Avatar = 35px Mitte) */
    .ks-review-item:nth-child(odd) .ks-review-popover::after { left: 35px; right: auto; }
    .ks-review-item:nth-child(even) .ks-review-popover::after { right: 35px; left: auto; }
}


/* --- 3. CTA GRADIENT BANNER (Auto-Crop) --- */
.ks-cta-banner {
    background: linear-gradient(135deg, var(--ks-bg-surface) 0%, color-mix(in srgb, var(--ks-primary) 20%, var(--ks-base)) 100%);
    border: 1px solid var(--ks-primary); box-shadow: var(--ks-glow-hover);
}
.ks-cta-img-wrap { aspect-ratio: 1/1; width: 100%; border-radius: var(--ks-radius); overflow: hidden; }
.ks-cta-img-wrap img { width: 100%; height: 100%; object-fit: cover; }

/* --- 4. AMPLITUDE SERVICES TABS (Auto-Crop 4:3) --- */
.amplitude-wrapper { display: flex; align-items: center; justify-content: space-between; gap: 60px; max-width: 1100px; margin: 0 auto; }
.amplitude-left { flex: 1; min-width: 300px; }
.tab-item { padding: 20px 24px; cursor: pointer; margin-bottom: 8px; border-radius: var(--ks-radius); transition: all 0.2s ease; border-left: 4px solid transparent; color: var(--ks-contrast); }
.tab-item:hover { background-color: var(--ks-bg-surface); }
.tab-item.active { background-color: var(--ks-bg-surface); border-left-color: var(--ks-primary); }
.tab-title { font-size: 1.25rem; font-weight: 600; margin: 0; }
.tab-desc-wrapper { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.3s ease; }
.tab-item.active .tab-desc-wrapper { grid-template-rows: 1fr; }
.tab-desc { overflow: hidden; color: var(--ks-secondary); font-size: 1rem; }
.tab-desc-inner { padding-top: 12px; }

.amplitude-right { flex: 1.2; position: relative; aspect-ratio: 4/3; width: 100%; }
.image-stack { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: var(--ks-radius); overflow: hidden; background: var(--ks-bg-surface); box-shadow: var(--ks-shadow-base); }
.image-stack img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.4s ease; z-index: 1; }
.image-stack img.active { opacity: 1; z-index: 2; }

@media (max-width: 900px) {
    .amplitude-wrapper { flex-direction: column; gap: 40px; }
    .amplitude-left { order: 2; } .amplitude-right { order: 1; width: 100%; flex: auto; aspect-ratio: 4/3; }
}

/* --- 5. PROJECTS TAB SWITCHER (Auto-Crop 4:3) --- */
.tab-switcher-container { font-family: inherit; }
.tab-nav { display: flex; justify-content: center; gap: 15px; margin-bottom: 50px; flex-wrap: nowrap; }
.tab-btn { padding: 16px 24px; border: 1px solid var(--ks-border); border-radius: var(--ks-radius); background: var(--ks-bg-surface); color: var(--ks-contrast); font-size: 1.1rem; font-weight: 600; cursor: pointer; transition: all 0.3s ease; text-align: center; flex: 1; }
.tab-btn:hover { border-color: var(--ks-primary); }
.tab-btn.active { background: var(--ks-primary); color: var(--ks-base); border-color: var(--ks-primary); }
.tab-sub { display: block; font-size: 0.85rem; font-weight: 400; margin-bottom: 4px; opacity: 0.8; }
.tab-panel { display: none; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.tab-panel.active { display: grid; animation: smoothFade 0.5s ease forwards; }

.panel-text h3 { font-size: 2rem; margin-bottom: 20px; line-height: 1.2; }
.panel-text p { font-size: 1.1rem; color: var(--ks-secondary); line-height: 1.6; }
/* 1. Der Wrapper bekommt den Radius, die Hintergrundfarbe und den sauberen Schatten */
.panel-img-wrapper { 
    position: relative; 
    aspect-ratio: 4/3; 
    width: 100%; 
    z-index: 1; 
    border-radius: var(--ks-radius); 
    box-shadow: var(--ks-shadow-base); 
    background: var(--ks-base); 
}

/* 2. (Die alte ::before Klasse bleibt gelöscht!) */

/* 3. Das Bild füllt den Wrapper einfach nur noch aus */
.panel-img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    border-radius: var(--ks-radius); 
    display: block; 
}
@keyframes smoothFade { 0% { opacity: 0; transform: translateY(10px); } 100% { opacity: 1; transform: translateY(0); } }

@media (max-width: 900px) {
    .tab-nav { flex-direction: column; gap: 10px; }
    .tab-panel.active { grid-template-columns: 1fr; gap: 30px; }
    .panel-img-wrapper { order: -1; margin-right: 20px; }
}

/* --- 6. ABOUT US & SWIPE GALLERY (Auto-Crop) --- */
/* FIX: max-width hinzugefügt, damit das Bild nicht mehr riesig wird. margin: 0 auto zentriert es schön. */
.ks-about-img {
    aspect-ratio: 1/1;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    border-radius: var(--ks-radius);
    box-shadow: var(--ks-shadow-base);
    background: var(--ks-bg-surface);
    overflow: hidden;
    position: relative;
}
.ks-about-img img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}

.css-swipe-slider { display: flex; gap: var(--ks-gap-cards); overflow-x: auto; scrollbar-width: none; padding: 1rem 0 2rem 0; width: 100%; }
.css-swipe-slider::-webkit-scrollbar { display: none; }
/* FIX: Schatten vom img auf das ks-gallery-item verschoben, um Doppelungen zu vermeiden */
.css-swipe-slider .ks-gallery-item { margin: 0; flex: 0 0 auto; width: 320px; border-radius: var(--ks-radius); box-shadow: var(--ks-shadow-base); background: var(--ks-bg-surface); }
.css-swipe-slider img { aspect-ratio: 4/3; width: 100%; height: auto; object-fit: cover; border-radius: var(--ks-radius); display: block; }

/* --- SWIPE GALERIE (Mit weichem Fade-Effekt an den Rändern) --- */
.ks-gallery-fullwidth .css-swipe-slider {
    width: 100%; /* Bleibt sicher im Layout-Rahmen, kein horizontaler Scroll mehr! */
    padding-left: 0 !important;
    padding-right: 0 !important;
    
    /* Der magische Fade-Effekt: Blendet die Ränder links und rechts weich aus */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 15%, black 85%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 15%, black 85%, transparent 100%);
}

/* Auf dem Handy machen wir den Fade-Bereich etwas kleiner, um Platz zu sparen */
@media (max-width: 768px) {
    .ks-gallery-fullwidth .css-swipe-slider {
        -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
        mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
    }
}

/* --- 8. MEDIA GALLERY (Bento Grid) --- */
.ks-media-bento {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: var(--ks-gap-cards);
    max-width: 1200px;
    margin: 0 auto;
}

.ks-media-main {
    grid-column: 1 / 2;
    grid-row: 1 / 3;
    border-radius: var(--ks-radius);
    overflow: hidden;
    box-shadow: var(--ks-shadow-base);
    background: var(--ks-bg-surface);
    aspect-ratio: 16/9;
    min-height: 0; 
    min-width: 0;
    position: relative; /* FIX 1: Verankert den Rahmen für absolute Kinder */
}

.ks-media-sub {
    border-radius: var(--ks-radius);
    overflow: hidden;
    box-shadow: var(--ks-shadow-base);
    background: var(--ks-bg-surface);
    min-height: 0; 
    min-width: 0;
    position: relative; /* FIX 2: Verankert den Rahmen für absolute Kinder */
}

/* FIX 3: Im Editor zwingen wir die Buttons absolut in die Box. So können sie das Grid niemals aufdehnen. */
.ks-media-bento .components-button {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
}

/* FIX 4: Im Frontend zwingen wir Bilder/Videos absolut in die Box. */
.ks-media-el {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Auf mobilen Geräten elegant untereinander anordnen */
@media (max-width: 768px) {
    .ks-media-bento {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
    }
    .ks-media-main {
        grid-column: 1 / 3;
    }
    .ks-media-sub {
        aspect-ratio: 1/1;
    }
}

/* NEU: Ansprechpartner Avatar im Kontakt-Block (Mit Theme-Radius) */
.ks-support-avatar {
    width: 100px; 
    height: 100px;
    margin-bottom: 1.5rem;
    
    /* FIX: Hier nutzen wir jetzt deinen globalen Ecken-Radius anstatt eines Kreises */
    border-radius: var(--ks-radius); 
    
    overflow: hidden;
    box-shadow: var(--ks-shadow-base);
    background: var(--ks-bg-surface);
    display: block;
}

.ks-support-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* --- DYNAMISCHER MOUSE-GLOW FÜR CTA, PRICING & KONTAKT --- */
.ks-cta-banner, 
.ks-pricing-card, 
.ks-contact-card {
    position: relative;
    background: var(--ks-bg-surface) !important;
    border: 1px solid color-mix(in srgb, var(--ks-primary) 25%, transparent) !important;
    box-shadow: var(--ks-shadow-base) !important;
    overflow: hidden;
    transition: border-color 0.4s ease, box-shadow 0.4s ease;
}

/* Der Leucht-Effekt als unsichtbares Overlay */
.ks-cta-banner::after, 
.ks-pricing-card::after, 
.ks-contact-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    
    /* Der Trick: Wir nutzen JS-Variablen für die Maus-Position. 
       Wenn JS nicht läuft (wie im Editor), greift der Fallback "50% 50%" (Mitte) */
    background: radial-gradient(
        circle 600px at var(--mouse-x, 50%) var(--mouse-y, 50%), 
        color-mix(in srgb, var(--ks-primary) 12%, transparent) 0%, 
        transparent 70%
    );
    opacity: 0;
    transition: opacity 0.5s ease;
    z-index: 0;
    pointer-events: none; /* Klicks gehen durch den Glow hindurch */
}

/* Schaltet das Licht an, wenn die Maus über die Karte fährt */
.ks-cta-banner:hover::after, 
.ks-pricing-card:hover::after, 
.ks-contact-card:hover::after {
    opacity: 1; 
}

/* Rahmen und Schatten leuchten ebenfalls leicht auf */
.ks-cta-banner:hover, 
.ks-pricing-card:hover, 
.ks-contact-card:hover {
    border-color: color-mix(in srgb, var(--ks-primary) 60%, transparent) !important;
    box-shadow: var(--ks-glow-hover) !important;
}

/* Alle Inhalte (Texte, Buttons, Bilder) müssen über dem Leuchten liegen */
.ks-cta-banner > *, 
.ks-pricing-card > *, 
.ks-contact-card > * {
    position: relative;
    z-index: 1;
}

/* --- HINTERGRUND FÜR PROJEKTE TABS (Wie USP, aber statisch & eckig) --- */
.wp-block-koloneo-section-projects {
    /* Exakt derselbe Farbverlauf wie bei USP */
    background: linear-gradient(135deg, var(--ks-base) 0%, color-mix(in srgb, var(--ks-primary) 15%, var(--ks-base)) 50%, var(--ks-base) 100%);
    
    /* Schafft Platz nach innen (oben/unten und links/rechts) */
    padding: clamp(4rem, 8vw, 6rem) clamp(1.5rem, 3vw, 3rem);
    
    /* Eckige Begrenzungslinien oben und unten (passend zum USP) */
    border-top: 1px solid color-mix(in srgb, var(--ks-primary) 20%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--ks-primary) 20%, transparent);
}

/* --- GLOBALES BILDER-STYLING (Rand statt Schatten für alle Bilder) --- */
.ks-review-avatar-wrap,
.image-stack,
.panel-img-wrapper,
.ks-about-img,
.css-swipe-slider .ks-gallery-item,
.ks-media-main,
.ks-media-sub,
.ks-support-avatar {
    box-shadow: none !important; /* Entfernt den bisherigen Schatten überall */
    border: 1px solid var(--ks-border) !important; /* Fügt exakt den Rand der Statistik-Kacheln hinzu */
}

/* --- FIX: Innenabstand und abgerundete Ecken für die Kontakt-Karte --- */
.ks-contact-card {
    padding: clamp(2rem, 5vw, 4rem); /* Responsiver Innenabstand wie bei den anderen großen Karten */
    border-radius: var(--ks-radius); /* Übernimmt deine globalen abgerundeten Ecken */
}

/* --- FAQ SECTION (Akkordeon) --- */
.ks-faq-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
.ks-faq-item { background: var(--ks-bg-surface); border: 1px solid var(--ks-border); border-radius: var(--ks-radius); overflow: hidden; transition: border-color 0.3s ease; }
.ks-faq-item:hover { border-color: color-mix(in srgb, var(--ks-primary) 50%, transparent); }

/* Frage Button */
.ks-faq-question { width: 100%; text-align: left; padding: 1.5rem; background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; color: var(--ks-contrast); font-size: 1.1rem; font-weight: 600; font-family: inherit; transition: color 0.2s ease; }
.ks-faq-question:hover { color: var(--ks-primary); }

/* Animiertes Plus/Minus Icon */
.ks-faq-icon { position: relative; width: 24px; height: 24px; flex-shrink: 0; margin-left: 15px; background: color-mix(in srgb, var(--ks-primary) 15%, transparent); border-radius: 50%; }
.ks-faq-icon::before, .ks-faq-icon::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--ks-primary); transition: transform 0.3s ease, opacity 0.3s ease; }
.ks-faq-icon::before { width: 10px; height: 2px; } /* Horizontale Linie (-) */
.ks-faq-icon::after { width: 2px; height: 10px; } /* Vertikale Linie (|) */
.ks-faq-item.active .ks-faq-icon::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; } /* Wird zum Minus */

/* Animierter Antwort-Bereich (Grid-Trick) */
.ks-faq-answer-wrapper { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.3s ease; }
.ks-faq-item.active .ks-faq-answer-wrapper { grid-template-rows: 1fr; }
.ks-faq-answer-inner { overflow: hidden; }

/* FIX: Top-Padding von 0 auf 0.5rem (oder 1rem) erhöht, damit die Antwort weiter runter rückt */
.ks-faq-answer-content { padding: 0.5rem 1.5rem 1.5rem 1.5rem; color: var(--ks-secondary); font-size: 1rem; line-height: 1.6; }

/* Editor Darstellung (Im Editor sind alle immer offen) */
/* FIX: Gestrichelte Linie und komische Margins entfernt, damit es sauber aussieht */
.ks-is-editor .ks-faq-answer-wrapper { grid-template-rows: 1fr; }

/* ==================================================
   NEUE TEMPLATE SECTIONS (Aus Screenshots)
   ================================================== */

/* 1. Twin Media (Text links, 2 hohe Bilder rechts) - IMG_5954 */
.ks-tmpl-twin-media-right {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ks-gap-cards);
}
.ks-tmpl-img-portrait {
    aspect-ratio: 3/4;
    width: 100%;
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    background: var(--ks-bg-surface);
    overflow: hidden;
    position: relative;
}
.ks-tmpl-img-portrait img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}

/* 2. Three Cards (3 vertikale Bilder mit Text drunter) - IMG_5959 */
.ks-tmpl-card-img {
    aspect-ratio: 1/1;
    width: 100%;
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    background: var(--ks-bg-surface);
    overflow: hidden;
    position: relative;
    margin-bottom: 1rem;
}

.ks-tmpl-card-img img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.ks-tmpl-card-meta h4 { margin: 0 0 4px 0; font-size: 1.1rem; line-height: 1.2; }
.ks-tmpl-card-meta p { margin: 0; font-size: 0.9rem; color: var(--ks-secondary); }

/* 3. Bento Four (1 Großes Bild links, 3 rechts) - IMG_5960 */
.ks-tmpl-bento-four {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--ks-gap-cards);
}
.ks-tmpl-bento-item {
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    background: var(--ks-bg-surface);
    position: relative;
    overflow: hidden;
    min-height: 150px;
}
/* Vertikal gespiegelt: Hauptbild rechts */
.ks-tmpl-bento-main  { grid-column: 3 / 4; grid-row: 1 / 3; }
.ks-tmpl-bento-top   { grid-column: 1 / 3; grid-row: 1 / 2; aspect-ratio: 2/1; }
.ks-tmpl-bento-bot-l { grid-column: 1 / 2; grid-row: 2 / 3; aspect-ratio: 1/1; }
.ks-tmpl-bento-bot-r { grid-column: 2 / 3; grid-row: 2 / 3; aspect-ratio: 1/1; }
/* Editor-Fix: Buttons füllen die Zelle (wie bei Media Bento) */
.ks-tmpl-bento-item .components-button {
    position: absolute !important;
    top: 0; left: 0;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
}

/* 4. Feature Split (Text oben, 2 große Bilder unten) - IMG_5957 */
.ks-tmpl-feature-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ks-gap-sections);
    margin-bottom: var(--ks-gap-sections);
    align-items: end;
}
.ks-tmpl-img-square {
    aspect-ratio: 1/1;
    width: 100%;
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    background: var(--ks-bg-surface);
    overflow: hidden;
    position: relative;
}
.ks-tmpl-img-square img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}

/* Mobile Anpassungen */
@media (max-width: 768px) {
    .ks-tmpl-feature-header { grid-template-columns: 1fr; }
    .ks-tmpl-bento-four { grid-template-columns: 1fr 1fr; }
    .ks-tmpl-bento-main  { grid-column: 1 / 3; grid-row: auto; aspect-ratio: 4/3; }
    .ks-tmpl-bento-top   { grid-column: 1 / 3; grid-row: auto; }
    .ks-tmpl-bento-bot-l { grid-column: 1 / 2; grid-row: auto; }
    .ks-tmpl-bento-bot-r { grid-column: 2 / 3; grid-row: auto; }
}

/* 5. Single Large Image - IMG_5956 */
.ks-tmpl-single-image-wrap {
    width: 100%;
    aspect-ratio: 16/9; /* Breitbild-Format */
    border-radius: var(--ks-radius);
    border: 1px solid var(--ks-border);
    overflow: hidden;
    background: var(--ks-bg-surface);
}
.ks-tmpl-single-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* 6. Text Only */
.ks-tmpl-text-only {
    max-width: 800px;
    margin: 0 auto;
}
/* Optional: Wenn der Text-Block immer zentriert sein soll, entferne die /* vor der nächsten Zeile */
/* .ks-tmpl-text-only { text-align: center; } */