/* Works - hero matches About lamp (GSAP + parallax); brand pink/red instead of warm gold */

.works-page {
    --works-void: #04050a;
    --works-pink: var(--uxm-brand, #e8195a);
    --works-pink-glow: rgba(232, 25, 90, 0.55);
    --works-pink-soft: rgba(232, 25, 90, 0.22);
    --works-rose-mid: #f0457a;
    --works-champagne: #c9b896;
    --works-champagne-bright: #e8d5b4;
    --works-ink: #8a8694;
    background: var(--works-void);
    min-height: 100vh;
}

/* -- Hero: same structure as About lamp (100vh) -- */
.works-hero {
    background: #080808;
    box-sizing: border-box;
    color: #ffffff;
    height: 100vh;
    height: 100dvh;
    min-height: 100vh;
    min-height: 100dvh;
    overflow-x: hidden;
    overflow-y: hidden;
    padding: 0;
    position: relative;
}

/* WebGL mist (Contact hero only; Works lamp hero has no this node) */
.works-hero__webgl {
    height: 100%;
    inset: 0;
    min-height: 100%;
    pointer-events: none;
    position: absolute;
    width: 100%;
    z-index: 0;
}

.works-hero__webgl canvas {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

@media (prefers-reduced-motion: reduce) {
    .works-hero__webgl {
        background:
            linear-gradient(102deg, transparent 40%, rgba(201, 184, 150, 0.06) 50%, transparent 60%),
            radial-gradient(ellipse 120% 28% at 54% 46%, rgba(72, 68, 88, 0.4) 0%, transparent 62%),
            radial-gradient(ellipse 32% 72% at 50% 48%, rgba(55, 52, 68, 0.28) 0%, transparent 55%),
            linear-gradient(168deg, #05060c 0%, #03040a 42%, #060812 100%);
    }
}

.works-hero__grain {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
    inset: 0;
    mix-blend-mode: soft-light;
    opacity: 0.055;
    pointer-events: none;
    position: absolute;
    z-index: 1;
}

.works-hero__bloom {
    background: radial-gradient(
        ellipse 55% 42% at 58% 38%,
        rgba(201, 184, 150, 0.07) 0%,
        rgba(120, 110, 95, 0.02) 42%,
        transparent 72%
    );
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 1;
}

.works-hero__vignette {
    background: radial-gradient(ellipse 72% 58% at 50% 48%, transparent 0%, transparent 38%, rgba(0, 0, 0, 0.52) 100%);
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 2;
}

.works-hero__void {
    background:
        radial-gradient(ellipse 92% 58% at 50% 118%, rgba(232, 25, 90, 0.12) 0%, transparent 46%),
        radial-gradient(ellipse 72% 42% at 50% -5%, rgba(248, 80, 120, 0.08) 0%, transparent 44%),
        linear-gradient(180deg, #050505 0%, #080808 38%, #0a0a0a 100%);
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.works-hero__architecture {
    height: 100%;
    left: 0;
    opacity: 0.85;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.works-hero__beam-column {
    bottom: 0;
    left: 50%;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: min(38vw, 320px);
    z-index: 3;
}

.works-hero__beam-ambient {
    background: linear-gradient(
        180deg,
        rgba(255, 235, 242, 0.1) 0%,
        rgba(232, 25, 90, 0.06) 38%,
        transparent 72%
    );
    filter: blur(24px);
    inset: 0 12% 18% 12%;
    opacity: 0.92;
    position: absolute;
}

.works-hero__beam-halo {
    background: linear-gradient(
        180deg,
        rgba(255, 240, 246, 0.32) 0%,
        rgba(248, 100, 140, 0.14) 42%,
        rgba(232, 25, 90, 0.06) 68%,
        transparent 100%
    );
    filter: blur(10px);
    height: 58%;
    left: 50%;
    opacity: 0.88;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 22%;
}

.works-hero__beam-core {
    background: linear-gradient(
        180deg,
        rgba(255, 255, 252, 1) 0%,
        rgba(255, 220, 232, 0.82) 18%,
        rgba(248, 90, 130, 0.32) 45%,
        rgba(232, 25, 90, 0.1) 68%,
        rgba(232, 25, 90, 0) 100%
    );
    box-shadow:
        0 0 1px rgba(255, 255, 255, 0.95),
        0 0 36px rgba(248, 80, 120, 0.35),
        0 0 88px rgba(232, 25, 90, 0.18);
    height: 56%;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 1.5px;
}

@media (min-width: 768px) {
    .works-hero__beam-core {
        width: 1.25px;
    }
}

.works-hero__beam-sheen {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.52) 0%, transparent 28%);
    filter: blur(1.2px);
    height: 22%;
    left: 50%;
    opacity: 0.42;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: translateX(-50%) translateX(-0.5px);
    width: 3px;
}

.works-hero__pool {
    background: radial-gradient(
        ellipse 130% 85% at 50% 100%,
        rgba(255, 200, 215, 0.38) 0%,
        rgba(248, 90, 130, 0.14) 30%,
        rgba(232, 25, 90, 0.08) 48%,
        rgba(180, 20, 70, 0.04) 62%,
        transparent 78%
    );
    bottom: 0;
    filter: blur(2px);
    height: 50%;
    left: 0;
    min-height: 180px;
    pointer-events: none;
    position: absolute;
    right: 0;
    width: 100%;
    will-change: transform;
    z-index: 1;
}

.works-hero__pool::after {
    background: radial-gradient(ellipse 95% 60% at 50% 95%, var(--works-pink-soft) 0%, transparent 55%);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.works-hero__content {
    left: 0;
    margin: 0 auto;
    max-width: min(1320px, 94vw);
    padding: 0 5vw;
    position: relative;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 4;
}

.works-hero__text {
    margin: 0 auto;
    max-width: 900px;
    text-align: center;
}

.works-hero__eyebrow {
    color: var(--works-pink);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.32em;
    margin: 0 0 clamp(1.5rem, 3vh, 2rem);
    text-transform: uppercase;
}

/* Title stack: fixed line + cycling word */
.works-hero__title-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.35rem, 1.2vh, 0.65rem);
    margin: 0 0 1.75rem;
    filter: drop-shadow(0 28px 64px rgba(0, 0, 0, 0.55));
}

.works-hero__title-line {
    background: linear-gradient(180deg, #fdfcfa 0%, #e8e4ec 48%, #c8c2d0 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    display: block;
    font-family: var(--uxm-font-heading, 'Montserrat', sans-serif);
    font-size: clamp(2.5rem, 8vw, 4.75rem);
    font-weight: var(--uxm-hero-heading-weight, 500);
    letter-spacing: -0.03em;
    line-height: 1.02;
}

/* Rotating headline word: same metrics as title line + clip for slide swap */
.works-hero__cycle {
    display: block;
    font-family: var(--uxm-font-heading, 'Montserrat', sans-serif);
    font-size: clamp(2.5rem, 8vw, 4.75rem);
    font-weight: var(--uxm-hero-heading-weight, 500);
    letter-spacing: -0.03em;
    line-height: 1.02;
    min-height: calc(1.02em + 0.02em);
    position: relative;
    text-align: center;
}

.works-hero__cycle-slot {
    display: inline-block;
    margin: 0 auto;
    max-width: 100%;
    overflow: hidden;
    padding-bottom: 0.02em;
    position: relative;
    vertical-align: bottom;
}

.works-hero__cycle-inner {
    animation: works-hero-word-initial 0.75s cubic-bezier(0.22, 1, 0.36, 1) forwards;
    color: var(--works-pink);
    display: inline-block;
    font-family: var(--uxm-font-heading, 'Montserrat', sans-serif);
    font-size: clamp(2.5rem, 8vw, 4.75rem);
    font-style: normal;
    font-weight: var(--uxm-hero-heading-weight, 500);
    letter-spacing: -0.03em;
    line-height: 1.02;
    position: relative;
    transform: translate3d(0, 0, 0);
    will-change: transform, opacity;
}

.works-hero__cycle-inner::after {
    background: var(--works-pink);
    bottom: 0;
    content: '';
    height: 1px;
    left: 8%;
    opacity: 0.65;
    position: absolute;
    right: 8%;
}

.works-hero__cycle-inner.is-swap-out {
    transition: transform 0.42s cubic-bezier(0.55, 0.06, 0.68, 0.19), opacity 0.32s ease;
    opacity: 0;
    transform: translate3d(0, -108%, 0);
}

.works-hero__cycle-inner.is-swap-in {
    animation: works-hero-word-swap-in 0.55s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes works-hero-word-initial {
    from {
        opacity: 0;
        transform: translate3d(0, 0.5em, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes works-hero-word-swap-in {
    from {
        opacity: 0;
        transform: translate3d(0, 0.55em, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .works-hero__cycle-inner {
        animation: none;
    }

    .works-hero__cycle-inner.is-swap-out,
    .works-hero__cycle-inner.is-swap-in {
        animation: none !important;
        transition: opacity 0.2s ease;
        transform: none;
    }
}

.works-hero__rule {
    background: linear-gradient(90deg, transparent, var(--works-pink) 22%, var(--works-rose-mid) 50%, var(--works-pink) 78%, transparent);
    height: 1px;
    margin: -0.25rem auto 1.75rem;
    max-width: 120px;
    opacity: 0.35;
    width: 100%;
}

.works-hero__lede {
    color: rgba(255, 255, 255, 0.82);
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(0.98rem, 1.85vw, 1.08rem);
    font-weight: 300;
    letter-spacing: 0.02em;
    line-height: 1.85;
    margin: 0 auto;
    max-width: 460px;
}

@media (prefers-reduced-motion: reduce) {
    .works-hero__title-line {
        background: none;
        -webkit-background-clip: unset;
        background-clip: unset;
        color: #f4f2f8;
    }

    .works-hero__title-block {
        filter: none;
    }

    .works-hero__cycle-inner {
        color: var(--works-pink);
    }

    .works-cta__heading {
        background: none;
        -webkit-background-clip: unset;
        background-clip: unset;
        color: #f4f2f8;
    }
}

/* --- Showcase grid (editorial / 2026 calibre) --- */

.works-showcase {
    background:
        radial-gradient(ellipse 90% 45% at 12% 0%, rgba(201, 184, 150, 0.07) 0%, transparent 52%),
        radial-gradient(ellipse 70% 40% at 92% 18%, rgba(100, 95, 120, 0.12) 0%, transparent 48%),
        linear-gradient(180deg, #03040a 0%, var(--works-void) 38%, #020308 100%);
    overflow: hidden;
    padding: clamp(1.25rem, 3.5vw, 2.25rem) clamp(22px, 5vw, 72px) clamp(5.5rem, 12vw, 9rem);
    position: relative;
}

.works-showcase__grain {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
    inset: 0;
    mix-blend-mode: overlay;
    opacity: 0.04;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.works-showcase__glow {
    background: radial-gradient(ellipse 55% 35% at 50% 0%, rgba(232, 213, 180, 0.06) 0%, transparent 65%);
    height: 280px;
    left: 50%;
    pointer-events: none;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: min(1100px, 100%);
    z-index: 0;
}

.works-showcase__inner {
    margin: 0 auto;
    max-width: 1320px;
    position: relative;
    z-index: 1;
}

/* --- Bottom CTA (grid → footer) --- */

.works-cta {
    background:
        radial-gradient(ellipse 80% 50% at 50% 100%, rgba(201, 184, 150, 0.06) 0%, transparent 55%),
        linear-gradient(180deg, #020308 0%, var(--works-void) 45%, #03040a 100%);
    box-sizing: border-box;
    color: #f4f2f8;
    padding: clamp(120px, 14vw, 180px) clamp(22px, 5vw, 72px);
    text-align: center;
    width: 100%;
}

.works-cta__inner {
    margin: 0 auto;
    max-width: 640px;
}

.works-cta__eyebrow {
    color: var(--works-champagne);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0.28em;
    margin: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
    text-transform: uppercase;
}

/* Same display stack as hero headlines */
.works-cta__heading {
    background: linear-gradient(180deg, #fdfcfa 0%, #e8e4ec 48%, #c8c2d0 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-family: var(--uxm-font-heading, 'Montserrat', sans-serif);
    font-size: clamp(2.1rem, 5.5vw, 3.35rem);
    font-weight: var(--uxm-hero-heading-weight, 500);
    letter-spacing: -0.03em;
    line-height: 1.08;
    margin: 0 0 clamp(1rem, 2vw, 1.35rem);
}

.works-cta__sub {
    color: rgba(210, 206, 218, 0.78);
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(1rem, 2vw, 1.12rem);
    font-weight: 300;
    line-height: 1.6;
    margin: 0 0 clamp(2rem, 4vw, 2.75rem);
}

.works-cta__btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
}

/* Interlocking mosaic: row1 [~75% landscape | ~25% portrait], row2 [portrait | landscape] */

.works-showcase__grid {
    display: grid;
    list-style: none;
    margin: 0;
    padding: 0;
}

.works-showcase__grid--catalog {
    align-items: stretch;
    column-gap: clamp(18px, 2.4vw, 28px);
    grid-template-columns: 1fr;
    row-gap: clamp(18px, 2.4vw, 28px);
}

@media (max-width: 767px) {
    .works-showcase__grid--catalog .works-showcase-card__frame {
        aspect-ratio: 16 / 11;
        min-height: clamp(220px, 62vw, 360px);
    }
}

@media (min-width: 768px) {
    /* Outer columns a touch wider than 1fr so portrait tiles gain ~15-20px; mirrors works mosaic (col 1 + col 4). */
    .works-showcase__grid--catalog {
        grid-template-columns: 1.15fr 1fr 1fr 1.15fr;
    }

    .works-showcase__cell--wl {
        grid-column: 1 / 4;
    }

    .works-showcase__cell--nr {
        grid-column: 4 / 5;
    }

    .works-showcase__cell--nl {
        grid-column: 1 / 2;
    }

    .works-showcase__cell--wr {
        grid-column: 2 / 5;
    }

    .works-showcase__cell--span-all {
        grid-column: 1 / -1;
    }

    .works-showcase__cell--wl .works-showcase-card__frame,
    .works-showcase__cell--wr .works-showcase-card__frame {
        aspect-ratio: 16 / 10;
        min-height: clamp(220px, 24vw, 340px);
    }

    .works-showcase__cell--nr .works-showcase-card__frame,
    .works-showcase__cell--nl .works-showcase-card__frame {
        aspect-ratio: 3 / 4;
        min-height: clamp(280px, 36vw, 480px);
    }

    .works-showcase__cell--span-all .works-showcase-card__frame {
        aspect-ratio: 21 / 9;
        min-height: clamp(230px, min(30vw, 34vh), 400px);
    }
}

.works-showcase__cell {
    display: flex;
    flex-direction: column;
    margin: 0;
    min-height: 0;
    min-width: 0;
}

/* Card - floating panel, rounded like reference mosaic */

.works-showcase-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

.works-showcase-card__link {
    color: inherit;
    display: flex;
    flex: 1;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    outline: none;
    text-decoration: none;
    transform: translateY(0);
    transition:
        transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.45s ease;
}

@media (hover: hover) and (pointer: fine) {
    .works-showcase-card__link:hover,
    .works-showcase-card__link:focus-visible {
        transform: translateY(-14px);
    }
}

.works-showcase-card__link:focus-visible .works-showcase-card__frame {
    outline: 2px solid var(--works-champagne-bright);
    outline-offset: 4px;
}

.works-showcase-card__frame {
    border-radius: clamp(14px, 1.7vw, 20px);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.07) inset,
        0 0 0 1px rgba(255, 255, 255, 0.055),
        0 28px 52px rgba(0, 0, 0, 0.38),
        0 56px 110px rgba(0, 0, 0, 0.44),
        0 96px 160px rgba(0, 0, 0, 0.28);
    flex: 1 1 auto;
    height: auto;
    isolation: isolate;
    min-height: 200px;
    overflow: hidden;
    position: relative;
    transition: box-shadow 0.55s cubic-bezier(0.22, 1, 0.36, 1);
    width: 100%;
}

@media (hover: hover) and (pointer: fine) {
    .works-showcase-card__link:hover .works-showcase-card__frame,
    .works-showcase-card__link:focus-visible .works-showcase-card__frame {
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.1) inset,
            0 0 0 1px rgba(201, 184, 150, 0.16),
            0 36px 64px rgba(0, 0, 0, 0.42),
            0 80px 140px rgba(0, 0, 0, 0.5),
            0 120px 200px rgba(0, 0, 0, 0.32);
    }
}

.works-showcase-card__img {
    display: block;
    height: 100%;
    left: 0;
    object-fit: cover;
    object-position: center;
    position: absolute;
    top: 0;
    transform: scale(1.02);
    transition: transform 0.95s cubic-bezier(0.22, 1, 0.36, 1);
    width: 100%;
}

.works-showcase-card__link:hover .works-showcase-card__img,
.works-showcase-card__link:focus-visible .works-showcase-card__img {
    transform: scale(1.055);
}

.works-showcase-card__gradient {
    background: linear-gradient(
        180deg,
        rgba(3, 4, 10, 0) 0%,
        rgba(3, 4, 10, 0.04) 38%,
        rgba(3, 4, 10, 0.62) 78%,
        rgba(3, 4, 10, 0.96) 100%
    );
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 1;
}

.works-showcase-card__arrow {
    align-items: center;
    background: rgba(4, 5, 10, 0.52);
    border: 1px solid rgba(255, 255, 255, 0.26);
    border-radius: 6px;
    color: rgba(248, 246, 252, 0.95);
    display: flex;
    height: 38px;
    justify-content: center;
    pointer-events: none;
    position: absolute;
    right: clamp(0.85rem, 2.2vw, 1.35rem);
    top: clamp(0.85rem, 2.2vw, 1.35rem);
    transition:
        opacity 0.4s ease,
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.35s ease,
        background 0.35s ease;
    width: 38px;
    z-index: 3;
}

.works-showcase-card__link:hover .works-showcase-card__arrow,
.works-showcase-card__link:focus-visible .works-showcase-card__arrow {
    background: rgba(4, 5, 10, 0.78);
    border-color: rgba(232, 213, 180, 0.5);
    transform: translate(2px, -2px);
}

@media (hover: hover) and (pointer: fine) {
    .works-showcase-card__arrow {
        opacity: 0;
    }

    .works-showcase-card__link:hover .works-showcase-card__arrow,
    .works-showcase-card__link:focus-visible .works-showcase-card__arrow {
        opacity: 1;
    }
}

@media (hover: none), (pointer: coarse) {
    .works-showcase-card__arrow {
        opacity: 0.88;
    }
}

.works-showcase-card__copy {
    bottom: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    left: 0;
    max-width: min(38rem, 92%);
    padding: clamp(1.15rem, 3.2vw, 2rem);
    position: absolute;
    text-align: left;
    z-index: 2;
}

.works-showcase-card__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 0.15rem;
}

.works-showcase-card__pill {
    border: 1px solid rgba(255, 255, 255, 0.38);
    border-radius: 999px;
    color: rgba(248, 246, 252, 0.88);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    padding: 0.32rem 0.65rem;
    text-transform: uppercase;
}

.works-showcase-card__client {
    color: rgba(200, 198, 210, 0.75);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    margin: 0;
    text-transform: uppercase;
}

.works-showcase-card__headline {
    color: #f8f8f8;
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(1.15rem, 2.4vw, 1.65rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0;
}

.works-showcase-card__outcome {
    color: rgba(230, 228, 238, 0.82);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    line-height: 1.45;
    margin: 0;
}

.works-showcase-card__metric {
    color: var(--uxm-brand, #e8195a);
    font-weight: 700;
}

@media (min-width: 992px) {
    .works-showcase-card__client {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 1;
        overflow: hidden;
    }

    .works-showcase-card__headline {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden;
    }

    .works-showcase-card__outcome {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden;
    }
}

@media (prefers-reduced-motion: reduce) {
    .works-showcase-card__img,
    .works-showcase-card__arrow,
    .works-showcase-card__link,
    .works-showcase-card__frame {
        transition: none !important;
    }

    .works-showcase-card__link:hover,
    .works-showcase-card__link:focus-visible {
        transform: none;
    }

    .works-showcase-card__link:hover .works-showcase-card__img,
    .works-showcase-card__link:focus-visible .works-showcase-card__img {
        transform: scale(1.02);
    }

    .works-showcase-card__link:hover .works-showcase-card__arrow,
    .works-showcase-card__link:focus-visible .works-showcase-card__arrow {
        transform: none;
    }

}

/* Tablet / small laptop: show full catalog stack (no horizontal mosaic strip). */
@media (max-width: 991px) {
    .works-showcase__grid--catalog {
        grid-template-columns: 1fr;
        row-gap: clamp(20px, 4vw, 32px);
    }

    .works-showcase__grid--catalog .works-showcase__cell,
    .works-showcase__grid--catalog .works-showcase__cell--wl,
    .works-showcase__grid--catalog .works-showcase__cell--nr,
    .works-showcase__grid--catalog .works-showcase__cell--nl,
    .works-showcase__grid--catalog .works-showcase__cell--wr,
    .works-showcase__grid--catalog .works-showcase__cell--span-all {
        grid-column: 1 / -1;
    }
}
