@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,500;0,600;0,700;0,800;0,900;1,700;1,800;1,900&family=Caveat:wght@500;600&family=Roboto+Condensed:wght@400;500;600;700&display=swap');

:root {
  --paper: #f4e6c8;
  --ink: #10181b;
  --red: #ed2d1c;
  --blue: #155db5;
  --pink: #e9cbd3;
  --line: rgba(16, 24, 27, .62);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "Roboto Condensed", Arial, sans-serif;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  z-index: 100;
  inset: 0;
  pointer-events: none;
  opacity: .25;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.08'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}
body.is-locked { overflow: hidden; }
button, a { color: inherit; font: inherit; }
button { cursor: pointer; }
img { display: block; max-width: 100%; }
a { text-underline-offset: 5px; }

.site-header {
  position: fixed;
  z-index: 50;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 27px 3.2vw 18px;
  background: linear-gradient(var(--paper) 72%, rgba(244,230,200,0));
}
.wordmark {
  font-family: "Barlow Condensed", Impact, sans-serif;
  font-size: clamp(38px, 4.3vw, 70px);
  font-weight: 800;
  font-style: italic;
  line-height: .75;
  letter-spacing: -.025em;
  text-decoration: none;
  transform: skew(-4deg);
}
.site-nav { display: flex; align-items: center; gap: clamp(28px, 4.2vw, 70px); font-size: 13px; font-weight: 600; text-transform: uppercase; }
.site-nav a { position: relative; text-decoration: none; }
.site-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -8px; height: 2px; background: var(--blue); transition: right .3s; }
.site-nav a:hover::after, .site-nav a.is-active::after { right: 0; }
.site-nav .nav-cta { color: var(--red); }
.site-nav .nav-cta::after { display: none; }
.nav-cta i { display: inline-block; width: 11px; height: 11px; margin-right: 15px; border-radius: 50%; background: var(--red); }
.menu-toggle { display: none; border: 0; padding: 0; background: transparent; text-transform: uppercase; }

.hero { position: relative; min-height: 1000px; height: 100svh; padding: 150px 3.2vw 32px; overflow: hidden; }
.hero-rule { position: absolute; left: 2.8vw; top: 15.8%; bottom: 13%; border-left: 1px dashed var(--line); }
.hero-copy { position: relative; z-index: 4; width: 44%; padding-left: 1.2vw; }
.hero h1 { margin: 0; font-family: "Barlow Condensed", Impact, sans-serif; font-size: clamp(116px, 13.3vw, 214px); font-weight: 800; font-style: italic; line-height: .72; letter-spacing: -.045em; text-transform: uppercase; }
.hero h1 span { display: block; }
.hero-services { margin: 26px 0 0; color: var(--red); font-family: "Barlow Condensed", sans-serif; font-size: clamp(18px, 1.65vw, 27px); font-weight: 700; text-transform: uppercase; }
.hero-services::after { content: ""; display: block; width: 180px; height: 12px; margin-top: 8px; border-top: 2px solid var(--blue); border-radius: 50%; transform: rotate(-1deg); }
.hero-meta { margin: 14px 0 0 8px; }
.hero-meta > p { margin: 0 0 16px; font-size: 18px; font-weight: 700; text-transform: uppercase; }
.hero-filters { display: flex; gap: clamp(35px, 5vw, 84px); }
.hero-filters button, .filter-row button { position: relative; border: 0; padding: 0 2px 8px; background: transparent; font-size: 14px; text-transform: uppercase; }
.hero-filters button::after, .filter-row button::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 2px; background: var(--blue); transition: right .25s; }
.hero-filters button.is-active::after, .hero-filters button:hover::after, .filter-row button.is-active::after, .filter-row button:hover::after { right: 0; }
.hero-filters button.is-active { color: var(--red); }
.scribble-cta { display: inline-block; position: relative; margin: 52px 0 0; padding: 15px 21px; color: var(--red); font-size: 16px; font-weight: 600; text-transform: uppercase; text-decoration: none; }
.scribble-cta::before, .scribble-cta::after { content: ""; position: absolute; inset: 0 -12px; border: 2px solid var(--red); border-radius: 51% 46% 53% 47%; transform: rotate(-3deg); }
.scribble-cta::after { inset: -4px -17px 2px -9px; transform: rotate(3deg); }
.poster-stage { position: absolute; z-index: 2; inset: 100px 3.5vw 25px 43%; isolation: isolate; }
.poster { position: absolute; z-index: 1; padding: 0; border: 0; background: transparent; box-shadow: 0 20px 35px rgba(35,22,10,.16); transition: transform .55s cubic-bezier(.2,.75,.2,1), filter .55s; }
.poster:hover { z-index: 2; filter: saturate(1.12); }
.poster img, .poster video { display: block; width: 100%; height: 100%; object-fit: contain; }
.poster video { pointer-events: none; background: transparent; }
.poster-one { left: 12%; top: 2%; width: 29%; height: auto; aspect-ratio: 992 / 1586; transform: rotate(1.2deg); }
.poster-one:hover { transform: rotate(-1deg) translateY(-12px); }
.poster-two { right: 4%; top: 10%; width: 30%; height: auto; aspect-ratio: 1012 / 1800; transform: rotate(.25deg); }
.poster-two:hover { transform: rotate(2deg) translateY(-12px); }
.poster-three { left: 8%; bottom: -9%; width: 31%; height: auto; aspect-ratio: 1004 / 1800; transform: rotate(-1deg); }
.poster-three:hover { transform: rotate(1deg) translateY(-12px); }
.tape { position: absolute; z-index: 3; top: -18px; left: 39%; width: 30%; height: 30px; opacity: .92; transform: rotate(4deg); }
.tape-red { background: var(--red); }
.tape-blue { background: var(--blue); transform: rotate(7deg); }
.annotation { position: absolute; z-index: 20; margin: 0; font-family: Caveat, cursive; font-size: clamp(18px, 1.6vw, 26px); line-height: 1.05; text-transform: uppercase; transform: rotate(-4deg); pointer-events: none; }
.annotation b { display: block; width: fit-content; margin: 0 auto 9px; padding: 1px 6px; border: 1.5px solid currentColor; border-radius: 50%; font-weight: 500; }
.annotation span { display: block; font-size: 42px; }
.annotation-one { left: 0; top: 21%; color: var(--blue); }
.annotation-two { right: -1%; top: 11%; color: var(--red); }
.annotation-three { left: -2%; bottom: 8%; color: var(--blue); text-align: right; }
.hero-about { position: absolute; right: 0; bottom: 2%; width: 29%; font-size: 18px; line-height: 1.35; }
.hero-about p { margin: 0 0 65px; }
.hero-about p::after { content: ""; display: block; width: 150px; height: 10px; margin-top: 5px; border-top: 2px solid var(--blue); border-radius: 50%; }
.hero-about a { font-size: 16px; }
.scroll-cue { position: absolute; z-index: 8; left: 50%; bottom: 8px; display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 10px; text-transform: uppercase; text-decoration: none; transform: translateX(-50%); }
.scroll-cue b { font-size: 18px; font-weight: 400; animation: bounce 1.7s infinite; }
@keyframes bounce { 50% { transform: translateY(5px); } }

.work { position: relative; padding: 16vh 4vw 25vh; }
.work-header { display: flex; justify-content: space-between; align-items: end; }
.work-header > div { display: flex; align-items: end; gap: 18px; }
.work h2 { margin: 0; font-family: "Barlow Condensed", Impact, sans-serif; font-size: clamp(105px, 13.5vw, 218px); font-weight: 800; font-style: italic; line-height: .72; letter-spacing: -.045em; text-transform: uppercase; }
.work-header span { color: var(--red); font-family: "Barlow Condensed", sans-serif; font-size: clamp(30px, 3.1vw, 50px); font-weight: 800; line-height: 1; }
.work-header > p { max-width: 300px; margin: 0 4vw 10px 0; font-size: 18px; line-height: 1.3; }
.work-header > p::after { content: ""; display: block; width: 150px; margin-top: 8px; border-top: 2px solid var(--blue); border-radius: 50%; }
.filter-row { display: flex; gap: clamp(35px, 7vw, 115px); margin: 38px 0 0; padding: 0 6px 19px; border-bottom: 1px dashed var(--line); }
.filter-row button { font-weight: 600; }
.filter-row button span { margin-left: 6px; font-size: 11px; }
.filter-row button i { display: inline-block; width: 11px; height: 11px; margin-right: 12px; border-radius: 50%; background: var(--red); }

.project-stack { position: relative; min-height: 460vh; margin-top: 22px; }
.project-stack.is-filtered {
  display: grid;
  gap: clamp(18px, 2.2vw, 34px);
  align-items: start;
  min-height: 0;
  padding: 48px 0 12vh;
}
.project-stack.is-filtered[data-active-filter="identity"] { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.project-stack.is-filtered[data-active-filter="campaign"],
.project-stack.is-filtered[data-active-filter="video"] { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.project-stack.is-filtered[data-active-filter="motion"] { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.project-stack.is-filtered .project {
  position: relative;
  top: auto;
  width: 100%;
  margin: 0;
  transform: none !important;
  filter: drop-shadow(0 12px 18px rgba(31,20,10,.12));
}
.project-stack.is-filtered .project img,
.project-stack.is-filtered .project video { max-height: 48vh; }
.project-stack.is-filtered .project footer { grid-template-columns: 1fr auto; gap: 10px; }
.project-stack.is-filtered .project footer span:nth-child(2) { display: none; }
.project { position: sticky; top: 14vh; width: 62%; margin-bottom: 40vh; filter: drop-shadow(0 18px 24px rgba(31,20,10,.14)); transition: opacity .35s, filter .35s; }
.project[hidden] { display: none; }
.project:nth-child(2) { top: 17vh; margin-left: auto; width: 39%; }
.project:nth-child(3) { top: 20vh; width: 59%; margin-left: 7%; }
.project:nth-child(4) { top: 16vh; width: 37%; margin-left: auto; margin-right: 8%; }
.project:nth-child(5) { top: 19vh; width: 38%; margin-left: 14%; }
.project:nth-child(6) { top: 15vh; width: 48%; margin-left: auto; margin-right: 3%; }
.project:nth-child(7) { top: 18vh; width: 42%; margin-left: 6%; }
.project:nth-child(8) { top: 21vh; width: 55%; margin-left: auto; }
.project:nth-child(9) { top: 15vh; width: 38%; margin-left: 10%; }
.project:nth-child(10) { top: 18vh; width: 56%; margin-left: auto; margin-right: 5%; }
.project:nth-child(11) { top: 21vh; width: 40%; margin-left: 5%; }
.project:nth-child(12) { top: 16vh; width: 54%; margin-left: auto; margin-right: 6%; }
.project button { position: relative; display: block; width: fit-content; max-width: 100%; height: auto; margin-inline: auto; padding: 0; border: 0; overflow: hidden; background: transparent; }
.project img, .project video { display: block; width: auto; height: auto; max-width: 100%; max-height: min(72vh, 760px); object-fit: contain; transition: transform .8s cubic-bezier(.2,.7,.2,1); }
.project video { background: var(--ink); pointer-events: none; }
.project button:hover img, .project button:hover video { transform: scale(1.035); }
.project-arrow { position: absolute; right: 18px; top: 18px; display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid currentColor; border-radius: 50%; color: white; font-size: 24px; transition: color .25s, background .25s; }
.project button:hover .project-arrow { color: var(--ink); background: white; }
.project footer { display: grid; grid-template-columns: 1.2fr 1fr auto; gap: 20px; padding: 13px 5px 0; font-size: 12px; text-transform: uppercase; }
.project footer b { font-size: 15px; }
.project-pink { transform: rotate(-.3deg); }
.project-dark { transform: rotate(.5deg); }
.project-blue { transform: rotate(-.6deg); }
.project-orange { transform: rotate(1deg); }
.project-cobalt { transform: rotate(-1deg); }

.proof {
  display: grid;
  grid-template-columns: .7fr 1.15fr 1fr;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  background: var(--red);
}
.proof p {
  min-height: 250px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 0;
  padding: 24px 2.5vw;
  border-right: 1px solid var(--ink);
  text-transform: uppercase;
}
.proof p:last-child { border-right: 0; }
.proof strong {
  font-family: "Barlow Condensed", Impact, sans-serif;
  font-size: clamp(76px, 10vw, 158px);
  font-weight: 800;
  font-style: italic;
  line-height: .7;
  letter-spacing: -.045em;
}
.proof span { font-size: 13px; line-height: 1.3; }

.services { position: relative; min-height: 100svh; padding: 13vh 4vw; color: var(--paper); background: var(--ink); }
.section-index { display: flex; justify-content: space-between; margin: 0; padding-bottom: 18px; border-bottom: 1px dashed rgba(244,230,200,.5); font-size: 11px; text-transform: uppercase; }
.services h2 { margin: 10vh 0 13vh; font-family: "Barlow Condensed", Impact, sans-serif; font-size: clamp(88px, 12vw, 190px); font-weight: 800; font-style: italic; line-height: .72; letter-spacing: -.04em; text-transform: uppercase; }
.services h2 em { color: var(--red); font-style: inherit; }
.services ol { margin: 0 0 0 34%; padding: 0; list-style: none; }
.services li { display: grid; grid-template-columns: 50px 1fr minmax(180px, 30%); align-items: start; gap: 18px; padding: 18px 0; border-top: 1px solid rgba(244,230,200,.35); }
.services li span { padding-top: 5px; font-size: 11px; }
.services li b { font-family: "Barlow Condensed", sans-serif; font-size: clamp(30px, 4vw, 60px); line-height: .9; text-transform: uppercase; }
.services li i { padding-top: 0; font-size: 13px; line-height: 1.35; font-style: normal; }

.music { position: relative; min-height: 120svh; padding: 14vh 4vw; overflow: hidden; }
.music-heading { position: relative; z-index: 3; }
.music-heading > p { margin: 0 0 8vh; font-size: 11px; text-transform: uppercase; }
.music h2 { margin: 0; font-family: "Barlow Condensed", Impact, sans-serif; font-size: clamp(95px, 13vw, 205px); font-weight: 800; font-style: italic; line-height: .73; letter-spacing: -.045em; text-transform: uppercase; }
.music h2 em { color: var(--blue); font-style: inherit; }
.music-actions { position: relative; z-index: 4; width: fit-content; margin-top: 8vh; }
.spotify-cta { display: inline-flex; align-items: center; gap: 14px; padding: 17px 22px; color: var(--paper); background: var(--ink); font-size: 13px; font-weight: 700; letter-spacing: .04em; text-decoration: none; text-transform: uppercase; transition: transform .25s, background .25s; }
.spotify-cta:hover { transform: translateY(-3px); background: #263129; }
.spotify-cta i { width: 13px; height: 13px; border-radius: 50%; background: #1ed760; box-shadow: 0 0 0 4px rgba(30,215,96,.16); }
.music-socials { display: flex; gap: 24px; margin-top: 20px; font-size: 11px; text-transform: uppercase; }
.music-socials a { text-decoration-thickness: 1px; }
.record-stack { position: absolute; z-index: 2; right: 7vw; top: 19vh; width: min(36vw, 560px); height: 75vh; }
.record-stack img { position: absolute; width: 58%; height: auto; object-fit: contain; box-shadow: 0 24px 48px rgba(38,25,12,.2); }
.record-stack img:nth-child(1) { left: 0; top: 8%; transform: rotate(-8deg); }
.record-stack img:nth-child(2) { right: 0; top: 19%; transform: rotate(9deg); }
.record-stack img:nth-child(3) { left: 20%; bottom: 0; transform: rotate(-1deg); }
.music-signoff { position: absolute; right: 5vw; bottom: 8vh; margin: 0; font-family: Caveat, cursive; color: var(--red); font-size: 28px; line-height: 1.1; transform: rotate(-3deg); }

.contact { min-height: 100svh; display: flex; flex-direction: column; justify-content: space-between; padding: 5vh 4vw 28px; color: var(--paper); background: var(--red); }
.contact > p { margin: 0; font-size: 13px; text-transform: uppercase; }
.contact h2 { margin: auto 0 2vh; font-family: "Barlow Condensed", Impact, sans-serif; font-size: clamp(120px, 18vw, 285px); font-weight: 800; font-style: italic; line-height: .68; letter-spacing: -.05em; text-transform: uppercase; }
.contact h2 em { color: var(--ink); font-style: inherit; }
.contact > a { align-self: flex-end; margin-bottom: 8vh; color: var(--ink); font-size: clamp(24px, 3vw, 48px); }
.contact footer { display: flex; justify-content: space-between; padding-top: 18px; border-top: 1px dashed rgba(16,24,27,.55); color: var(--ink); font-size: 11px; line-height: 1.4; text-transform: uppercase; }
.contact footer span:last-child { text-align: right; }
.footer-socials { display: flex; gap: 26px; }
.footer-socials a { color: inherit; }

.lightbox { width: 100%; max-width: none; height: 100%; max-height: none; margin: 0; padding: 0; border: 0; color: var(--paper); background: rgba(12,18,20,.97); }
.lightbox::backdrop { background: transparent; }
.lightbox-close { position: fixed; z-index: 2; top: 25px; right: 30px; border: 0; background: transparent; color: inherit; font-size: 12px; text-transform: uppercase; }
.lightbox figure { height: 100%; display: grid; grid-template-rows: 1fr auto; margin: 0; padding: 6vh 5vw 4vh; }
.lightbox figure > img, .lightbox figure > video { align-self: center; justify-self: center; max-width: 75vw; max-height: 78vh; box-shadow: 0 25px 70px rgba(0,0,0,.4); }
.lightbox figure > video { width: auto; height: auto; background: #000; }
.lightbox [hidden] { display: none; }
.lightbox figcaption { display: grid; grid-template-columns: 60px 1fr auto; gap: 25px; align-items: end; padding-top: 16px; border-top: 1px solid rgba(244,230,200,.45); }
.lightbox h2 { margin: 0; font-family: "Barlow Condensed", sans-serif; font-size: 32px; text-transform: uppercase; }
.lightbox p { margin: 3px 0 0; font-size: 11px; text-transform: uppercase; }

@media (max-width: 900px) {
  .site-header { padding: 20px 18px; }
  .wordmark { font-size: 42px; }
  .menu-toggle { display: block; position: relative; z-index: 3; }
  .site-nav { position: fixed; inset: 0; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; gap: 10px; padding: 80px 24px; color: var(--paper); background: var(--red); transform: translateY(-102%); transition: transform .55s cubic-bezier(.76,0,.24,1); }
  .site-nav.is-open { transform: translateY(0); }
  .site-nav a { font-family: "Barlow Condensed", sans-serif; font-size: 17vw; font-weight: 800; line-height: .85; }
  .site-nav .nav-cta { margin-top: 35px; color: var(--ink); font-family: inherit; font-size: 16px; }
  .hero { min-height: 1320px; height: auto; padding: 125px 18px 80px; }
  .hero-rule { display: none; }
  .hero-copy { width: 100%; padding: 0; }
  .hero h1 { font-size: 27vw; }
  .hero-services { max-width: 350px; font-size: 18px; }
  .hero-meta { margin-top: 25px; }
  .hero-filters { gap: 35px; }
  .scribble-cta { margin-top: 38px; }
  .poster-stage { inset: 610px 18px 30px; }
  .poster-one { left: 3%; top: 3%; width: 46%; height: auto; }
  .poster-two { right: 0; top: 16%; width: 43%; height: auto; }
  .poster-three { left: 7%; bottom: 2%; width: 43%; height: auto; }
  .annotation-one { display: none; }
  .annotation-two { right: 2%; top: 5%; }
  .annotation-three { left: 56%; bottom: 22%; }
  .hero-about { right: 0; bottom: 0; width: 39%; font-size: 15px; }
  .hero-about p { margin-bottom: 30px; }
  .hero-about a { font-size: 13px; }
  .scroll-cue { display: none; }
  .work { padding: 100px 18px 140px; }
  .work-header { display: block; }
  .work-header > div { display: block; }
  .work h2 { font-size: 24vw; }
  .work-header span { font-size: 30px; }
  .work-header > p { margin: 35px 0 0; }
  .filter-row { gap: 20px; overflow-x: auto; padding: 30px 0 15px; }
  .filter-row button { flex: 0 0 auto; }
  .project-stack { min-height: 3600px; }
  .project-stack.is-filtered,
  .project-stack.is-filtered[data-active-filter] { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 34px 12px; min-height: 0; padding: 35px 0 80px; }
  .project, .project:nth-child(n) { top: 11vh; width: 93%; margin: 0 auto 52vh; }
  .project:nth-child(even) { margin-left: 7%; }
  .project-stack.is-filtered .project,
  .project-stack.is-filtered .project:nth-child(n) { top: auto; width: 100%; margin: 0; }
  .project button { height: auto; min-height: 0; }
  .project img, .project video { max-height: 68vh; }
  .project-stack.is-filtered .project img,
  .project-stack.is-filtered .project video { max-height: 44vh; }
  .project footer { grid-template-columns: 1fr auto; }
  .project footer span:nth-child(2) { display: none; }
  .proof { grid-template-columns: 1fr; }
  .proof p { min-height: 210px; padding: 24px 18px; border-right: 0; border-bottom: 1px solid var(--ink); }
  .proof p:last-child { border-bottom: 0; }
  .proof strong { font-size: 31vw; }
  .services { padding: 100px 18px; }
  .services h2 { font-size: 22vw; }
  .services ol { margin-left: 0; }
  .services li { grid-template-columns: 30px 1fr; }
  .services li i { grid-column: 2; }
  .music { min-height: 1200px; padding: 100px 18px; }
  .music h2 { font-size: 23vw; }
  .music-actions { margin-top: 55px; }
  .spotify-cta { padding: 15px 18px; }
  .music-socials { flex-direction: column; gap: 10px; }
  .record-stack { right: 5vw; top: 590px; width: 88vw; height: 530px; }
  .music-signoff { right: 18px; bottom: 35px; font-size: 22px; }
  .contact { padding: 30px 18px 20px; }
  .contact h2 { font-size: 24vw; }
  .contact > a { align-self: flex-start; font-size: 24px; }
  .contact footer { gap: 18px; flex-wrap: wrap; }
  .footer-socials { order: 3; width: 100%; gap: 18px; flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
