/* =========================================================================
   Vistema Videos – Plattform-Look (v2.0.0)
   1:1 nachgebaut nach app.vistema.org/videos
   ========================================================================= */

.vistema-wrap {
    /* Design-Tokens vom Plattform-Look ------------------------------------- */
    --vis-text:        #111111;
    --vis-text-soft:   #374151;
    --vis-text-mute:   #6b7280;
    --vis-bg:          #ffffff;
    --vis-bg-soft:     #f7f8fa;
    --vis-border:      #e5e7eb;
    --vis-border-2:    #f0f0f0;

    /* Beige/Cream wie auf der Plattform */
    --vis-beige:       #f4ead8;
    --vis-beige-2:     #ecd9b8;
    --vis-beige-text:  #6b5530;

    /* Goldener Preis-Frame */
    --vis-gold:        #c9a458;
    --vis-gold-soft:   #f9f1de;

    /* Gratis (grün) */
    --vis-free-bg:     #d8f3dc;
    --vis-free-text:   #2d6a4f;
    --vis-free-border: #a7d8b7;

    --vis-radius:      14px;
    --vis-radius-sm:   8px;
    --vis-radius-pill: 999px;

    --vis-shadow:      0 1px 2px rgba(15,23,42,.04), 0 4px 14px rgba(15,23,42,.05);
    --vis-shadow-lg:   0 4px 8px rgba(15,23,42,.05), 0 18px 40px rgba(15,23,42,.08);

    color: var(--vis-text);
    max-width: 1280px;
    margin: 0 auto;
    overflow-x: clip;
}

.vistema-wrap *,
.vistema-wrap *::before,
.vistema-wrap *::after { box-sizing: border-box; }

/* Theme-Reset für Links */
.vistema-wrap a,
.vistema-wrap a:visited,
.vistema-wrap a:hover,
.vistema-wrap a:active {
    color: inherit;
    text-decoration: none;
}

/* =========================================================================
   Toolbar (Filter + Layout-Toggle)
   ========================================================================= */
.vistema-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .6rem;
    margin: 0 0 1.75rem;
}
.vistema-filter {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    flex: 1 1 auto;
    min-width: 0;
}
.vistema-filter__search,
.vistema-filter__cat {
    height: 44px;
    padding: 0 1rem;
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius-sm);
    font: inherit;
    font-size: 15px;
    background: var(--vis-bg);
    color: var(--vis-text);
    transition: border-color .15s ease, box-shadow .15s ease;
    box-sizing: border-box;
    line-height: 1;
}
.vistema-filter__search::placeholder { color: var(--vis-text-mute); }
.vistema-filter__search:focus,
.vistema-filter__cat:focus {
    outline: none;
    border-color: var(--vis-text);
    box-shadow: 0 0 0 3px rgba(17,17,17,.08);
}
.vistema-filter__search { flex: 1 1 280px; min-width: 200px; }
.vistema-filter__cat {
    flex: 0 1 220px;
    cursor: pointer;
    /* Custom-Caret per SVG-Background, mehr Platz rechts damit's nicht am Rand klebt */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 2.5rem;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='1 1 6 6 11 1'/></svg>");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 12px 8px;
}
.vistema-filter__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid var(--vis-text);
    border-radius: var(--vis-radius-sm);
    background: var(--vis-text);
    color: #fff;
    font: inherit;
    cursor: pointer;
    transition: background .15s ease;
    flex-shrink: 0;
    box-sizing: border-box;
}
.vistema-filter__submit:hover { background: #000; }
.vistema-filter__submit svg { display: block; }

/* Layout-Toggle */
.vistema-layout-toggle {
    display: inline-flex;
    height: 44px;
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius-sm);
    overflow: hidden;
    background: var(--vis-bg);
    flex-shrink: 0;
    box-sizing: border-box;
}
.vistema-layout-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 100%;
    color: var(--vis-text-mute);
    border-right: 1px solid var(--vis-border);
    transition: background .15s ease, color .15s ease;
}
.vistema-layout-btn:last-child { border-right: 0; }
.vistema-layout-btn:hover { color: var(--vis-text); background: var(--vis-bg-soft); }
.vistema-layout-btn.is-active {
    background: var(--vis-text);
    color: #fff !important;
}

/* =========================================================================
   GRID
   ========================================================================= */
.vistema-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}

/* =========================================================================
   CARD
   ========================================================================= */
.vistema-card {
    background: var(--vis-bg);
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius);
    overflow: hidden;
    box-shadow: var(--vis-shadow);
    transition: transform .25s cubic-bezier(.4,0,.2,1),
                box-shadow .25s cubic-bezier(.4,0,.2,1),
                border-color .2s ease;
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.vistema-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--vis-shadow-lg);
    border-color: #d4d4d4;
}

.vistema-card__media {
    display: block;
    aspect-ratio: 16 / 9;
    background: linear-gradient(135deg, #f3f4f6, #e5e7eb);
    overflow: hidden;
    flex-shrink: 0;
}
.vistema-card__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.vistema-card:hover .vistema-card__media img { transform: scale(1.03); }

.vistema-card__body {
    padding: 1.1rem 1.25rem 1.25rem;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-width: 0;
    gap: .7rem;
}

.vistema-card__head {
    display: flex;
    gap: .75rem;
    align-items: flex-start;
    justify-content: space-between;
}
.vistema-card__title-link {
    flex: 1 1 auto;
    min-width: 0;
}
.vistema-card__title {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    line-height: 1.3;
    letter-spacing: -.01em;
    margin: 0;
    color: var(--vis-text) !important;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.vistema-card__summary {
    color: var(--vis-text-soft);
    font-size: .92rem;
    line-height: 1.55;
    margin: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* HTML-Inhalte zähmen */
.vistema-card__summary p,
.vistema-card__summary span,
.vistema-card__summary div,
.vistema-card__summary strong,
.vistema-card__summary em,
.vistema-card__summary b,
.vistema-card__summary i,
.vistema-card__summary h1,
.vistema-card__summary h2,
.vistema-card__summary h3,
.vistema-card__summary h4 {
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}
.vistema-card__summary br { display: none !important; }
.vistema-card__summary p + p::before { content: " "; }
.vistema-card__summary img,
.vistema-card__summary svg,
.vistema-card__summary iframe { display: none !important; }
.vistema-card__summary ul,
.vistema-card__summary ol,
.vistema-card__summary li {
    display: inline !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.vistema-card__cats {
    display: flex; flex-wrap: wrap; gap: .35rem;
    margin: 0;
}

.vistema-card__foot {
    margin-top: auto;
    padding-top: .15rem;
    display: flex;
    align-items: stretch;
    gap: .5rem;
}
.vistema-card__foot .vistema-action {
    flex: 1 1 auto;
    width: auto;
}
.vistema-card__foot .vistema-price-badge {
    flex: 0 0 auto;
    align-self: stretch;
    display: inline-flex;
    align-items: center;
}

/* =========================================================================
   BADGES (Kategorie + Preis)
   ========================================================================= */

/* Re-add anchor class */
.vistema-anchor {
    display: block;
    width: 0; height: 0;
    overflow: hidden;
    scroll-margin-top: 24px;
}

/* =========================================================================
   DETAIL-SEITE: Marketing-Sections oberhalb ausblenden
   -------------------------------------------------------------------------
   Das Plugin setzt die Body-Klasse `vistema-is-detail` wenn die
   Detail-Ansicht (?id=NN) aktiv ist.

   So nutzt du das in Elementor:
   1. Section markieren (Hero, Willkommen-Block, ...)
   2. "Erweitert" → "CSS-Klassen" → Klasse `vistema-hide-on-detail` eintragen
   3. Speichern

   Diese Sections werden dann nur auf der Detail-Seite ausgeblendet,
   auf der Übersichtsseite bleiben sie sichtbar.
   ========================================================================= */

.vistema-is-detail .vistema-hide-on-detail {
    display: none !important;
}

/* Kategorie-Badge: lesbar, gedämpft, Identifier-Farbe als Akzent */
.vistema-badge {
    --vis-cat: #6b7280;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .28rem .7rem .28rem .65rem;
    border-radius: var(--vis-radius-pill);
    /* Heller Tint im Hintergrund (12% Sättigung) */
    background: color-mix(in srgb, var(--vis-cat) 14%, #ffffff);
    /* Dunkle Variante der Kategoriefarbe für Lesbarkeit */
    color: color-mix(in srgb, var(--vis-cat) 55%, #0a0a0a);
    font-size: .76rem;
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: .005em;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    border: 1px solid color-mix(in srgb, var(--vis-cat) 22%, transparent);
}
/* Punkt links als Akzent in Vollfarbe */
.vistema-badge::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--vis-cat);
    flex-shrink: 0;
}
/* Fallback für sehr alte Browser ohne color-mix */
@supports not (color: color-mix(in srgb, red, blue)) {
    .vistema-badge {
        background: #f3f4f6;
        color: #374151;
        border-color: #e5e7eb;
    }
}

/* Preis-Badge: goldener Frame, transparent / cremiger Hintergrund */
.vistema-price-badge {
    display: inline-flex;
    align-items: center;
    padding: .35rem .85rem;
    border-radius: var(--vis-radius-sm);
    border: 1.5px solid var(--vis-gold);
    background: var(--vis-gold-soft);
    color: var(--vis-beige-text);
    font-size: .9rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: .005em;
}
.vistema-price-badge.is-free {
    border-color: var(--vis-free-border);
    background: var(--vis-free-bg);
    color: var(--vis-free-text);
}

/* =========================================================================
   ACTION-BUTTON (Kaufen / Hinzufügen)
   ========================================================================= */

.vistema-action,
.vistema-action:hover,
.vistema-action:visited,
.vistema-action:focus,
.vistema-action:active {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    width: 100%;
    padding: .7rem 1rem;
    background: var(--vis-beige);
    border: 1px solid var(--vis-beige-2);
    border-radius: var(--vis-radius-sm);
    color: var(--vis-beige-text) !important;
    font: inherit;
    font-size: .95rem;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    text-align: center;
    -webkit-appearance: none;
    appearance: none;
    text-decoration: none !important;
}
.vistema-action {
    transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.vistema-action:hover {
    background: var(--vis-beige-2) !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(201,164,88,.15);
}
.vistema-action:focus-visible {
    outline: 2px solid var(--vis-text);
    outline-offset: 2px;
}
.vistema-action:active { transform: translateY(0); }
.vistema-action svg { flex-shrink: 0; }
.vistema-action--lg {
    padding: .9rem 1.25rem;
    font-size: 1rem;
}

/* =========================================================================
   LIST VIEW (Row)
   ========================================================================= */

.vistema-list {
    display: flex;
    flex-direction: column;
    gap: .9rem;
}
.vistema-row {
    display: grid;
    grid-template-columns: 200px 1fr auto;
    gap: 1.25rem;
    background: var(--vis-bg);
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius);
    padding: 1rem;
    box-shadow: var(--vis-shadow);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    align-items: center;
    min-width: 0;
}
.vistema-row:hover {
    transform: translateY(-1px);
    box-shadow: var(--vis-shadow-lg);
    border-color: #d4d4d4;
}
.vistema-row__media {
    display: block;
    aspect-ratio: 16 / 9;
    background: linear-gradient(135deg, #f3f4f6, #e5e7eb);
    border-radius: var(--vis-radius-sm);
    overflow: hidden;
    width: 100%;
}
.vistema-row__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.vistema-row__body {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}
.vistema-row__title {
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    margin: 0;
    color: var(--vis-text) !important;
    line-height: 1.3;
    letter-spacing: -.01em;
    overflow-wrap: anywhere;
}
.vistema-row__summary {
    color: var(--vis-text-soft);
    font-size: .92rem;
    line-height: 1.55;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.vistema-row__summary p,
.vistema-row__summary span,
.vistema-row__summary div,
.vistema-row__summary strong,
.vistema-row__summary em,
.vistema-row__summary b,
.vistema-row__summary i,
.vistema-row__summary h1,
.vistema-row__summary h2,
.vistema-row__summary h3,
.vistema-row__summary h4 {
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}
.vistema-row__summary br { display: none !important; }
.vistema-row__summary img,
.vistema-row__summary svg { display: none !important; }

.vistema-row__aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .65rem;
    flex-shrink: 0;
    min-width: 140px;
}
.vistema-row__aside .vistema-action { width: auto; min-width: 140px; }

/* =========================================================================
   PAGINATION
   ========================================================================= */
.vistema-pagination {
    display: flex;
    justify-content: center;
    gap: .25rem;
    margin: 2.5rem 0 .75rem;
    flex-wrap: wrap;
}
.vistema-page {
    min-width: 2.5rem;
    padding: .5rem .75rem;
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius-sm);
    color: var(--vis-text-soft);
    text-align: center;
    background: var(--vis-bg);
    font-size: .92rem;
    font-weight: 500;
    transition: all .15s ease;
}
.vistema-page:hover { border-color: var(--vis-text); color: var(--vis-text); }
.vistema-page.is-current,
.vistema-page.is-current:hover,
.vistema-page.is-current:visited {
    background: var(--vis-text) !important;
    color: #ffffff !important;
    border-color: var(--vis-text) !important;
}
.vistema-page--gap { border: none; background: transparent; cursor: default; color: var(--vis-text-mute); }

.vistema-count {
    text-align: left;
    color: var(--vis-text);
    font-size: 1.05rem;
    margin: 0 0 1.25rem;
    font-weight: 500;
}

.vistema-empty {
    text-align: center;
    color: var(--vis-text-mute);
    padding: 3rem 1rem;
    font-size: .95rem;
}
.vistema-error {
    padding: 1rem 1.2rem;
    border: 1px solid #fecaca;
    background: #fef2f2;
    color: #991b1b;
    border-radius: var(--vis-radius-sm);
    font-size: .9rem;
}

/* =========================================================================
   DETAIL-ANSICHT
   ========================================================================= */

.vistema-back { margin: 0 0 1.5rem; }
.vistema-back a {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem 1rem;
    background: var(--vis-beige);
    border: 1px solid var(--vis-beige-2);
    border-radius: var(--vis-radius-sm);
    color: var(--vis-beige-text) !important;
    font-size: .92rem;
    font-weight: 500;
    transition: background .15s ease, transform .15s ease;
}
.vistema-back a:hover {
    background: var(--vis-beige-2);
    transform: translateX(-2px);
}

.vistema-detail__head {
    margin: 1.5rem 0 2rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    align-items: flex-start;
    text-align: left;
}
.vistema-detail__head .vistema-card__cats { justify-content: flex-start; }
.vistema-detail__title {
    font-size: clamp(1.75rem, 2.6vw, 2.4rem);
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
    letter-spacing: -.02em;
    color: var(--vis-text);
    overflow-wrap: anywhere;
}
.vistema-detail__summary {
    font-size: 1.05rem;
    line-height: 1.6;
    margin: 0;
    color: var(--vis-text-soft);
    text-align: left;
}
.vistema-detail__summary p { margin: 0 0 .5em; }
.vistema-detail__summary p:last-child { margin-bottom: 0; }

/* Main-Layout: Player + Sidebar */
.vistema-detail__main {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.75rem;
    margin-bottom: 2rem;
    align-items: start;
}
.vistema-detail__player-col { min-width: 0; }
.vistema-player {
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: var(--vis-radius);
    overflow: hidden;
    box-shadow: var(--vis-shadow-lg);
    position: relative;
}
.vistema-player__video {
    width: 100%; height: 100%;
    display: block;
    background: #000;
}

/* Großer Play-Button zentriert auf Poster-Thumbnail */
.vistema-player__play {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 88px;
    height: 88px;
    border-radius: 50%;
    border: 0;
    background: rgba(0, 0, 0, .65);
    color: #ffffff !important;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    box-shadow: 0 4px 24px rgba(0, 0, 0, .35);
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease, opacity .2s ease;
    z-index: 2;
    -webkit-appearance: none;
    appearance: none;
}
.vistema-player__play:hover {
    background: rgba(0, 0, 0, .85);
    transform: translate(-50%, -50%) scale(1.06);
    box-shadow: 0 6px 32px rgba(0, 0, 0, .45);
}
.vistema-player__play:active {
    transform: translate(-50%, -50%) scale(.97);
}
.vistema-player__play:focus-visible {
    outline: 3px solid #fff;
    outline-offset: 4px;
}
.vistema-player__play svg {
    /* SVG-Pfad ist links unwuchtig — minimal nach rechts schieben fürs optische Zentrum */
    margin-left: 4px;
}
/* Sobald das Video läuft → Play-Button ausblenden, native Controls übernehmen */
.vistema-player.is-playing .vistema-player__play {
    opacity: 0;
    pointer-events: none;
}

@media (max-width: 480px) {
    .vistema-player__play {
        width: 68px;
        height: 68px;
    }
    .vistema-player__play svg {
        width: 26px;
        height: 26px;
    }
}

.vistema-player--no-stream {
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    background: var(--vis-bg-soft);
    position: relative;
}
.vistema-player--no-stream img {
    width: 100%; height: 100%;
    object-fit: cover;
}
.vistema-player__hint {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    margin: 0;
    padding: .65rem 1rem;
    background: linear-gradient(transparent, rgba(0,0,0,.7));
    color: #fff;
    font-size: .85rem;
    text-align: center;
    pointer-events: none;
}

/* Pricecard rechts */
.vistema-detail__aside {
    position: sticky;
    top: 1.5rem;
}
.vistema-pricecard {
    background: var(--vis-bg);
    border: 1px solid var(--vis-border);
    border-radius: var(--vis-radius);
    padding: 1.5rem;
    box-shadow: var(--vis-shadow);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.vistema-pricecard__price {
    font-size: 2rem;
    font-weight: 700;
    color: var(--vis-text);
    letter-spacing: -.02em;
    line-height: 1;
}
.vistema-pricecard__price .is-free {
    display: inline-block;
    padding: .35rem 1.1rem;
    background: var(--vis-free-bg);
    color: var(--vis-free-text);
    border: 1.5px solid var(--vis-free-border);
    border-radius: var(--vis-radius-sm);
    font-size: 1.5rem;
}
.vistema-meta {
    margin: 0;
    padding-top: 1rem;
    border-top: 1px solid var(--vis-border-2);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: .5rem 1rem;
    font-size: .92rem;
}
.vistema-meta dt {
    margin: 0;
    color: var(--vis-text-mute);
    text-transform: uppercase;
    letter-spacing: .04em;
    font-size: .78rem;
    font-weight: 500;
    align-self: center;
    text-align: left;
}
.vistema-meta dd {
    margin: 0;
    color: var(--vis-text);
    font-weight: 500;
    text-align: right;
}

/* Beschreibung */
.vistema-detail__desc {
    line-height: 1.7;
    color: var(--vis-text-soft);
    font-size: 1rem;
    overflow-wrap: anywhere;
    margin-bottom: 2rem;
    text-align: left;
}
.vistema-detail__desc p { margin: 0 0 1em; }
.vistema-detail__desc h2,
.vistema-detail__desc h3 {
    margin-top: 1.75em;
    margin-bottom: .5em;
    color: var(--vis-text);
    font-weight: 700;
    letter-spacing: -.01em;
}
.vistema-detail__desc img {
    max-width: 100%;
    height: auto;
    border-radius: var(--vis-radius-sm);
}
.vistema-detail__desc ul,
.vistema-detail__desc ol { padding-left: 1.5em; margin: 0 0 1em; }
.vistema-detail__desc li { margin-bottom: .35em; }

/* Screenshots */
.vistema-screens__title {
    font-size: 1.4rem;
    font-weight: 700;
    margin: 2rem 0 1.25rem;
    letter-spacing: -.01em;
    color: var(--vis-text);
}
.vistema-screens__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: .9rem;
    margin-bottom: 2.5rem;
}
.vistema-screens__grid a {
    display: block;
    aspect-ratio: 16 / 9;
    border-radius: var(--vis-radius-sm);
    overflow: hidden;
    background: var(--vis-bg-soft);
    box-shadow: var(--vis-shadow);
    transition: transform .25s ease, box-shadow .25s ease;
}
.vistema-screens__grid a:hover {
    transform: translateY(-2px);
    box-shadow: var(--vis-shadow-lg);
}
.vistema-screens__grid img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.vistema-screens__grid a:hover img { transform: scale(1.04); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */

@media (max-width: 900px) {
    .vistema-detail__main {
        grid-template-columns: 1fr;
    }
    .vistema-detail__aside {
        position: static;
    }
    .vistema-pricecard {
        max-width: 480px;
        margin: 0 auto;
    }
    .vistema-row {
        grid-template-columns: 140px 1fr;
        gap: .9rem;
    }
    .vistema-row__aside {
        grid-column: 1 / -1;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        min-width: 0;
        padding-top: .25rem;
        border-top: 1px solid var(--vis-border-2);
    }
    .vistema-row__aside .vistema-action { flex: 1 1 auto; }
}

@media (max-width: 600px) {
    .vistema-toolbar { flex-direction: column; align-items: stretch; }
    .vistema-filter { width: 100%; }
    .vistema-filter__search,
    .vistema-filter__cat,
    .vistema-filter__submit { width: 100%; }
    .vistema-layout-toggle { align-self: flex-end; }

    .vistema-grid { grid-template-columns: 1fr; gap: 1.1rem; }
    .vistema-card__body { padding: 1rem 1.1rem 1.15rem; }

    .vistema-row {
        grid-template-columns: 1fr;
        padding: .85rem;
    }
    .vistema-row__media { aspect-ratio: 16 / 9; }
}

/* =========================================================================
   MODAL (Bestätigungs-Popup für Kaufen/Hinzufügen)
   ========================================================================= */

.vistema-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: vistema-fade-in .15s ease;
}
.vistema-modal[hidden] { display: none; }

@keyframes vistema-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes vistema-pop-in {
    from { opacity: 0; transform: translateY(8px) scale(.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.vistema-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, .55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}

.vistema-modal__panel {
    position: relative;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 4px 12px rgba(0,0,0,.12), 0 24px 60px rgba(0,0,0,.24);
    padding: 2rem 1.75rem 1.75rem;
    max-width: 460px;
    width: 100%;
    animation: vistema-pop-in .2s cubic-bezier(.4,0,.2,1);
    text-align: center;
    color: #111111;
}

.vistema-modal__close {
    position: absolute;
    top: .85rem;
    right: .85rem;
    width: 36px;
    height: 36px;
    border: 0;
    background: transparent;
    color: #6b7280;
    cursor: pointer;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .15s ease, color .15s ease;
}
.vistema-modal__close:hover {
    background: #f3f4f6;
    color: #111111;
}
.vistema-modal__close:focus-visible {
    outline: 2px solid #111111;
    outline-offset: 2px;
}

.vistema-modal__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1.1rem;
    border-radius: 50%;
    background: #f4ead8;
    color: #6b5530;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.vistema-modal__title {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    margin: 0 0 .5rem !important;
    line-height: 1.3 !important;
    letter-spacing: -.01em;
    color: #111111 !important;
}

.vistema-modal__video {
    margin: 0 0 1rem;
    color: #6b7280;
    font-size: .92rem;
    font-weight: 500;
    overflow-wrap: anywhere;
}

.vistema-modal__text {
    margin: 0 0 1.5rem;
    color: #374151;
    font-size: .95rem;
    line-height: 1.55;
}

.vistema-modal__actions {
    display: flex;
    gap: .65rem;
    justify-content: center;
    flex-wrap: wrap;
}

.vistema-modal__cancel,
.vistema-modal__cancel:hover,
.vistema-modal__cancel:focus,
.vistema-modal__cancel:active {
    padding: .7rem 1.25rem;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    color: #374151 !important;
    border-radius: 8px;
    font: inherit;
    font-size: .95rem;
    font-weight: 500;
    cursor: pointer;
    flex: 0 1 auto;
    text-decoration: none !important;
    -webkit-appearance: none;
    appearance: none;
}
.vistema-modal__cancel { transition: background .15s ease, border-color .15s ease, color .15s ease; }
.vistema-modal__cancel:hover {
    background: #f3f4f6 !important;
    border-color: #d1d5db !important;
    color: #111111 !important;
}
.vistema-modal__cancel:focus-visible {
    outline: 2px solid #111111;
    outline-offset: 2px;
}

.vistema-modal__confirm,
.vistema-modal__confirm:hover,
.vistema-modal__confirm:visited,
.vistema-modal__confirm:focus,
.vistema-modal__confirm:active {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .7rem 1.25rem;
    border-radius: 8px;
    background: #111111;
    color: #ffffff !important;
    font-size: .95rem;
    font-weight: 600;
    text-decoration: none !important;
    flex: 0 1 auto;
    border: 1px solid #111111;
}
.vistema-modal__confirm { transition: background .15s ease, transform .15s ease, box-shadow .15s ease; }
.vistema-modal__confirm:hover {
    background: #000000 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.vistema-modal__confirm:focus-visible {
    outline: 2px solid #111111;
    outline-offset: 3px;
}

@media (max-width: 480px) {
    .vistema-modal__panel { padding: 1.75rem 1.25rem 1.5rem; }
    .vistema-modal__actions { flex-direction: column-reverse; }
    .vistema-modal__cancel,
    .vistema-modal__confirm { width: 100%; justify-content: center; }
}

/* =========================================================================
   PREVIEW-KARUSSELL (mehrere Vorschau-Videos)
   ========================================================================= */

.vistema-previews {
    position: relative;
    margin-top: 1rem;
    display: flex;
    align-items: stretch;
    gap: .5rem;
}

.vistema-previews__track {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    gap: .65rem;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    -ms-overflow-style: none;
    scrollbar-width: none;
    padding: 2px; /* damit der active-Ring nicht abgeschnitten ist */
}
.vistema-previews__track::-webkit-scrollbar { display: none; }

.vistema-preview-thumb {
    position: relative;
    flex: 0 0 auto;
    width: 140px;
    aspect-ratio: 16 / 9;
    padding: 0;
    border: 0;
    background: var(--vis-bg-soft, #f3f4f6);
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    scroll-snap-align: start;
    transition: transform .15s ease, box-shadow .15s ease;
    color: #fff;
    -webkit-appearance: none;
    appearance: none;
    box-shadow: 0 0 0 2px transparent;
}
.vistema-preview-thumb:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 0 2px rgba(17,17,17,.15), 0 4px 12px rgba(0,0,0,.12);
}
.vistema-preview-thumb.is-active {
    box-shadow: 0 0 0 2px var(--vis-text, #111111);
}
.vistema-preview-thumb:focus-visible {
    outline: 2px solid var(--vis-text, #111111);
    outline-offset: 2px;
}

.vistema-preview-thumb__img {
    position: absolute;
    inset: 0;
    background-color: #1a1a1a;
    background-size: cover;
    background-position: center;
    transition: opacity .2s ease;
}
.vistema-preview-thumb__placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
}
.vistema-preview-thumb__img.is-loaded .vistema-preview-thumb__placeholder { display: none; }

.vistema-preview-thumb__index {
    position: absolute;
    top: 6px;
    left: 6px;
    z-index: 2;
    font-size: 11px;
    font-weight: 700;
    background: rgba(0,0,0,.7);
    color: #fff;
    padding: 2px 7px;
    border-radius: 4px;
    line-height: 1.2;
}
.vistema-preview-thumb__play {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(0,0,0,.65);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .15s ease, transform .15s ease;
}
.vistema-preview-thumb__play svg { margin-left: 2px; }
.vistema-preview-thumb:hover .vistema-preview-thumb__play {
    background: rgba(0,0,0,.85);
    transform: translate(-50%, -50%) scale(1.06);
}
.vistema-preview-thumb.is-active .vistema-preview-thumb__play {
    background: var(--vis-text, #111111);
}

/* Karussell-Pfeile */
.vistema-previews__nav {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    border: 1px solid var(--vis-border, #e5e7eb);
    border-radius: 8px;
    background: var(--vis-bg, #fff);
    color: var(--vis-text, #111);
    cursor: pointer;
    transition: background .15s ease, color .15s ease, opacity .15s ease;
    -webkit-appearance: none;
    appearance: none;
    align-self: stretch;
}
.vistema-previews__nav:hover {
    background: var(--vis-bg-soft, #f3f4f6);
}
.vistema-previews__nav:focus-visible {
    outline: 2px solid var(--vis-text, #111);
    outline-offset: 2px;
}
.vistema-previews:not(.can-scroll) .vistema-previews__nav { display: none; }
.vistema-previews.at-start  .vistema-previews__nav--prev { opacity: .35; pointer-events: none; }
.vistema-previews.at-end    .vistema-previews__nav--next { opacity: .35; pointer-events: none; }

@media (max-width: 480px) {
    .vistema-preview-thumb { width: 120px; }
    .vistema-preview-thumb__play { width: 32px; height: 32px; }
}

/* =========================================================================
   SPIELLÄNGE-BADGE auf Thumbnails (YouTube-Style)
   ========================================================================= */

.vistema-card__media,
.vistema-row__media {
    position: relative; /* damit das Badge absolut positioniert werden kann */
}

.vistema-duration-badge {
    position: absolute;
    bottom: 8px;
    right: 8px;
    z-index: 2;
    padding: 3px 7px;
    background: rgba(0, 0, 0, .82);
    color: #ffffff;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.25;
    border-radius: 4px;
    letter-spacing: .01em;
    pointer-events: none;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 480px) {
    .vistema-duration-badge {
        bottom: 6px;
        right: 6px;
        font-size: 11px;
        padding: 2px 6px;
    }
}
