:root {
    /* Typography source notes: (Google Fonts; Interaction Model:** Model::* typewriter-driven plate navigation. */
    --indigo: #2B2D42;
    --yellow: #F2E307;
    --cyan: #00B4D8;
    --orange: #FF6B35;
    --black: #1A1A1A;
    --stone: #B8B2A7;
    --magenta: #E8175D;
    --paper: #F5F0E8;
    --display: "Playfair Display", serif;
    --mono: "IBM Plex Mono", monospace;
    --condensed: "IBM Plex Sans Condensed", "Inter", sans-serif;
    --space: "Space Grotesk", "Inter", sans-serif;
}

* { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    scroll-snap-type: y mandatory;
}

body {
    margin: 0;
    background: var(--paper);
    color: var(--black);
    font-family: var(--mono);
    overflow-x: hidden;
}

.registration-grid,
.ink-noise {
    position: fixed;
    inset: 0;
    pointer-events: none;
}

.registration-grid {
    z-index: 20;
    background-image:
        linear-gradient(rgba(232, 23, 93, .08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(232, 23, 93, .08) 1px, transparent 1px);
    background-size: 80px 80px;
    mix-blend-mode: multiply;
}

.ink-noise {
    z-index: 21;
    opacity: .12;
    background:
        radial-gradient(circle at 11% 28%, var(--black) 0 1px, transparent 2px),
        radial-gradient(circle at 71% 18%, var(--magenta) 0 1px, transparent 2px),
        radial-gradient(circle at 45% 79%, var(--cyan) 0 1px, transparent 2px),
        radial-gradient(circle at 88% 62%, var(--orange) 0 1px, transparent 2px);
    background-size: 37px 41px, 53px 47px, 43px 59px, 61px 31px;
}

.fixed-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 28px;
    font-family: var(--condensed);
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .78rem;
    background: rgba(245, 240, 232, .62);
    border-bottom: 3px solid var(--black);
    box-shadow: 5px 5px 0 rgba(232, 23, 93, .7), -4px 8px 0 rgba(0, 180, 216, .55);
    transition: background-color .25s ease, color .25s ease;
}

.brand-mark,
.plate-link,
.contact-email { color: inherit; text-decoration: none; }

.plate-index { display: flex; gap: 18px; }

.plate-link {
    display: inline-block;
    padding: 2px 3px;
    border: 2px solid transparent;
}

.plate-link.active,
.plate-link:hover {
    background: var(--yellow);
    border-color: var(--black);
    transform: rotate(-2deg);
}

.plate {
    position: relative;
    min-height: 100vh;
    width: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    display: grid;
    place-items: center;
    overflow: hidden;
    padding: 82px 24px 48px;
}

.plate::before {
    content: attr(data-plate);
    position: absolute;
    right: clamp(16px, 4vw, 52px);
    bottom: 22px;
    font-family: var(--display);
    font-size: clamp(5rem, 14vw, 13rem);
    line-height: .75;
    color: rgba(26, 26, 26, .08);
}

.plate-content {
    width: min(100%, 760px);
    position: relative;
    z-index: 2;
}

.wide-content { width: min(100%, 1120px); }

.split-content {
    width: min(100%, 1160px);
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(300px, 1.05fr);
    gap: clamp(26px, 6vw, 78px);
    align-items: center;
}

.split-content.reverse { grid-template-columns: minmax(300px, 1.05fr) minmax(280px, 1fr); }

.plate-hero { background: var(--magenta); }
.plate-manifesto { background: var(--paper); }
.plate-series { background: var(--cyan); }
.plate-process { background: var(--indigo); color: var(--paper); }
.plate-studio { background: var(--orange); }
.plate-contact { background: var(--yellow); }

.hero-column {
    width: min(760px, 88vw);
    text-align: center;
    position: relative;
    z-index: 3;
}

.kicker {
    margin: 0 0 18px;
    font-family: var(--condensed);
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    font-size: .9rem;
}

.hero-title,
.section-title,
.contact-title {
    margin: 0;
    font-family: var(--display);
    font-weight: 900;
    letter-spacing: -.04em;
    line-height: .92;
}

.hero-title {
    font-size: clamp(4.1rem, 12vw, 10.8rem);
    text-transform: lowercase;
    color: var(--paper);
    text-shadow: 8px 0 0 var(--cyan), -8px 0 0 var(--yellow), 0 10px 0 var(--black);
    animation: registrationSettle 1.1s cubic-bezier(.19, 1, .22, 1) both;
}

.section-title {
    font-size: clamp(3rem, 8vw, 8rem);
    color: var(--magenta);
}

.typed-row,
.type-specimen,
.contact-email {
    display: inline-block;
    margin-top: 30px;
    padding: 12px 16px;
    background: var(--paper);
    border: 3px solid var(--black);
    box-shadow: 7px 7px 0 var(--cyan);
    font-family: var(--mono);
    font-size: clamp(.95rem, 2vw, 1.25rem);
    min-height: 54px;
}

.typewriter-cursor {
    display: inline-block;
    width: .68em;
    height: 1.08em;
    margin-left: 3px;
    vertical-align: -0.16em;
    background: var(--yellow);
    border: 1px solid var(--black);
    animation: blink .53s steps(2, start) infinite;
}

.torn-sticker {
    position: absolute;
    z-index: 2;
    padding: 18px 22px;
    font-family: var(--space);
    font-size: clamp(1rem, 2vw, 1.65rem);
    line-height: .95;
    text-transform: uppercase;
    border: 4px solid var(--black);
    box-shadow: 8px 8px 0 var(--black);
}

.sticker-cyan { left: 8vw; top: 21vh; background: var(--cyan); transform: rotate(-11deg); }
.sticker-yellow { right: 6vw; bottom: 17vh; background: var(--yellow); transform: rotate(8deg); }

.registration-mark {
    position: absolute;
    width: 74px;
    height: 74px;
    border: 3px solid var(--black);
    border-radius: 50%;
    opacity: .8;
}

.registration-mark::before,
.registration-mark::after {
    content: "";
    position: absolute;
    background: var(--black);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.registration-mark::before { width: 104px; height: 3px; }
.registration-mark::after { width: 3px; height: 104px; }
.mark-a { left: 28px; bottom: 34px; }
.mark-b { right: 24px; top: 96px; }

.text-block {
    background: rgba(245, 240, 232, .92);
    border: 4px solid var(--black);
    padding: clamp(24px, 4vw, 44px);
    box-shadow: 12px 12px 0 var(--yellow);
}

.rupture-left { transform: translateX(-36px) rotate(-1deg); }
.rupture-right { transform: translateX(36px) rotate(1.5deg); }

.body-copy {
    font-size: clamp(1rem, 1.8vw, 1.18rem);
    line-height: 1.68;
    max-width: 58ch;
}

.poster-window {
    min-height: 520px;
    position: relative;
    border: 5px solid var(--black);
    background: var(--stone);
    box-shadow: -14px 14px 0 var(--cyan), 16px -14px 0 var(--magenta);
    overflow: hidden;
}

.halftone-face,
.cyan-plate,
.magenta-plate,
.work-art::before,
.work-art::after {
    position: absolute;
    inset: 0;
}

.halftone-face {
    background:
        radial-gradient(circle at center, var(--black) 0 23%, transparent 24%) 0 0 / 14px 14px,
        linear-gradient(135deg, transparent 0 28%, var(--paper) 29% 40%, transparent 41% 100%),
        radial-gradient(circle at 48% 42%, var(--paper) 0 12%, transparent 13%),
        radial-gradient(circle at 53% 56%, var(--black) 0 19%, transparent 20%),
        var(--yellow);
    mix-blend-mode: multiply;
}

.cyan-plate {
    background: repeating-linear-gradient(-18deg, transparent 0 13px, rgba(0,180,216,.68) 14px 22px, transparent 23px 34px);
    transform: translate(10px, -8px);
    mix-blend-mode: multiply;
    transition: transform .4s ease;
}

.magenta-plate {
    background: radial-gradient(circle at 48% 52%, transparent 0 22%, rgba(232,23,93,.85) 23% 34%, transparent 35%);
    transform: translate(-8px, 6px);
    mix-blend-mode: multiply;
    transition: transform .4s ease;
}

.poster-window:hover .cyan-plate,
.poster-window.is-settled .cyan-plate { transform: translate(3px, -2px); }
.poster-window:hover .magenta-plate,
.poster-window.is-settled .magenta-plate { transform: translate(-3px, 2px); }

.caption-label,
.work-card p,
.contact-note {
    font-family: var(--condensed);
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.caption-label {
    position: absolute;
    left: 16px;
    bottom: 16px;
    background: var(--paper);
    border: 3px solid var(--black);
    padding: 8px 10px;
}

.torn-title {
    color: var(--paper);
    text-shadow: 5px 5px 0 var(--black), -5px -5px 0 var(--magenta);
    margin-bottom: 34px;
    transform: translateX(-5vw);
}

.work-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    gap: 22px;
}

.work-card {
    position: relative;
    background: var(--paper);
    border: 4px solid var(--black);
    padding: 12px;
    min-height: 360px;
    box-shadow: 9px 9px 0 var(--black);
    transition: transform .2s ease, box-shadow .2s ease;
}

.work-card:nth-child(2) { transform: translateY(38px) rotate(1deg); }
.work-card:nth-child(3) { transform: translateY(-18px) rotate(-1.5deg); }
.work-card:nth-child(4) { transform: translateY(24px) rotate(2deg); }
.work-card:hover { transform: translate(6px, -8px) rotate(-2deg); box-shadow: 16px 16px 0 var(--magenta); }

.work-art {
    height: 270px;
    position: relative;
    overflow: hidden;
    border: 3px solid var(--black);
    background-color: var(--stone);
    background-image: radial-gradient(circle, var(--black) 0 2px, transparent 3px);
    background-size: 12px 12px;
}

.work-art::before,
.work-art::after { content: ""; mix-blend-mode: multiply; }
.art-one::before { background: var(--magenta); clip-path: polygon(18% 10%, 82% 24%, 74% 86%, 8% 70%); transform: translate(-8px, 4px); }
.art-one::after { background: var(--cyan); clip-path: circle(34% at 62% 48%); transform: translate(8px, -8px); }
.art-two::before { background: var(--cyan); clip-path: polygon(0 22%, 100% 0, 76% 100%, 19% 86%); transform: translate(6px, -4px); }
.art-two::after { background: var(--yellow); clip-path: polygon(22% 18%, 90% 52%, 28% 92%); transform: translate(-7px, 9px); }
.art-three::before { background: var(--yellow); clip-path: circle(44% at 44% 46%); transform: translate(9px, 5px); }
.art-three::after { background: var(--magenta); clip-path: polygon(10% 70%, 88% 12%, 100% 100%); transform: translate(-6px, -6px); }
.art-four::before { background: var(--orange); clip-path: polygon(0 0, 72% 8%, 96% 64%, 10% 100%); transform: translate(-9px, -2px); }
.art-four::after { background: var(--indigo); clip-path: circle(30% at 51% 53%); transform: translate(10px, 7px); }

.work-card p { margin: 14px 0 0; font-size: .88rem; }

.plate-process .section-title { color: var(--yellow); }

.process-layout {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
}

.process-title {
    max-width: 900px;
    text-shadow: 7px 0 0 var(--magenta), -7px 0 0 var(--cyan);
}

.type-specimen {
    color: var(--black);
    box-shadow: 7px 7px 0 var(--magenta);
    margin: 34px 0;
}

.process-notes {
    display: grid;
    grid-template-columns: repeat(2, minmax(240px, 1fr));
    gap: 28px;
    max-width: 900px;
    font-size: 1.07rem;
    line-height: 1.7;
}

.cmyk-stack {
    width: min(680px, 80vw);
    height: 46px;
    margin-top: 28px;
    border: 4px solid var(--paper);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.cmyk-stack span:nth-child(1) { background: var(--cyan); }
.cmyk-stack span:nth-child(2) { background: var(--magenta); }
.cmyk-stack span:nth-child(3) { background: var(--yellow); }
.cmyk-stack span:nth-child(4) { background: var(--black); }

.stamp-cloud {
    min-height: 520px;
    position: relative;
}

.stamp-cloud span {
    position: absolute;
    display: inline-block;
    padding: 14px 20px;
    border: 5px solid var(--black);
    font-family: var(--space);
    font-size: clamp(1.3rem, 5vw, 4.2rem);
    line-height: .9;
    color: var(--black);
    background: var(--paper);
    mix-blend-mode: multiply;
}

.stamp-cloud span:nth-child(1) { left: 4%; top: 5%; background: var(--yellow); transform: rotate(-10deg); }
.stamp-cloud span:nth-child(2) { right: 6%; top: 18%; background: var(--cyan); transform: rotate(12deg); }
.stamp-cloud span:nth-child(3) { left: 12%; top: 42%; background: var(--magenta); transform: rotate(-3deg); }
.stamp-cloud span:nth-child(4) { right: 14%; bottom: 18%; background: var(--stone); transform: rotate(7deg); }
.stamp-cloud span:nth-child(5) { left: 0; bottom: 2%; background: var(--paper); transform: rotate(-14deg); }

.plate-studio .section-title { color: var(--indigo); }
.plate-studio .text-block { box-shadow: -12px 12px 0 var(--cyan); }

.contact-panel {
    width: min(920px, 92vw);
    position: relative;
    z-index: 2;
    text-align: center;
    background: var(--paper);
    border: 6px solid var(--black);
    padding: clamp(30px, 7vw, 78px);
    box-shadow: 18px 18px 0 var(--magenta), -18px -18px 0 var(--cyan);
}

.contact-title {
    font-size: clamp(3rem, 8vw, 7.5rem);
    color: var(--black);
}

.contact-email {
    margin-top: 34px;
    color: var(--black);
    box-shadow: 7px 7px 0 var(--orange);
}

.contact-note { margin: 28px 0 0; }

@keyframes blink { 50% { opacity: 0; } }

@keyframes registrationSettle {
    0% { text-shadow: 30px -18px 0 var(--cyan), -26px 16px 0 var(--yellow), 0 22px 0 var(--black); transform: skewX(-7deg); }
    100% { text-shadow: 8px 0 0 var(--cyan), -8px 0 0 var(--yellow), 0 10px 0 var(--black); transform: skewX(0); }
}

.in-view .section-title { animation: slamIn .46s cubic-bezier(.18,.89,.32,1.28) both; }

@keyframes slamIn {
    from { opacity: .35; transform: translate(-22px, 18px) rotate(-3deg); }
    to { opacity: 1; transform: translate(0, 0) rotate(0); }
}

@media (max-width: 900px) {
    .split-content,
    .split-content.reverse,
    .process-notes { grid-template-columns: 1fr; }
    .rupture-left,
    .rupture-right,
    .torn-title { transform: none; }
    .work-grid { grid-template-columns: repeat(2, minmax(150px, 1fr)); }
    .work-card:nth-child(n) { transform: none; min-height: 300px; }
    .work-art { height: 210px; }
    .poster-window { min-height: 380px; }
}

@media (max-width: 620px) {
    .fixed-nav { padding: 12px; font-size: .66rem; }
    .plate-index { gap: 7px; }
    .plate { padding: 76px 16px 42px; }
    .work-grid { grid-template-columns: 1fr; }
    .sticker-cyan,
    .sticker-yellow { display: none; }
    .hero-title { text-shadow: 4px 0 0 var(--cyan), -4px 0 0 var(--yellow), 0 6px 0 var(--black); }
    .contact-panel { box-shadow: 9px 9px 0 var(--magenta), -9px -9px 0 var(--cyan); }
}
