:root {
    --bg: #030508;
    --bg-2: #07101a;
    --ink: #c8e0f0;
    --ink-dim: #6b7f92;
    --ink-faint: #243444;
    --accent: #00ffaa;
    --accent-2: #00d4ff;
    --warn: #ff2dd4;
    --mono: 'JetBrains Mono', Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    --serif: 'Space Mono', 'JetBrains Mono', monospace;
}

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

html {
    background: #000;
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    margin: 0;
    background: #000;
    color: var(--ink);
    font: 300 15px/1.6 var(--mono);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body::before,
body::after {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
}

body::before {
    z-index: 0;
    background:
        radial-gradient(circle at 18% 22%, rgba(0, 255, 170, 0.16), transparent 24vw),
        radial-gradient(circle at 78% 14%, rgba(0, 212, 255, 0.14), transparent 22vw),
        radial-gradient(circle at 70% 76%, rgba(255, 45, 212, 0.1), transparent 26vw),
        linear-gradient(135deg, rgba(2, 8, 14, 0.96), rgba(3, 6, 10, 0.98));
    animation: rl-bg-drift 16s ease-in-out infinite alternate;
}

body::after {
    z-index: 1;
    opacity: 0.28;
    background-image:
        linear-gradient(rgba(0, 255, 170, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 255, 170, 0.08) 1px, transparent 1px),
        radial-gradient(ellipse at center, transparent 28%, rgba(0, 0, 0, 0.74));
    background-size: 52px 52px, 52px 52px, 100% 100%;
    mix-blend-mode: screen;
}

@keyframes rl-bg-drift {
    from { filter: hue-rotate(0deg) brightness(0.95); transform: scale(1); }
    to { filter: hue-rotate(18deg) brightness(1.08); transform: scale(1.04); }
}

a {
    color: inherit;
    text-decoration: none;
}

img,
video,
iframe {
    max-width: 100%;
}

code {
    color: var(--accent);
    font-family: var(--mono);
}

.grain,
.vignette {
    position: fixed;
    inset: -80px;
    pointer-events: none;
}

.grain {
    z-index: 2;
    opacity: 0.065;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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.72'/%3E%3C/svg%3E");
}

.vignette {
    z-index: 3;
    background: radial-gradient(ellipse at center, transparent 34%, rgba(0, 0, 0, 0.72) 100%);
}

.sub-strip {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 24px;
    align-items: center;
    padding: 26px 46px;
    color: #fff;
    font: 500 11px/1 var(--mono);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.85);
}

.sub-strip nav {
    display: flex;
    justify-content: center;
    gap: 24px;
}

.sub-strip a,
.sub-next a,
.work-link {
    transition: color 0.2s ease, opacity 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.sub-strip a:hover,
.sub-next a:hover,
.work-link:hover {
    color: var(--accent);
}

.strip-brand {
    font-weight: 700;
}

.sub-main,
.sub-foot {
    position: relative;
    z-index: 10;
    width: min(1180px, calc(100% - 12vw));
    margin: 0 auto;
}

.sub-main {
    padding: 18vh 0 9vh;
}

.sub-hero {
    min-height: 62vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 4vh 0 10vh;
}

.eyebrow,
.section-num,
.card-meta,
.media-cap,
.detail-path {
    color: rgba(200, 224, 240, 0.52);
    font: 300 11px/1.35 var(--mono);
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.eyebrow {
    margin-bottom: 30px;
}

.sub-hero h1,
.section-title {
    margin: 0;
    color: var(--ink);
    font: 700 clamp(48px, 9vw, 138px)/0.95 var(--mono);
    letter-spacing: -0.055em;
    text-transform: uppercase;
}

.sub-hero h1 em,
.section-title em,
.card-title em {
    color: var(--accent);
    font-style: normal;
    font-weight: 400;
    text-shadow: 0 0 24px rgba(0, 255, 170, 0.65);
}

.lede {
    max-width: 720px;
    margin: 44px 0 0;
    color: var(--ink-dim);
    font-size: 17px;
}

.lede em {
    color: var(--ink);
    font: italic 22px/1.25 var(--serif);
}

.work-index,
.project-grid,
.media-stack,
.sub-next {
    margin-top: 72px;
}

.work-index {
    border-top: 1px solid var(--ink-faint);
}

.work-link {
    display: grid;
    grid-template-columns: 74px 1.2fr 1.8fr auto;
    gap: 24px;
    align-items: baseline;
    padding: 22px 0;
    border-bottom: 1px solid var(--ink-faint);
}

.work-title {
    color: var(--ink);
    font: 500 20px/1.2 var(--mono);
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.work-desc {
    color: var(--ink-dim);
}

.work-link:hover {
    transform: translateX(8px);
}

.project-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.project-card,
.project-block,
.gallery-item {
    border: 1px solid rgba(42, 56, 72, 0.9);
    background: linear-gradient(145deg, rgba(5, 12, 19, 0.86), rgba(2, 7, 11, 0.68));
    box-shadow: 0 0 0 1px rgba(0, 255, 170, 0.03), 0 28px 80px rgba(0, 0, 0, 0.28);
}

.project-card {
    display: grid;
    grid-template-rows: minmax(220px, 38vw) auto;
    min-height: 100%;
    overflow: hidden;
}

.card-media,
.gallery-media {
    min-height: 220px;
    background: #030508;
    overflow: hidden;
}

.card-media img,
.card-media video,
.gallery-media img,
.media-item img,
.media-item video {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.card-body {
    padding: 24px;
}

.card-title {
    margin: 10px 0 12px;
    color: var(--ink);
    font: 500 clamp(21px, 3vw, 32px)/1.05 var(--mono);
    letter-spacing: -0.03em;
    text-transform: uppercase;
}

.card-copy {
    margin: 0;
    color: var(--ink-dim);
}

.detail-path {
    display: block;
    margin-top: 18px;
    word-break: break-word;
}

.section-head {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 34px;
    align-items: start;
    margin: 120px 0 34px;
}

.section-title {
    max-width: 12ch;
    font-size: clamp(34px, 6vw, 84px);
    line-height: 1;
}

.project-block {
    margin-top: 28px;
    padding: clamp(20px, 4vw, 42px);
}

.project-block + .project-block {
    margin-top: 44px;
}

.block-head {
    display: grid;
    grid-template-columns: 1fr minmax(220px, 0.42fr);
    gap: 32px;
    margin-bottom: 28px;
}

.block-head h2 {
    margin: 0;
    color: var(--ink);
    font: 600 clamp(28px, 5vw, 58px)/1 var(--mono);
    letter-spacing: -0.045em;
    text-transform: uppercase;
}

.block-copy {
    margin: 14px 0 0;
    max-width: 68ch;
    color: var(--ink-dim);
}

.block-meta {
    align-self: end;
    padding: 16px 0 0;
    border-top: 1px solid var(--ink-faint);
    color: rgba(200, 224, 240, 0.6);
    font: 300 11px/1.7 var(--mono);
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.media-grid,
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.gallery-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.media-item,
.gallery-item {
    position: relative;
    margin: 0;
    overflow: hidden;
}

.media-item {
    background: rgba(0, 0, 0, 0.5);
}

.media-item img,
.media-item video,
.gallery-media img {
    min-height: 280px;
    border: 1px solid rgba(42, 56, 72, 0.88);
}

.media-item img,
.gallery-media img {
    cursor: zoom-in;
}

.media-cap {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 0 0;
}

.gallery-item {
    min-height: 100%;
}

.gallery-media {
    aspect-ratio: 4 / 5;
}

.gallery-item:nth-child(3n + 1) .gallery-media {
    aspect-ratio: 16 / 10;
}

.gallery-item:nth-child(4n) .gallery-media {
    aspect-ratio: 1 / 1;
}

.gallery-caption {
    padding: 14px 16px 18px;
}

.embed {
    position: relative;
    aspect-ratio: 16 / 9;
    background: #000;
    border: 1px solid rgba(42, 56, 72, 0.88);
}

.embed iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.youtube-lite {
    display: grid;
    place-items: center;
}

.youtube-load {
    width: 100%;
    height: 100%;
    padding: 28px;
    border: 0;
    background:
        radial-gradient(circle at 50% 42%, rgba(0, 255, 170, 0.16), transparent 26%),
        linear-gradient(135deg, rgba(2, 8, 14, 0.88), rgba(3, 5, 10, 0.96));
    color: var(--ink);
    font-family: var(--mono);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
}

.youtube-load span,
.youtube-load strong {
    display: block;
}

.youtube-load span {
    color: var(--accent);
    font-size: 11px;
    margin-bottom: 12px;
}

.youtube-load strong {
    font-size: clamp(16px, 2.4vw, 28px);
    font-weight: 500;
}

.youtube-load:hover,
.youtube-load:focus-visible {
    outline: 1px solid var(--accent);
    outline-offset: -8px;
}

.sub-next {
    border-top: 1px solid var(--ink-faint);
}

.sub-next a {
    display: grid;
    grid-template-columns: 130px 1fr auto;
    gap: 24px;
    align-items: center;
    padding: 28px 0;
    text-transform: uppercase;
}

.next-title {
    color: var(--ink);
    font: 500 clamp(24px, 4vw, 44px)/1.1 var(--mono);
    letter-spacing: -0.03em;
}

.sub-foot {
    z-index: 10;
    display: flex;
    justify-content: space-between;
    gap: 24px;
    padding: 34px 0 46px;
    border-top: 1px solid var(--ink-faint);
    color: rgba(200, 224, 240, 0.48);
    font: 300 11px/1.4 var(--mono);
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.lightbox {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: 4vh 4vw;
    background: rgba(0, 0, 0, 0.95);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease;
    cursor: zoom-out;
}

.lightbox.is-open {
    opacity: 1;
    pointer-events: auto;
}

.lightbox img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.lightbox-close {
    position: absolute;
    top: 24px;
    right: 24px;
    padding: 8px 12px;
    border: 1px solid var(--ink-faint);
    background: rgba(0, 0, 0, 0.5);
    color: var(--ink-dim);
    font: 500 11px/1 var(--mono);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
}

.js .reveal {
    opacity: 0;
    transform: translateY(36px);
    transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.2, 0.8, 0.3, 1);
}

.js .reveal.is-in {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: 0.001ms !important;
    }

    .js .reveal {
        opacity: 1;
        transform: none;
    }
}

@media (max-width: 880px) {
    .sub-strip {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 18px 22px;
    }

    .sub-strip nav {
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 14px;
    }

    .sub-main,
    .sub-foot {
        width: min(100% - 36px, 1180px);
    }

    .sub-main {
        padding-top: 22vh;
    }

    .project-grid,
    .media-grid,
    .gallery-grid,
    .block-head,
    .section-head,
    .work-link,
    .sub-next a {
        grid-template-columns: 1fr;
    }

    .project-card {
        grid-template-rows: auto auto;
    }

    .card-media,
    .gallery-media {
        min-height: 0;
        aspect-ratio: 16 / 10;
    }

    .media-item img,
    .media-item video {
        min-height: 0;
    }

    .work-link:hover {
        transform: none;
    }

    .sub-foot {
        flex-direction: column;
    }
}
