.tpw-wrap,
.tpw-wrap * {
    box-sizing: border-box;
}

.tpw-wrap {
    --tpw-columns-desktop: 4;
    --tpw-columns-tablet: 3;
    --tpw-columns-mobile: 2;
    --tpw-columns: var(--tpw-columns-desktop);
    --tpw-irregular-columns-desktop: var(--tpw-columns-desktop);
    --tpw-irregular-columns-tablet: var(--tpw-columns-tablet);
    --tpw-irregular-columns-mobile: var(--tpw-columns-mobile);
    --tpw-irregular-columns: var(--tpw-irregular-columns-desktop);
    --tpw-gap: 16px;
    --tpw-radius: 22px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
}

@supports not (overflow-x: clip) {
    .tpw-wrap { overflow-x: hidden; }
}

.tpw-empty {
    width: 100%;
    max-width: 100%;
    padding: 18px 20px;
    border: 1px dashed rgba(0,0,0,.25);
    border-radius: 12px;
    color: #666;
    background: rgba(255,255,255,.65);
}

.tpw-filter {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0 0 22px;
    overflow: hidden;
}

.tpw-filter-btn {
    appearance: none;
    min-width: 0;
    max-width: 100%;
    border: 1px solid rgba(20, 20, 20, .12);
    border-radius: 999px;
    padding: 9px 18px;
    background: rgba(255, 255, 255, .78);
    color: #222;
    font-size: 14px;
    line-height: 1.2;
    cursor: pointer;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    text-align: center;
    transition: transform .22s ease, opacity .22s ease, background .22s ease, color .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.tpw-filter-btn:hover,
.tpw-filter-btn:focus-visible {
    transform: translateY(-1px);
    outline: none;
    box-shadow: 0 8px 22px rgba(0,0,0,.08);
}

.tpw-filter-btn.is-active {
    background: #111;
    color: #fff;
    border-color: #111;
}

.tpw-wall {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
}

@supports not (overflow-x: clip) {
    .tpw-wall { overflow-x: hidden; }
}

.tpw-layout-masonry {
    column-count: var(--tpw-columns);
    column-gap: var(--tpw-gap);
}

.tpw-layout-grid {
    display: grid;
    grid-template-columns: repeat(var(--tpw-columns), minmax(0, 1fr));
    gap: var(--tpw-gap);
}

.tpw-layout-irregular {
    display: grid;
    grid-template-columns: repeat(var(--tpw-irregular-columns), minmax(0, 1fr));
    grid-auto-flow: dense;
    grid-auto-rows: clamp(76px, 10vw, 190px);
    align-items: stretch;
    gap: var(--tpw-gap);
}

.tpw-layout-irregular .tpw-item {
    width: 100%;
    max-width: 100%;
    min-height: 0;
}

.tpw-layout-irregular .tpw-item.tpw-has-natural-size {
    max-width: min(100%, var(--tpw-natural-width, 9999px));
    justify-self: center;
}

.tpw-layout-irregular .tpw-shape-wide {
    grid-column: span var(--tpw-large-span);
    grid-row: span 2;
}

.tpw-layout-irregular .tpw-shape-landscape {
    grid-column: span var(--tpw-wide-span);
    grid-row: span 2;
}

.tpw-layout-irregular .tpw-shape-square {
    grid-column: span 1;
    grid-row: span 2;
}

.tpw-layout-irregular .tpw-shape-portrait {
    grid-column: span 1;
    grid-row: span 3;
}

.tpw-layout-irregular .tpw-shape-tall {
    grid-column: span 1;
    grid-row: span 4;
}


.tpw-item {
    position: relative;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    margin: 0;
    border-radius: var(--tpw-radius);
    background: rgba(245,245,245,.85);
    transform-origin: center center;
    transition: opacity .38s ease, transform .38s ease, filter .38s ease;
}

.tpw-layout-masonry .tpw-item {
    display: inline-block;
    width: 100%;
    max-width: 100%;
    margin-bottom: var(--tpw-gap);
    break-inside: avoid;
    -webkit-column-break-inside: avoid;
}

.tpw-layout-grid .tpw-item {
    aspect-ratio: 1 / 1.12;
}

.tpw-link,
.tpw-image,
.tpw-video-placeholder,
.tpw-embed-preview {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.tpw-link {
    position: relative;
    overflow: hidden;
    border-radius: inherit;
    color: inherit;
    text-decoration: none;
}

.tpw-link:hover,
.tpw-link:focus {
    color: inherit;
    text-decoration: none;
}

.tpw-image {
    height: auto;
    object-fit: cover;
    border-radius: inherit;
    transition: transform .5s ease, filter .5s ease, opacity .35s ease;
}

.tpw-video-placeholder,
.tpw-embed-preview {
    transition: transform .5s ease, filter .5s ease, opacity .35s ease;
}


.tpw-layout-grid .tpw-image,
.tpw-layout-grid .tpw-link,
.tpw-layout-grid .tpw-video-placeholder,
.tpw-layout-grid .tpw-embed-preview,
.tpw-layout-irregular .tpw-image,
.tpw-layout-irregular .tpw-link,
.tpw-layout-irregular .tpw-video-placeholder,
.tpw-layout-irregular .tpw-embed-preview {
    height: 100%;
}

.tpw-layout-irregular .tpw-image,
.tpw-layout-irregular .tpw-video-placeholder,
.tpw-layout-irregular .tpw-embed-preview {
    object-fit: cover;
}

.tpw-layout-irregular .tpw-embed-preview {
    min-height: 0;
    aspect-ratio: auto;
}

.tpw-video-placeholder {
    min-height: 190px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.88);
    background: radial-gradient(circle at 35% 25%, rgba(255,255,255,.16), rgba(0,0,0,.08) 34%, rgba(0,0,0,.74) 100%);
    border-radius: inherit;
}

.tpw-video-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 70px;
    min-height: 32px;
    border: 1px solid rgba(255,255,255,.48);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: 12px;
    letter-spacing: .12em;
    background: rgba(255,255,255,.12);
}

.tpw-embed-preview {
    position: relative;
    width: 100%;
    max-width: 100%;
    min-height: 240px;
    aspect-ratio: 16 / 11;
    overflow: hidden;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(245,245,245,.92), rgba(220,220,220,.82));
}

.tpw-embed-iframe {
    display: block;
    width: 100%;
    height: 100%;
    min-height: inherit;
    border: 0;
    background: #fff;
    pointer-events: none;
}

/* Embedded websites are live previews used as clickable tiles.
   The preview uses a smaller responsive viewport and scales it to the card size,
   so mobile-style pages fill the tile instead of leaving a white area on the right. */
.tpw-media-website .tpw-link {
    background: #fff;
    cursor: pointer;
}

.tpw-media-website .tpw-embed-preview {
    position: relative;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    background: #fff;
}

.tpw-media-website .tpw-embed-preview::before {
    display: none;
    content: none;
}

.tpw-media-website .tpw-embed-iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: var(--tpw-embed-viewport-width, 390px);
    height: var(--tpw-embed-viewport-height, 100%);
    min-height: 0;
    max-width: none;
    max-height: none;
    border: 0;
    background: #fff;
    transform: scale(var(--tpw-embed-scale, 1));
    transform-origin: 0 0;
    pointer-events: none;
}

.tpw-media-website .tpw-media-link::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 8;
    display: block;
    background: transparent;
    pointer-events: auto;
}

.tpw-web-click-layer {
    position: absolute;
    inset: 0;
    z-index: 6;
    display: block;
    background: transparent;
    pointer-events: none;
}

.tpw-media-website .tpw-web-badge {
    z-index: 6;
    pointer-events: none;
}

.tpw-media-website .tpw-caption {
    z-index: 7;
    pointer-events: none;
}

.tpw-web-badge {
    position: absolute;
    left: 12px;
    top: 12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    min-height: 26px;
    padding: 4px 10px;
    border-radius: 999px;
    color: #111;
    background: rgba(255,255,255,.88);
    box-shadow: 0 8px 22px rgba(0,0,0,.12);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    pointer-events: none;
}

.tpw-play {
    position: absolute;
    left: 50%;
    top: 50%;
    width: clamp(46px, 7vw, 68px);
    height: clamp(46px, 7vw, 68px);
    transform: translate(-50%, -50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,.86);
    box-shadow: 0 16px 40px rgba(0,0,0,.22);
    pointer-events: none;
    transition: transform .25s ease, background .25s ease;
    z-index: 2;
}

.tpw-play span {
    width: 0;
    height: 0;
    margin-left: 4px;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 16px solid #111;
}

.tpw-item:hover .tpw-play {
    transform: translate(-50%, -50%) scale(1.06);
    background: rgba(255,255,255,.96);
}

.tpw-caption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    max-width: 100%;
    padding: 44px 14px 13px;
    color: #fff;
    font-size: 14px;
    line-height: 1.35;
    background: linear-gradient(to top, rgba(0,0,0,.66), rgba(0,0,0,0));
    pointer-events: none;
    overflow-wrap: anywhere;
    z-index: 3;
}

.tpw-title,
.tpw-description {
    display: block;
}

.tpw-title {
    font-weight: 700;
    font-size: 1em;
    line-height: 1.25;
}

.tpw-description {
    margin-top: 3px;
    font-size: .88em;
    opacity: .88;
}

.tpw-hover-lift .tpw-item:hover,
.tpw-hover-lift .tpw-item:focus-within,
.tpw-hover-lift .tpw-item:active {
    transform: translateY(-4px);
}

.tpw-hover-zoom .tpw-item:hover .tpw-image,
.tpw-hover-zoom .tpw-item:focus-within .tpw-image,
.tpw-hover-zoom .tpw-item:active .tpw-image,
.tpw-hover-zoom .tpw-item:hover .tpw-video-placeholder,
.tpw-hover-zoom .tpw-item:focus-within .tpw-video-placeholder,
.tpw-hover-zoom .tpw-item:active .tpw-video-placeholder,
.tpw-hover-zoom .tpw-item:hover .tpw-embed-preview,
.tpw-hover-zoom .tpw-item:focus-within .tpw-embed-preview,
.tpw-hover-zoom .tpw-item:active .tpw-embed-preview {
    transform: scale(1.055);
}

.tpw-hover-soft .tpw-item:hover .tpw-image,
.tpw-hover-soft .tpw-item:focus-within .tpw-image,
.tpw-hover-soft .tpw-item:active .tpw-image,
.tpw-hover-soft .tpw-item:hover .tpw-video-placeholder,
.tpw-hover-soft .tpw-item:focus-within .tpw-video-placeholder,
.tpw-hover-soft .tpw-item:active .tpw-video-placeholder,
.tpw-hover-soft .tpw-item:hover .tpw-embed-preview,
.tpw-hover-soft .tpw-item:focus-within .tpw-embed-preview,
.tpw-hover-soft .tpw-item:active .tpw-embed-preview {
    filter: saturate(1.08) contrast(1.04) brightness(1.04);
}

.tpw-item.is-hidden {
    display: none !important;
}

.tpw-animation-fade .tpw-item,
.tpw-animation-slide .tpw-item,
.tpw-animation-zoom .tpw-item,
.tpw-animation-float .tpw-item,
.tpw-animation-multi-slide .tpw-item {
    opacity: 0;
}

.tpw-ready.tpw-animation-fade .tpw-item,
.tpw-ready.tpw-animation-slide .tpw-item,
.tpw-ready.tpw-animation-zoom .tpw-item,
.tpw-ready.tpw-animation-float .tpw-item,
.tpw-ready.tpw-animation-multi-slide .tpw-item {
    opacity: 1;
    transition-delay: var(--tpw-delay, 0ms);
}

.tpw-animation-slide .tpw-item {
    transform: translateY(18px);
}

.tpw-ready.tpw-animation-slide .tpw-item {
    transform: translateY(0);
}

.tpw-animation-zoom .tpw-item {
    transform: scale(.94);
}

.tpw-ready.tpw-animation-zoom .tpw-item {
    transform: scale(1);
}

.tpw-animation-multi-slide .tpw-enter-left { transform: translateX(-34px); }
.tpw-animation-multi-slide .tpw-enter-right { transform: translateX(34px); }
.tpw-animation-multi-slide .tpw-enter-top { transform: translateY(-34px); }
.tpw-animation-multi-slide .tpw-enter-bottom { transform: translateY(34px); }
.tpw-animation-multi-slide .tpw-enter-top-left { transform: translate(-34px, -34px); }
.tpw-animation-multi-slide .tpw-enter-top-right { transform: translate(34px, -34px); }
.tpw-animation-multi-slide .tpw-enter-bottom-left { transform: translate(-34px, 34px); }
.tpw-animation-multi-slide .tpw-enter-bottom-right { transform: translate(34px, 34px); }

.tpw-ready.tpw-animation-multi-slide .tpw-item {
    transform: translate(0, 0) scale(1);
}

.tpw-animation-float.tpw-ready .tpw-item {
    animation: tpwSoftFloat 6.5s ease-in-out infinite;
    animation-delay: calc(var(--tpw-delay, 0ms) * .35);
}

@keyframes tpwSoftFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-7px); }
}


/* Irregular layout media should fill its varied card safely. */
.tpw-layout-irregular .tpw-video-placeholder,
.tpw-layout-irregular .tpw-embed-preview {
    min-height: 0;
    aspect-ratio: auto;
}

.tpw-lightbox-open {
    overflow: hidden;
}

.tpw-lightbox {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: clamp(14px, 3vw, 34px);
    background: rgba(8,8,10,.82);
    z-index: 999999;
}

.tpw-lightbox.is-open {
    display: flex;
}

.tpw-lightbox-panel {
    position: relative;
    width: min(1120px, 100%);
    max-width: 100%;
    max-height: calc(100vh - 42px);
    display: flex;
    flex-direction: column;
    border-radius: 18px;
    overflow: hidden;
    background: #101010;
    box-shadow: 0 26px 90px rgba(0,0,0,.42);
}

.tpw-lightbox-media {
    position: relative;
    width: 100%;
    max-width: 100%;
    background: #000;
}

.tpw-lightbox-media img,
.tpw-lightbox-media video,
.tpw-lightbox-media iframe {
    display: block;
    width: 100%;
    max-width: 100%;
    border: 0;
}

.tpw-lightbox-media img {
    height: auto;
    max-height: calc(100vh - 150px);
    object-fit: contain;
    background: #000;
}

.tpw-lightbox-media video,
.tpw-lightbox-media iframe {
    aspect-ratio: 16 / 9;
    height: auto;
    max-height: calc(100vh - 150px);
}

.tpw-lightbox-info {
    display: none;
    padding: 14px 18px 16px;
    color: #fff;
    background: #101010;
}

.tpw-lightbox-info.has-text {
    display: block;
}

.tpw-lightbox-title {
    font-size: 17px;
    line-height: 1.35;
    font-weight: 700;
}

.tpw-lightbox-description {
    margin-top: 4px;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(255,255,255,.78);
}

.tpw-lightbox-close {
    position: absolute;
    right: 10px;
    top: 10px;
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.92);
    color: #111;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    z-index: 3;
}

.tpw-lightbox-close:hover,
.tpw-lightbox-close:focus-visible {
    background: #fff;
    outline: none;
}

@media (max-width: 1024px) {
    .tpw-wrap {
        --tpw-columns: var(--tpw-columns-tablet);
        --tpw-irregular-columns: var(--tpw-irregular-columns-tablet);
        --tpw-wide-span: var(--tpw-wide-span-tablet);
        --tpw-large-span: var(--tpw-large-span-tablet);
        --tpw-gap: min(var(--tpw-gap), 18px);
    }
}

@media (max-width: 767px) {
    .tpw-wrap {
        --tpw-columns: var(--tpw-columns-mobile);
        --tpw-irregular-columns: var(--tpw-irregular-columns-mobile);
        --tpw-wide-span: var(--tpw-wide-span-mobile);
        --tpw-large-span: var(--tpw-large-span-mobile);
        --tpw-gap: min(var(--tpw-gap), 14px);
    }

    .tpw-filter {
        justify-content: flex-start;
        overflow: hidden;
    }

    .tpw-filter-btn {
        flex: 1 1 auto;
        padding: 8px 14px;
    }

    .tpw-caption {
        font-size: 13px;
        padding: 34px 12px 11px;
    }

    .tpw-lightbox {
        padding: 10px;
    }

    .tpw-lightbox-panel {
        max-height: calc(100vh - 20px);
        border-radius: 14px;
    }

    .tpw-lightbox-media img {
        max-height: calc(100vh - 132px);
    }

    .tpw-lightbox-media video,
    .tpw-lightbox-media iframe {
        max-height: calc(100vh - 132px);
    }
}

@media (max-width: 420px) {
    .tpw-wrap {
        --tpw-columns: 1;
        --tpw-irregular-columns: 1;
        --tpw-wide-span: 1;
        --tpw-large-span: 1;
        --tpw-gap: min(var(--tpw-gap), 12px);
    }

    .tpw-layout-irregular .tpw-item {
        grid-column: span 1;
        grid-row: auto;
        aspect-ratio: var(--tpw-natural-ratio, auto);
    }

    .tpw-filter-btn {
        flex-basis: calc(50% - 8px);
        font-size: 13px;
    }
}

/* v1.4.1: make configured entrance and interaction effects reliable on public frontend. */
.tpw-wrap.tpw-animation-fade .tpw-item,
.tpw-wrap.tpw-animation-slide .tpw-item,
.tpw-wrap.tpw-animation-zoom .tpw-item,
.tpw-wrap.tpw-animation-multi-slide .tpw-item {
    will-change: transform, opacity;
}

.tpw-wrap.tpw-ready.tpw-animation-fade .tpw-item,
.tpw-wrap.tpw-ready.tpw-animation-slide .tpw-item,
.tpw-wrap.tpw-ready.tpw-animation-zoom .tpw-item,
.tpw-wrap.tpw-ready.tpw-animation-multi-slide .tpw-item {
    transition-property: opacity, transform, filter;
    transition-duration: .72s, .78s, .45s;
    transition-timing-function: cubic-bezier(.18,.82,.24,1), cubic-bezier(.18,.82,.24,1), ease;
}

.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-left { transform: translate3d(-76px, 0, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-right { transform: translate3d(76px, 0, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-top { transform: translate3d(0, -76px, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-bottom { transform: translate3d(0, 76px, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-top-left { transform: translate3d(-76px, -76px, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-top-right { transform: translate3d(76px, -76px, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-bottom-left { transform: translate3d(-76px, 76px, 0) scale(.965); }
.tpw-wrap.tpw-animation-multi-slide:not(.tpw-ready) .tpw-enter-bottom-right { transform: translate3d(76px, 76px, 0) scale(.965); }

.tpw-wrap.tpw-ready.tpw-hover-lift .tpw-item:hover,
.tpw-wrap.tpw-ready.tpw-hover-lift .tpw-item:focus-within,
.tpw-wrap.tpw-ready.tpw-hover-lift .tpw-item:active,
.tpw-wrap.tpw-ready.tpw-hover-lift .tpw-item.tpw-is-pressed,
.tpw-wrap.tpw-ready.tpw-hover-lift .tpw-item.tpw-click-pop {
    transform: translateY(-7px) scale(1.012);
}

.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:hover .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:focus-within .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:active .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-is-pressed .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-click-pop .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:hover .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:focus-within .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:active .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-is-pressed .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-click-pop .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:hover .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:focus-within .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item:active .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-is-pressed .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-item.tpw-click-pop .tpw-embed-preview {
    transform: scale(1.09);
}

.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:hover .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:focus-within .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:active .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item.tpw-is-pressed .tpw-image,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:hover .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:focus-within .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:active .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item.tpw-is-pressed .tpw-video-placeholder,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:hover .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:focus-within .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item:active .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-soft .tpw-item.tpw-is-pressed .tpw-embed-preview {
    filter: saturate(1.12) contrast(1.06) brightness(1.06);
}

/* v1.4.3: force embedded website tiles to zoom on public frontend too.
   Do not depend on the JS-added .tpw-ready class only, because logged-out cache/optimizers
   can delay that class even when the tile is already visible. */
.tpw-media-website {
    isolation: isolate;
}

.tpw-media-website .tpw-link {
    transform-origin: center center;
    transition: transform .36s cubic-bezier(.18,.82,.24,1), filter .36s ease, box-shadow .32s ease;
    will-change: transform;
    backface-visibility: hidden;
}

.tpw-hover-zoom .tpw-media-website:hover .tpw-link,
.tpw-hover-zoom .tpw-media-website:focus-within .tpw-link,
.tpw-hover-zoom .tpw-media-website:active .tpw-link,
.tpw-hover-zoom .tpw-media-website.tpw-is-pressed .tpw-link,
.tpw-hover-zoom .tpw-media-website.tpw-click-pop .tpw-link,
.tpw-hover-zoom .tpw-media-website.tpw-web-hover .tpw-link,
.tpw-hover-zoom .tpw-media-website .tpw-link:hover,
.tpw-hover-zoom .tpw-media-website .tpw-link:focus,
.tpw-hover-zoom .tpw-media-website .tpw-link:active,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:hover .tpw-link,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:focus-within .tpw-link,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:active .tpw-link,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-is-pressed .tpw-link,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-click-pop .tpw-link,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-web-hover .tpw-link {
    transform: translateZ(0) scale(1.075) !important;
}

.tpw-hover-zoom .tpw-media-website:hover .tpw-embed-preview,
.tpw-hover-zoom .tpw-media-website:focus-within .tpw-embed-preview,
.tpw-hover-zoom .tpw-media-website:active .tpw-embed-preview,
.tpw-hover-zoom .tpw-media-website.tpw-is-pressed .tpw-embed-preview,
.tpw-hover-zoom .tpw-media-website.tpw-click-pop .tpw-embed-preview,
.tpw-hover-zoom .tpw-media-website.tpw-web-hover .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:hover .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:focus-within .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website:active .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-is-pressed .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-click-pop .tpw-embed-preview,
.tpw-wrap.tpw-ready.tpw-hover-zoom .tpw-media-website.tpw-web-hover .tpw-embed-preview {
    transform: none !important;
}

.tpw-item.tpw-click-pop {
    animation: tpwTileClickPop .34s cubic-bezier(.18,.82,.24,1);
}

@keyframes tpwTileClickPop {
    0% { transform: scale(1); }
    45% { transform: scale(1.035); }
    100% { transform: scale(1); }
}

.tpw-lightbox.is-open .tpw-lightbox-panel {
    animation: tpwLightboxZoomIn .22s cubic-bezier(.18,.82,.24,1);
}

@keyframes tpwLightboxZoomIn {
    from { opacity: 0; transform: scale(.965); }
    to { opacity: 1; transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
    .tpw-wrap .tpw-item,
    .tpw-wrap .tpw-image,
    .tpw-wrap .tpw-video-placeholder,
    .tpw-wrap .tpw-embed-preview,
    .tpw-lightbox.is-open .tpw-lightbox-panel {
        animation: none !important;
        transition-duration: .01ms !important;
    }
}
