@font-face {
  font-family: "Eczar";
  src: url("../fonts/eczar/Eczar-VariableFont_wght.ttf") format("truetype");
  font-weight: 400 800;
  font-style: normal;
  font-display: swap;
}

:root {
  --font-body: "p22-underground", Arial, sans-serif;
  --font-display: "Eczar", Georgia, serif;
  --bg: #050506;
  --paper: #f3efe6;
  --ink: #f3efe6;
  --black: #050506;
  --muted: rgba(243, 239, 230, 0.63);
  --line: rgba(243, 239, 230, 0.16);
  --line-strong: rgba(243, 239, 230, 0.36);
  --accent: #ff3b2f;
  --blue: #2d63ff;
  --yellow: #f7d449;
  --card-radius: 0px;
  --gap: 0px;
  --max-width: 1560px;
  --nav-height: 68px;
  --scroll-progress: 0;
  --section-space: clamp(40px, 6vw, 84px);
  --signal-overlay-width: min(68vw, 840px);
  --signal-overlay-rise: min(8.5vw, 105px);
  --ease: cubic-bezier(.2,.8,.2,1);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  padding-top: var(--nav-height);
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg);
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-body);
}

.shell {
  width: min(calc(100% - clamp(28px, 5vw, 84px)), var(--max-width));
  margin: 0 auto;
}

.has-reveal-js [data-reveal] {
  --reveal-y: 34px;
  --reveal-scale: 1;
  opacity: 0;
  filter: brightness(.72) saturate(.85);
  transform: translate3d(0, var(--reveal-y), 0) scale(var(--reveal-scale));
  transition:
    opacity .82s var(--ease) var(--reveal-delay, 0ms),
    filter .82s var(--ease) var(--reveal-delay, 0ms),
    transform .82s var(--ease) var(--reveal-delay, 0ms);
  will-change: opacity, filter, transform;
}

.has-reveal-js [data-reveal="copy"] {
  --reveal-y: 26px;
  filter: none;
}

.has-reveal-js [data-reveal="image"],
.has-reveal-js [data-reveal="video"] {
  --reveal-y: 42px;
  --reveal-scale: .985;
}

.has-reveal-js [data-reveal="wide"] {
  --reveal-y: 20px;
}

.has-reveal-js [data-reveal].is-revealed {
  opacity: 1;
  filter: brightness(1) saturate(1);
  transform: translate3d(0, 0, 0) scale(1);
}

.has-reveal-js .project-card[data-reveal] {
  opacity: var(--o, 1);
  filter: none;
  transform: translate3d(var(--x, 0px), var(--y, 0px), 0);
  transition: none;
}

.has-reveal-js .project-card[data-reveal] .project-card-inner {
  filter: brightness(.56) saturate(.75);
  transition:
    opacity .28s var(--ease),
    filter .62s var(--ease) var(--reveal-delay, 0ms);
}

.has-reveal-js .project-card[data-reveal].is-revealed .project-card-inner {
  filter: brightness(1) saturate(1);
}

.site-nav {
  position: fixed;
  inset: 0 0 auto;
  z-index: 100;
  min-height: var(--nav-height);
  border-bottom: 1px solid var(--line);
  background: rgba(5, 5, 6, .86);
  backdrop-filter: blur(18px);
}

.site-nav::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 2px;
  background:
    linear-gradient(90deg, var(--accent), rgba(247, 212, 73, .86), var(--accent));
  box-shadow:
    0 0 14px rgba(255, 59, 47, .55),
    0 0 28px rgba(255, 59, 47, .22);
  transform: scaleX(var(--scroll-progress));
  transform-origin: left center;
}

.site-nav-inner {
  width: min(calc(100% - clamp(28px, 5vw, 84px)), var(--max-width));
  min-height: var(--nav-height);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(14px, 2vw, 34px);
}

.site-nav a,
.site-nav summary {
  color: var(--ink);
  font: 700 12px/1 var(--font-body);
  letter-spacing: .14em;
  text-decoration: none;
  text-transform: uppercase;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-nav summary:hover,
.site-nav summary:focus-visible {
  color: var(--accent);
}

.site-nav-dropdown {
  position: relative;
}

.site-nav-dropdown summary {
  list-style: none;
  cursor: pointer;
}

.site-nav-dropdown summary::-webkit-details-marker {
  display: none;
}

.site-nav-dropdown summary::after {
  content: "";
  display: inline-block;
  width: .45em;
  height: .45em;
  margin-left: .65em;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: translateY(-.2em) rotate(45deg);
}

.site-nav-dropdown[open] summary::after {
  transform: translateY(.05em) rotate(225deg);
}

.site-nav-menu {
  position: absolute;
  top: calc(100% + 18px);
  right: 0;
  min-width: 220px;
  margin: 0;
  padding: 10px;
  list-style: none;
  border: 1px solid var(--line);
  background: rgba(5, 5, 6, .96);
  box-shadow: 0 18px 42px rgba(0, 0, 0, .42);
}

.site-nav-menu a {
  display: block;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(243, 239, 230, .08);
}

.site-nav-menu li:last-child a {
  border-bottom: 0;
}

header {
  padding: clamp(24px, 4vw, 48px) 0 0;
  position: relative;
}

header::before {
  content: none;
}

header::after {
  content: none;
}

.hero-grid {
  position: relative;
  z-index: 1;
}

.intro-card {
  position: relative;
}

.hero-video-placeholder {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: linear-gradient(135deg, #171922 0%, #0b0d12 42%, #1d2230 100%);
  isolation: isolate;
}

.hero-video {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-video-placeholder::after,
.script-player-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero-video-placeholder::after,
.script-player-frame::after {
  z-index: 3;
  border: 1px solid rgba(243, 239, 230, .16);
  box-shadow: none;
}

.wargaming-intro {
  position: relative;
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(320px, 1fr);
  align-items: center;
  gap: clamp(28px, 5vw, 84px);
  padding-top: var(--section-space);
  isolation: isolate;
}

.wargaming-intro::before {
  content: "";
  position: absolute;
  inset: -10% -12% auto -12%;
  z-index: -1;
  height: min(54vw, 720px);
  pointer-events: none;
  background:
    radial-gradient(circle at 17% 36%, rgba(255, 59, 47, .22), transparent 28rem),
    radial-gradient(circle at 78% 22%, rgba(45, 99, 255, .14), transparent 24rem),
    linear-gradient(115deg, transparent 18%, rgba(243, 239, 230, .055), transparent 48%);
  opacity: .9;
}

.wargaming-intro-image {
  display: block;
  width: 100%;
  background: #10131a;
  border-left: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, .46),
    0 0 60px rgba(255, 59, 47, .12);
  transform-origin: center;
  animation: cinematicImageDrift 18s var(--ease) infinite alternate;
}

.wargaming-intro-copy {
  display: grid;
  gap: 14px;
}

.wargaming-intro-copy h1 {
  margin: 0;
  color: var(--paper);
  font-family: var(--font-display);
  font-size: clamp(44px, 7vw, 116px);
  line-height: .82;
  letter-spacing: -.07em;
  text-transform: uppercase;
}

.wargaming-intro-copy p {
  margin: 0;
  max-width: 58ch;
  color: var(--muted);
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.55;
}

.category-intro {
  position: relative;
  min-height: clamp(360px, 48vw, 720px);
  display: grid;
  align-items: start;
  gap: clamp(28px, 5vw, 84px);
  padding-top: var(--section-space);
  padding-bottom: clamp(24px, 5vw, 72px);
  isolation: isolate;
}

.category-intro::before {
  content: "";
  position: absolute;
  inset: 5% -12% 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 72% 20%, rgba(45, 99, 255, .18), transparent 20rem),
    radial-gradient(circle at 18% 68%, rgba(255, 59, 47, .2), transparent 24rem),
    linear-gradient(115deg, transparent 28%, rgba(243, 239, 230, .055), transparent 52%);
}

.category-intro-copy {
  display: grid;
  gap: 14px;
  max-width: 920px;
}

.category-intro-copy h1 {
  margin: 0;
  color: var(--paper);
  font-family: var(--font-display);
  font-size: clamp(70px, 14vw, 220px);
  line-height: .72;
  letter-spacing: -.08em;
  text-transform: uppercase;
}

.category-intro-copy p {
  max-width: 62ch;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.25vw, 20px);
  line-height: 1.55;
}

.category-intro-media {
  --glitch-hero-height: clamp(220px, 28vw, 380px);
  --glitch-hero-gap: clamp(12px, 2vw, 28px);
  position: relative;
  justify-self: stretch;
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--glitch-hero-gap);
}

.category-intro-image {
  display: block;
  width: 100%;
  min-width: 0;
  background: #10131a;
  border-left: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, .46),
    0 0 60px rgba(255, 59, 47, .12);
}

.glitch-art-hero-image {
  flex: 0 1 auto;
  height: var(--glitch-hero-height) !important;
  width: auto !important;
  max-width: none;
  object-fit: contain;
  image-rendering: auto;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.glitch-art-hero-secondary {
  filter: saturate(1.25) contrast(1.08);
}

.glitch-hero-video-frame {
  width: 100%;
  min-width: 0;
  overflow: hidden;
  background: #10131a;
}

.glitch-hero-video-frame[data-optional-frame] {
  display: none;
}

.glitch-hero-video-frame.has-media {
  display: block;
}

.glitch-hero-video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.glitch-footer-video-section {
  margin-top: var(--section-space);
  padding-bottom: var(--section-space);
  padding-top: 0;
}

.page-glitch-art .category-intro.glitch-art-intro {
  min-height: 0;
  padding-top: var(--section-space);
  padding-bottom: 0;
}

.page-glitch-art main.portfolio-wrap {
  margin-top: var(--section-space);
  margin-bottom: 0;
}

.glitch-hero-wide-image {
  display: block;
  width: 100%;
  min-width: 0;
  background: #10131a;
}

.glitch-video-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(12px, 2vw, 28px);
}

.glitch-video-grid-item {
  min-width: 0;
  overflow: hidden;
  background: #10131a;
}

.glitch-video-grid-item[data-optional-frame] {
  display: none;
}

.glitch-video-grid-item.has-media {
  display: block;
}

.glitch-video-grid video {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.hero-lower-panel {
  position: relative;
  z-index: 0;
  min-height: 280px;
  display: grid;
  grid-template-columns: minmax(280px, .85fr) minmax(0, 1.35fr);
  color: var(--ink);
  background:
    linear-gradient(90deg, rgba(255, 59, 47, .16), transparent 18rem),
    var(--black);
  overflow: hidden;
  isolation: isolate;
}

.hero-lower-panel::before {
  content: "";
  position: absolute;
  inset: -45%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 46%, rgba(255, 59, 47, .34), transparent 18rem),
    radial-gradient(circle at 44% 16%, rgba(45, 99, 255, .18), transparent 20rem),
    linear-gradient(115deg, transparent 35%, rgba(243, 239, 230, .08), transparent 58%);
  opacity: .72;
  transform: translate3d(-2%, -1%, 0) rotate(0deg);
  animation: shaderDrift 16s var(--ease) infinite alternate;
}

.hero-panel-lede {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  margin: 0;
  padding: clamp(36px, 4.5vw, 72px);
  color: var(--ink);
  border-left: clamp(5px, .6vw, 9px) solid var(--accent);
}

.hero-panel-lede strong {
  display: block;
  max-width: 680px;
  margin-bottom: .45em;
  color: var(--ink);
  font-family: var(--font-body);
  font-size: clamp(22px, 2.35vw, 34px);
  font-weight: 700;
  line-height: 1.18;
}

.hero-panel-lede span {
  display: block;
  max-width: 560px;
  font-size: clamp(17px, 1.8vw, 22px);
  line-height: 1.35;
}

.hero-panel-content {
  position: relative;
  z-index: 1;
  min-width: 0;
  padding: 0;
  display: grid;
  align-items: stretch;
  justify-items: end;
}

.hero-panel-copy {
  position: relative;
  height: 100%;
  width: 100%;
  max-width: none;
  padding: clamp(28px, 3.5vw, 54px);
  display: grid;
  align-content: center;
  background: var(--paper);
  color: var(--black);
  overflow: hidden;
  isolation: isolate;
}

.hero-panel-copy::before {
  content: "";
  position: absolute;
  inset: -30%;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 16% 12%, rgba(255, 59, 47, .10), transparent 16rem),
    linear-gradient(120deg, transparent 38%, rgba(255, 255, 255, .42), transparent 54%);
  opacity: .55;
  transform: translate3d(-5%, 0, 0);
  animation: paperSheen 18s var(--ease) infinite alternate;
}

.hero-panel-copy h2 {
  margin: 0 0 12px;
  color: var(--black);
  font-size: clamp(22px, 2.4vw, 36px);
  line-height: 1;
}

.hero-panel-copy p {
  margin: 0;
  color: rgba(5, 5, 6, .74);
  font-size: clamp(14px, 1.15vw, 17px);
  font-weight: 400;
  line-height: 1.55;
}

.toolbar {
  position: relative;
  padding: var(--section-space) 0 0;
  margin-bottom: var(--section-space);
}

.toolbar::before {
  content: "";
  display: block;
  height: 2px;
  background:
    linear-gradient(90deg, transparent, rgba(255, 59, 47, .95) 16%, rgba(243, 239, 230, .58) 50%, rgba(255, 59, 47, .95) 84%, transparent),
    linear-gradient(90deg, transparent, var(--accent), transparent);
  background-size: 200% 100%, 100% 100%;
  box-shadow:
    0 0 10px rgba(255, 59, 47, .28),
    0 0 28px rgba(255, 59, 47, .12);
  opacity: .88;
  animation: ruleGlow 8s var(--ease) infinite alternate;
}

.portfolio-wrap {
  position: relative;
  margin-bottom: var(--section-space);
  --grid-accent-image: none;
}

.case-study {
  position: relative;
  padding-top: calc(var(--signal-overlay-rise) + clamp(174px, 18vw, 308px));
  margin-bottom: clamp(18px, 3vw, 44px);
}

.case-study::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background:
    linear-gradient(90deg, transparent, rgba(255, 59, 47, .95) 16%, rgba(243, 239, 230, .58) 50%, rgba(255, 59, 47, .95) 84%, transparent),
    linear-gradient(90deg, transparent, var(--accent), transparent);
  background-size: 200% 100%, 100% 100%;
  box-shadow:
    0 0 10px rgba(255, 59, 47, .28),
    0 0 28px rgba(255, 59, 47, .12);
  opacity: .88;
  animation: ruleGlow 8s var(--ease) infinite alternate;
}

.case-study-subhead {
  position: absolute;
  top: clamp(28px, 3vw, 52px);
  left: 0;
  z-index: 4;
  width: 100%;
  margin: 0;
  color: var(--paper);
  font-family: var(--font-display);
  font-size: clamp(18px, 2.5vw, 45px);
  font-weight: 700;
  letter-spacing: -.06em;
  line-height: .9;
  text-align: center;
}

.case-study-marquee {
  position: absolute;
  top: clamp(88px, 8.5vw, 154px);
  left: 0;
  right: 0;
  z-index: 4;
  overflow: hidden;
  color: rgba(243, 239, 230, .12);
  font-family: var(--font-body);
  font-size: clamp(48px, 9vw, 154px);
  font-weight: 950;
  line-height: .95;
  text-transform: uppercase;
  white-space: nowrap;
  pointer-events: none;
}

.case-study-marquee-track {
  display: inline-flex;
  width: max-content;
  animation: marqueeScroll 50s linear infinite;
}

.case-study-marquee span {
  flex: 0 0 auto;
}

.marquee-separator {
  color: var(--accent);
  font: inherit;
}

.video-accent {
  isolation: isolate;
  overflow: visible;
}

.video-accent::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  z-index: 1;
  height: 38%;
  pointer-events: none;
  background: linear-gradient(180deg, transparent, rgba(5, 5, 6, .68));
}

.video-accent-title {
  position: absolute;
  left: clamp(18px, 4vw, 68px);
  bottom: clamp(18px, 4vw, 64px);
  z-index: 4;
  display: grid;
  color: var(--paper);
  font-family: var(--font-display);
  font-size: clamp(48px, 9vw, 154px);
  font-weight: 800;
  letter-spacing: -.08em;
  line-height: .72;
  text-transform: uppercase;
  text-shadow: 0 18px 42px rgba(0, 0, 0, .52);
  mix-blend-mode: screen;
}

.video-accent-title span:last-child {
  color: transparent;
  -webkit-text-stroke: 1px var(--paper);
  text-shadow: none;
  transform: translateX(clamp(24px, 6vw, 108px));
}

.signal-kicker {
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .16em;
  line-height: 1;
  text-transform: uppercase;
}

.signal-video-frame {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 4;
  overflow: hidden;
  width: var(--signal-overlay-width);
  min-width: 440px;
  transform: translateY(-50%);
  background: #10131a;
  isolation: isolate;
  aspect-ratio: 4 / 1;
}

.signal-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: var(--black);
}

.scripts-showcase {
  margin-bottom: var(--section-space);
}

.winterfest-showcase {
  margin-bottom: var(--section-space);
}

.winterfest-showcase::after {
  content: "";
  display: block;
  height: 2px;
  margin-top: var(--section-space);
  background:
    linear-gradient(90deg, transparent, rgba(255, 59, 47, .95) 16%, rgba(243, 239, 230, .58) 50%, rgba(255, 59, 47, .95) 84%, transparent),
    linear-gradient(90deg, transparent, var(--accent), transparent);
  background-size: 200% 100%, 100% 100%;
  box-shadow:
    0 0 10px rgba(255, 59, 47, .28),
    0 0 28px rgba(255, 59, 47, .12);
  opacity: .88;
  animation: ruleGlow 8s var(--ease) infinite alternate;
}

.portfolio-grid-header {
  display: grid;
  gap: 10px;
  max-width: 760px;
  margin-bottom: clamp(14px, 2vw, 28px);
}

.scripts-showcase-header {
  display: grid;
  grid-template-columns: minmax(380px, .82fr) minmax(420px, 1.18fr);
  align-items: end;
  gap: clamp(28px, 5vw, 84px);
  margin-bottom: clamp(14px, 2vw, 28px);
}

.scripts-showcase-copy {
  display: grid;
  gap: 10px;
  max-width: 760px;
}

.portfolio-grid-header h2,
.scripts-showcase-header h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(42px, 7vw, 112px);
  line-height: .82;
  letter-spacing: -.07em;
  text-transform: uppercase;
}

.portfolio-grid-header p,
.scripts-showcase-header p {
  margin: 0;
  max-width: 52ch;
  color: var(--muted);
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.55;
}

.scripts-showcase-image {
  display: block;
  width: 100%;
  min-width: 0;
  max-width: 760px;
  justify-self: end;
  background: #10131a;
  border-left: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
}

.script-player-frame {
  position: relative;
  overflow: hidden;
  background: #10131a;
  isolation: isolate;
}

.script-player {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  background: var(--black);
}

.portfolio-grid {
  position: relative;
  z-index: 1;
  isolation: isolate;
  min-height: 240px;
  height: var(--grid-height, 900px);
  padding-bottom: clamp(56px, 8vw, 120px);
  transition: height .18s cubic-bezier(.16, 1, .3, 1);
  perspective: none;
  border-left: 1px solid var(--line-strong);
}

.portfolio-grid:empty {
  min-height: 0;
  padding-bottom: 0;
  border-left: 0;
}

.gallery-empty-note {
  margin: clamp(18px, 3vw, 42px) 0 clamp(56px, 8vw, 120px);
  color: var(--muted);
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.55;
}

.portfolio-grid::before,
.portfolio-grid::after {
  content: "";
  position: absolute;
  inset: clamp(12px, 2vw, 32px) 0 clamp(56px, 8vw, 120px);
  z-index: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity .42s var(--ease);
}

.portfolio-grid::before {
  background-image: var(--grid-accent-image);
  background-position: center;
  background-size: cover;
  filter: blur(56px) saturate(1.1);
  transform: scale(1.08);
}

.portfolio-grid::after {
  background: rgba(0, 0, 0, .82);
}

.portfolio-wrap.has-grid-accent .portfolio-grid::before {
  opacity: .38;
}

.portfolio-wrap.has-grid-accent .portfolio-grid::after {
  opacity: 1;
}

.project-card {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--card-w, 320px);
  height: var(--card-h, 180px);
  transform: translate3d(var(--x, 0px), var(--y, 0px), 0);
  opacity: var(--o, 1);
  pointer-events: auto;
  will-change: transform, width, height, opacity;
  contain: layout style;
  backface-visibility: hidden;
  transform-style: preserve-3d;
  z-index: var(--z, 1);
}

.project-card.is-hidden { pointer-events: none; }

.project-card.is-expanded { z-index: 12; }

.project-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: var(--card-radius);
  overflow: hidden;
  isolation: isolate;
  cursor: pointer;
  background: #161922;
  box-shadow: none;
  transform: translate3d(0, 0, 0) scale(var(--s, 1));
  opacity: var(--inner-o, 1);
  transition: opacity .28s var(--ease), filter .35s var(--ease);
  will-change: opacity;
  backface-visibility: hidden;
  clip-path: none;
  border-right: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
}

.project-card.is-hidden .project-card-inner {
  --s: .96;
  --inner-o: 0;
}

.project-card.is-expanded .project-card-inner {
  outline: clamp(4px, .55vw, 8px) solid var(--accent);
  outline-offset: calc(clamp(4px, .55vw, 8px) * -1);
}

.project-meta {
  position: absolute;
  left: clamp(12px, 1.8vw, 24px);
  right: clamp(12px, 1.8vw, 24px);
  bottom: clamp(12px, 1.8vw, 24px);
  z-index: 3;
  display: grid;
  gap: 6px;
  padding: clamp(12px, 1.8vw, 20px);
  pointer-events: none;
  color: var(--paper);
  background: linear-gradient(90deg, rgba(5, 5, 6, .9) 0%, rgba(5, 5, 6, .78) 42%, rgba(5, 5, 6, 0) 100%);
  border-left: 2px solid var(--accent);
  opacity: 0;
  transform: translate3d(0, 12px, 0);
  transition:
    opacity .42s var(--ease),
    transform .42s var(--ease);
}

.project-meta-type {
  color: var(--accent);
  font-size: clamp(10px, .9vw, 12px);
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.project-meta-title {
  font-family: var(--font-display);
  font-size: clamp(24px, 4vw, 62px);
  font-weight: 800;
  letter-spacing: -.06em;
  line-height: .85;
  text-transform: uppercase;
}

.project-card.is-expanded .project-meta {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.project-card:hover .project-card-inner {
  transform: translate3d(0, 0, 0);
  box-shadow: none;
  clip-path: none;
}

.project-visual {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  background: linear-gradient(135deg, #2f3545, #11131a);
  transform: translate3d(0,0,0) scale(1.02);
  transition: transform .72s var(--ease);
  will-change: transform;
  backface-visibility: hidden;
}

.project-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  transform: translate3d(0,0,0);
}

.project-card:hover .project-visual,
.project-card.is-expanded .project-visual {
  transform: translate3d(0,0,0) scale(1.045);
}

.contact-page {
  position: relative;
  width: 100%;
  max-width: none;
  min-height: 100vh;
  display: grid;
  align-items: start;
  padding: clamp(24px, 4vw, 52px) clamp(28px, 5vw, 84px) var(--section-space);
  overflow: hidden;
  isolation: isolate;
}

.contact-map-bg {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background: #050506;
}

.contact-map-bg iframe {
  position: absolute;
  inset: -8% -8% -8% -2%;
  width: 116%;
  height: 116%;
  border: 0;
  filter: grayscale(1) invert(.92) contrast(1.18) saturate(.28);
  opacity: .58;
  transform: translate3d(8%, -2%, 0) scale(1.08);
  transform-origin: 62% 42%;
}

.contact-page::before,
.contact-page::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.contact-page::before {
  z-index: -1;
  background: linear-gradient(90deg, rgba(5, 5, 6, .96), rgba(5, 5, 6, .62) 32%, rgba(5, 5, 6, .86) 100%);
}

.contact-page::after {
  z-index: 0;
  background:
    linear-gradient(rgba(243, 239, 230, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(243, 239, 230, .035) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at 58% 42%, black 0 34%, transparent 72%);
  opacity: .56;
}

.contact-card {
  position: relative;
  z-index: 1;
  width: min(100%, 820px);
  margin: 0 auto 0 clamp(0px, 7vw, 120px);
  padding: clamp(32px, 6vw, 92px);
  background:
    linear-gradient(90deg, rgba(5, 5, 6, .94), rgba(5, 5, 6, .82), rgba(5, 5, 6, .34)),
    radial-gradient(circle at 0% 0%, rgba(255, 59, 47, .2), transparent 20rem);
  border-top: 1px solid var(--accent);
  border-left: 1px solid var(--line-strong);
  overflow: hidden;
  isolation: isolate;
}

.contact-copy {
  position: relative;
  z-index: 2;
  align-self: center;
}

.contact-copy .signal-kicker {
  display: inline-block;
  margin-bottom: clamp(10px, 1.6vw, 22px);
}

.contact-card h1 {
  margin: 0 0 clamp(28px, 4vw, 56px);
  font-size: clamp(58px, 11vw, 168px);
  line-height: .78;
  letter-spacing: -.08em;
  text-transform: uppercase;
}

.contact-list {
  display: grid;
  gap: 12px;
  margin: 0 0 clamp(28px, 4vw, 56px);
  padding: 0;
  list-style: none;
}

.contact-list a,
.home-link {
  color: var(--paper);
  text-decoration: none;
}

.contact-list a {
  font-size: clamp(22px, 3vw, 48px);
  font-weight: 800;
  letter-spacing: -.04em;
}

.contact-list a:hover,
.home-link:hover {
  color: var(--accent);
}

.contact-note {
  max-width: 760px;
  margin: 0 0 clamp(28px, 4vw, 56px);
  color: var(--muted);
  font-size: clamp(18px, 2vw, 30px);
  line-height: 1.35;
}

.home-link {
  display: inline-block;
  color: var(--accent);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

@keyframes shaderDrift {
  0% {
    transform: translate3d(-2%, -1%, 0) rotate(0deg) scale(1);
  }
  100% {
    transform: translate3d(3%, 2%, 0) rotate(4deg) scale(1.04);
  }
}

@keyframes cinematicImageDrift {
  0% {
    scale: 1;
  }
  100% {
    scale: 1.025;
  }
}

@keyframes paperSheen {
  0% {
    transform: translate3d(-5%, 0, 0);
  }
  100% {
    transform: translate3d(5%, 0, 0);
  }
}

@keyframes marqueeScroll {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-50%, 0, 0);
  }
}

@keyframes ruleGlow {
  0% {
    background-position: 0% 0, 0 0;
    box-shadow:
      0 0 8px rgba(255, 59, 47, .20),
      0 0 22px rgba(255, 59, 47, .08);
    opacity: .72;
  }
  100% {
    background-position: 100% 0, 0 0;
    box-shadow:
      0 0 14px rgba(255, 59, 47, .34),
      0 0 34px rgba(255, 59, 47, .16);
    opacity: .95;
  }
}

@media (max-width: 1180px) {
  .scripts-showcase-header {
    grid-template-columns: 1fr;
  }
  .scripts-showcase-image {
    max-width: none;
    justify-self: stretch;
  }
}

@media (max-width: 900px) {
  .wargaming-intro {
    grid-template-columns: 1fr;
  }
  .category-intro-media {
    --glitch-hero-height: auto;
    flex-direction: column;
    align-items: stretch;
  }
  .glitch-art-hero-image {
    width: 100% !important;
    height: auto !important;
    max-height: none;
  }
  .glitch-video-grid {
    grid-template-columns: 1fr;
  }
  .contact-card {
    margin: 0 auto;
  }
  .hero-lower-panel {
    min-height: 0;
    grid-template-columns: 1fr;
  }
  .hero-panel-content {
    display: grid;
    justify-items: stretch;
  }
}

@media (max-width: 700px) {
  :root {
    --nav-height: 92px;
  }
  .has-reveal-js [data-reveal],
  .has-reveal-js .project-card[data-reveal] {
    opacity: var(--o, 1);
    filter: none;
    transform: none;
    transition: none;
    will-change: auto;
  }
  .has-reveal-js .project-card[data-reveal] {
    transform: translate3d(var(--x, 0px), var(--y, 0px), 0);
  }
  .has-reveal-js .project-card[data-reveal] .project-card-inner {
    filter: none;
    transition: opacity .28s var(--ease), filter .35s var(--ease);
  }
  .wargaming-intro::before {
    opacity: .28;
  }
  .wargaming-intro-image {
    animation: none;
  }
  .project-meta {
    left: 10px;
    right: 10px;
    bottom: 10px;
    padding: 10px;
  }
  .project-meta-title {
    font-size: clamp(20px, 9vw, 34px);
  }
  .portfolio-wrap.has-grid-accent .portfolio-grid::before,
  .portfolio-wrap.has-grid-accent .portfolio-grid::after {
    opacity: 0;
  }
  .contact-card {
    padding: 28px;
  }
  .contact-page::before {
    background: linear-gradient(90deg, rgba(5, 5, 6, .95), rgba(5, 5, 6, .76));
  }
  .site-nav-inner {
    align-content: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px 18px;
    padding: 12px 0;
  }
  .site-nav-menu {
    right: 50%;
    transform: translateX(50%);
  }
  .hero-panel-lede { padding: 24px; }
  .hero-panel-content { padding: 0; }
  .hero-panel-copy { padding: 24px; }
  .signal-video-frame {
    --signal-overlay-width: 72vw;
    --signal-overlay-rise: 9vw;
    min-width: 240px;
  }
  .project-card-inner { clip-path: none !important; }
}

@media (prefers-reduced-motion: reduce) {
  .wargaming-intro-image {
    animation: none;
  }
  .has-reveal-js [data-reveal],
  .has-reveal-js .project-card[data-reveal] .project-card-inner {
    opacity: var(--o, 1);
    filter: none;
    transform: none;
    transition: none;
    will-change: auto;
  }
  .has-reveal-js .project-card[data-reveal] {
    transform: translate3d(var(--x, 0px), var(--y, 0px), 0);
  }
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}
