:root {
  --black: #060606;
  --ink: #111111;
  --paper: #f4f2ee;
  --paper-2: #e9e5dd;
  --muted: #77736b;
  --line: rgba(10, 10, 10, 0.16);
  --line-dark: rgba(255, 255, 255, 0.16);
  --white: #ffffff;
  --radius: 18px;
  --pad: clamp(18px, 3vw, 48px);
  --max: 1600px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  overflow-x: hidden;
  background: var(--paper);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.1;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

body.is-menu-open { overflow: hidden; }

.noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.045;
  z-index: 999;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
}

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

button,
input,
textarea { font: inherit; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 28px;
  align-items: center;
  padding: 18px var(--pad);
  background: rgba(244, 242, 238, 0.88);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.brand {
  display: inline-flex;
  gap: 8px;
  align-items: baseline;
  font-weight: 800;
  letter-spacing: -0.04em;
  font-size: clamp(18px, 1.6vw, 28px);
}

.brand span:last-child {
  color: var(--muted);
  font-weight: 600;
}

.nav {
  display: flex;
  gap: 20px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.nav a,
.lang-button {
  transition: opacity 160ms ease, transform 160ms ease;
}

.nav a:hover,
.lang-button:hover { opacity: 0.55; }

.lang-switch {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 999px;
  overflow: hidden;
}

.lang-button {
  border: 0;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  padding: 8px 10px;
  font-weight: 700;
  font-size: 12px;
}

.lang-button.is-active {
  background: var(--black);
  color: var(--white);
}

.section {
  padding: clamp(56px, 9vw, 148px) var(--pad);
  max-width: var(--max);
  margin: 0 auto;
}

.section-dark {
  max-width: none;
  background: var(--black);
  color: var(--paper);
  border-top: 1px solid var(--black);
  border-bottom: 1px solid var(--black);
}

.section-dark > * {
  max-width: var(--max);
  margin-inline: auto;
}

.eyebrow {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: clamp(44px, 8vw, 110px);
  font-size: clamp(12px, 1vw, 15px);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}

.hero { position: relative; isolation: isolate; overflow: hidden; padding-top: clamp(44px, 7vw, 116px); }

.hero-backdrop {
  position: absolute;
  inset: -10% -5% 5%;
  z-index: -1;
  pointer-events: none;
  perspective: 1200px;
}

.mesh-grid {
  position: absolute;
  inset: 18% 6% auto;
  height: 70%;
  border-radius: 40px;
  opacity: 0.22;
  background-image:
    linear-gradient(rgba(0,0,0,0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.09) 1px, transparent 1px);
  background-size: 34px 34px;
  transform: perspective(1200px) rotateX(74deg) translate3d(0, 0, -40px);
  mask-image: radial-gradient(circle at center, black 22%, transparent 82%);
}

.orb,
.ring,
.slab,
.section-art { position: absolute; pointer-events: none; }

.orb {
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.98), rgba(212,212,212,0.6) 22%, rgba(95,95,95,0.85) 55%, rgba(10,10,10,0.96) 88%);
  box-shadow: inset -24px -28px 34px rgba(0,0,0,0.36), inset 12px 12px 20px rgba(255,255,255,0.35), 0 22px 60px rgba(0,0,0,0.16);
  animation: drift 18s ease-in-out infinite alternate;
}

.orb::after {
  content: "";
  position: absolute;
  inset: 14% 16% auto auto;
  width: 18%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,255,255,0.78);
  filter: blur(3px);
}

.orb-a { width: clamp(170px, 18vw, 320px); aspect-ratio: 1; right: 4%; top: 8%; }
.orb-b { width: clamp(120px, 11vw, 220px); aspect-ratio: 1; left: 2%; bottom: 18%; animation-duration: 22s; }

.ring {
  border: 1px solid rgba(6,6,6,0.18);
  border-radius: 50%;
  transform-style: preserve-3d;
  animation: spin-ring 20s linear infinite;
}

.ring-a { width: clamp(280px, 28vw, 520px); aspect-ratio: 1; right: 11%; top: 8%; transform: rotateX(72deg) rotateZ(-18deg); }
.ring-b { width: clamp(240px, 23vw, 420px); aspect-ratio: 1; left: 8%; bottom: 4%; transform: rotateX(76deg) rotateZ(16deg); animation-direction: reverse; }

.slab {
  background: linear-gradient(135deg, rgba(255,255,255,0.52), rgba(255,255,255,0.16) 25%, rgba(0,0,0,0.08) 26%, rgba(0,0,0,0.04) 100%);
  border: 1px solid rgba(0,0,0,0.1);
  backdrop-filter: blur(8px);
  box-shadow: 0 30px 80px rgba(0,0,0,0.08);
}

.slab-a { width: clamp(180px, 18vw, 260px); height: clamp(90px, 8vw, 140px); left: 18%; top: 16%; transform: perspective(1000px) rotateX(58deg) rotateY(-28deg) rotateZ(18deg); }
.slab-b { width: clamp(150px, 16vw, 220px); height: clamp(80px, 7vw, 120px); right: 18%; bottom: 14%; transform: perspective(1000px) rotateX(64deg) rotateY(28deg) rotateZ(-18deg); animation: drift 16s ease-in-out infinite alternate-reverse; }

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.5fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: end;
}

h1,
h2,
h3,
p { margin: 0; }

h1 {
  font-size: clamp(58px, 12vw, 210px);
  line-height: 0.82;
  letter-spacing: -0.095em;
  text-transform: uppercase;
  font-weight: 950;
  max-width: 1160px;
}

h1 span { display: block; }

.hero-side {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 10px;
}

.lead {
  font-size: clamp(25px, 3vw, 54px);
  line-height: 0.96;
  letter-spacing: -0.055em;
  font-weight: 900;
}

.muted {
  color: var(--muted);
  font-size: clamp(16px, 1.35vw, 22px);
  line-height: 1.18;
  letter-spacing: -0.035em;
}

.cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 10px; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid currentColor;
  border-radius: 999px;
  padding: 14px 18px;
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease;
  cursor: pointer;
}

.button:hover { transform: translateY(-2px); }

.button-dark { background: var(--black); color: var(--white); }
.button-dark:hover { background: transparent; color: var(--black); }
.button-light { background: transparent; color: var(--black); }
.button-light:hover { background: var(--black); color: var(--white); }

.section-dark .button-dark { background: var(--paper); color: var(--black); }
.section-dark .button-dark:hover { background: transparent; color: var(--paper); }

.showreel {
  position: relative;
  margin-top: clamp(34px, 5vw, 76px);
  aspect-ratio: 16 / 9;
  width: 100%;
  background: var(--black);
  border-radius: clamp(18px, 2vw, 34px);
  overflow: hidden;
  box-shadow: 0 34px 120px rgba(0, 0, 0, 0.22);
}

.showreel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(0,0,0,0.34), rgba(0,0,0,0.08) 28%, rgba(0,0,0,0.12) 55%, rgba(0,0,0,0.64));
}

.showreel-bar {
  position: absolute;
  top: clamp(16px, 2vw, 30px);
  left: clamp(16px, 2vw, 30px);
  right: clamp(16px, 2vw, 30px);
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.showreel-bar > span,
.showreel-fallback span,
.video-placeholder span {
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.8;
}

.reel-control {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(255,255,255,0.36);
  background: rgba(255,255,255,0.08);
  color: var(--paper);
  border-radius: 999px;
  min-height: 48px;
  padding: 0 18px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  cursor: pointer;
  backdrop-filter: blur(12px);
  transition: transform 180ms ease, background 180ms ease;
}

.reel-control:hover { transform: translateY(-2px); background: rgba(255,255,255,0.14); }
.reel-control.is-paused { opacity: 0.76; }
.reel-control.is-paused .reel-dot { background: transparent; box-shadow: inset 0 0 0 2px rgba(255,255,255,0.9), 0 0 0 6px rgba(255,255,255,0.12); }
.reel-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--paper); box-shadow: 0 0 0 6px rgba(255,255,255,0.12); }

.showreel-video,
.video-card video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;
}

.showreel-overlay,
.showreel-fallback,
.video-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 10px;
  padding: clamp(20px, 4vw, 48px);
  color: var(--paper);
}

.showreel-overlay {
  z-index: 4;
  pointer-events: none;
}

.showreel-fallback,
.video-placeholder {
  z-index: 1;
  justify-content: space-between;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.18), transparent 34%),
    linear-gradient(135deg, #070707, #303030 48%, #090909);
}

.showreel-overlay strong,
.showreel-fallback strong,
.video-placeholder strong {
  font-size: clamp(34px, 8vw, 124px);
  line-height: 0.86;
  letter-spacing: -0.08em;
  text-transform: uppercase;
  max-width: 760px;
}

.showreel-overlay em,
.showreel-fallback em {
  font-style: normal;
  color: rgba(255,255,255,0.72);
  font-size: clamp(13px, 1vw, 15px);
}

.statement { padding-block: clamp(84px, 12vw, 190px); }

.statement-inner {
  display: grid;
  grid-template-columns: 1.4fr 0.6fr;
  gap: clamp(28px, 6vw, 90px);
  align-items: end;
}

.statement h2,
.value-strip h2,
.contact-hero h2 {
  font-size: clamp(56px, 11vw, 188px);
  line-height: 0.84;
  letter-spacing: -0.09em;
  text-transform: uppercase;
  font-weight: 950;
}

.statement h2 span,
.value-strip h2 span { display: block; }


.statement p {
  font-size: clamp(20px, 2.3vw, 40px);
  line-height: 1;
  letter-spacing: -0.055em;
  color: rgba(244,242,238,0.72);
  position: relative;
  z-index: 2;
}

.section-art {
  width: clamp(180px, 18vw, 280px);
  aspect-ratio: 1;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.35), rgba(255,255,255,0.08) 26%, rgba(255,255,255,0.04) 50%, transparent 72%), radial-gradient(circle at 60% 60%, rgba(255,255,255,0.14), transparent 62%);
  border: 1px solid rgba(255,255,255,0.14);
  filter: blur(0.2px);
  opacity: 0.9;
}

.statement { position: relative; overflow: hidden; }
.statement-inner { position: relative; z-index: 2; }

.has-ambient { position: relative; overflow: hidden; }
.has-ambient::before,
.has-ambient::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  border: 1px solid rgba(255,255,255,0.08);
}

.has-ambient::before {
  width: 360px;
  height: 360px;
  right: -80px;
  top: -60px;
  box-shadow: inset -30px -30px 70px rgba(255,255,255,0.04);
}

.has-ambient::after {
  width: 200px;
  height: 200px;
  left: -40px;
  bottom: -40px;
  opacity: 0.6;
}


.split-section {
  display: grid;
  grid-template-columns: 0.34fr 0.66fr;
  gap: clamp(28px, 5vw, 78px);
}

.section-title,
.work-header {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.section-title-full { margin-bottom: clamp(32px, 5vw, 78px); }

.section-number,
.service-index {
  display: inline-flex;
  width: max-content;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.section-dark .section-number,
.section-dark .service-index { color: rgba(244,242,238,0.48); }

.section-title h2,
.work-header h2,
.about-layout h2 {
  font-size: clamp(42px, 7vw, 118px);
  line-height: 0.86;
  letter-spacing: -0.08em;
  text-transform: uppercase;
  font-weight: 950;
}

.big-copy {
  font-size: clamp(26px, 4.4vw, 78px);
  line-height: 0.94;
  letter-spacing: -0.075em;
  font-weight: 920;
  max-width: 980px;
}

.grid-four {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  margin-top: clamp(32px, 5vw, 78px);
  background: var(--line);
  border: 1px solid var(--line);
}

.mini-card {
  background: var(--paper);
  padding: clamp(20px, 2.2vw, 34px);
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.mini-card span,
.steps span {
  color: var(--muted);
  font-weight: 900;
  font-size: 12px;
}

.mini-card h3,
.steps h3,
.compare-col h3,
.service-row h3 {
  font-size: clamp(23px, 2vw, 38px);
  letter-spacing: -0.06em;
  line-height: 0.95;
}

.mini-card p,
.steps p,
.service-copy p,
.service-copy li,
.compare-col li,
.note,
.section-bottom-note {
  font-size: clamp(15px, 1.2vw, 20px);
  line-height: 1.15;
  letter-spacing: -0.035em;
}

.two-columns { padding-block: clamp(64px, 10vw, 160px); }

.comparison {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line-dark);
  border: 1px solid var(--line-dark);
  max-width: var(--max);
  margin-top: clamp(32px, 5vw, 78px);
}

.compare-col {
  padding: clamp(24px, 4vw, 60px);
  background: var(--black);
  min-height: 420px;
}

.compare-col-light {
  background: var(--paper);
  color: var(--black);
}

.compare-col h3 { margin-bottom: 28px; }

.compare-col ul,
.pay-list,
.service-copy ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.compare-col li,
.pay-list li,
.service-copy li {
  border-top: 1px solid currentColor;
  padding: 13px 0;
}

.compare-col li { color: rgba(244,242,238,0.76); }
.compare-col-light li { color: var(--ink); }

.section-bottom-note {
  color: rgba(244,242,238,0.7);
  max-width: 780px;
  margin-top: 28px;
}

.value-strip {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: clamp(44px, 7vw, 112px) 0;
}

.value-strip p {
  max-width: 780px;
  margin-top: 28px;
  font-size: clamp(20px, 2.3vw, 42px);
  line-height: 1;
  letter-spacing: -0.06em;
  color: var(--muted);
}

.benefit-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  margin-top: clamp(32px, 5vw, 78px);
  border: 1px solid var(--line);
  background: var(--line);
}

.benefit-list span {
  background: var(--paper);
  padding: clamp(20px, 3vw, 44px);
  font-size: clamp(24px, 3vw, 54px);
  letter-spacing: -0.075em;
  font-weight: 900;
  line-height: 0.95;
}

.pay-grid {
  display: grid;
  grid-template-columns: 0.58fr 0.42fr;
  gap: clamp(30px, 6vw, 100px);
  align-items: start;
}

.pay-grid h3 {
  font-size: clamp(44px, 7vw, 118px);
  line-height: 0.88;
  letter-spacing: -0.085em;
  max-width: 970px;
}

.pay-grid p {
  color: rgba(244,242,238,0.72);
  max-width: 760px;
  margin-top: 28px;
  font-size: clamp(20px, 2vw, 34px);
  line-height: 1;
  letter-spacing: -0.055em;
}

.pay-list li {
  font-size: clamp(22px, 2.7vw, 50px);
  line-height: 0.96;
  letter-spacing: -0.07em;
  font-weight: 900;
}

.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}

.steps article {
  background: var(--paper);
  min-height: 360px;
  padding: clamp(22px, 3vw, 44px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.steps p { color: var(--muted); }

.work-header {
  max-width: var(--max);
  margin-bottom: clamp(32px, 5vw, 76px);
}

.work-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(42px, 6vw, 92px);
}

.work-card {
  border-top: 1px solid var(--line-dark);
  padding-top: clamp(22px, 3vw, 42px);
}

.video-card {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #111;
  overflow: hidden;
  border-radius: clamp(12px, 1.2vw, 20px);
}

.video-placeholder strong { font-size: clamp(34px, 7vw, 118px); }

.work-meta {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  margin-top: 18px;
  color: var(--paper);
}

.work-meta h3 {
  font-size: clamp(26px, 3vw, 58px);
  letter-spacing: -0.07em;
}

.work-meta p {
  color: rgba(244,242,238,0.62);
  font-size: clamp(15px, 1.2vw, 20px);
  letter-spacing: -0.03em;
}

.services-kicker {
  margin-top: 16px;
  color: var(--muted);
  font-size: clamp(16px, 1.5vw, 24px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.services-list {
  border-top: 1px solid var(--line);
}

.service-row {
  display: grid;
  grid-template-columns: 0.35fr 0.18fr 0.47fr;
  gap: clamp(22px, 4vw, 72px);
  align-items: start;
  border-bottom: 1px solid var(--line);
  padding: clamp(26px, 4vw, 64px) 0;
}

.service-price {
  font-size: clamp(34px, 5vw, 84px);
  line-height: 0.9;
  letter-spacing: -0.085em;
  font-weight: 950;
}

.service-copy p { font-weight: 800; margin-bottom: 18px; }
.service-copy li { color: var(--muted); }
.note { margin-top: 24px; color: var(--muted); }

.about-layout {
  display: grid;
  grid-template-columns: 0.45fr 0.55fr;
  gap: clamp(28px, 6vw, 100px);
  align-items: start;
}

.about-copy p {
  font-size: clamp(25px, 3vw, 56px);
  line-height: 0.98;
  letter-spacing: -0.07em;
  font-weight: 900;
  margin-bottom: 28px;
}

.about-copy p:last-child {
  color: rgba(244,242,238,0.7);
}

.contact-section {
  display: grid;
  grid-template-columns: 0.56fr 0.44fr;
  gap: clamp(30px, 5vw, 90px);
  align-items: start;
}

.contact-hero h2 {
  font-size: clamp(52px, 8.5vw, 152px);
  max-width: 980px;
}

.contact-hero p {
  margin-top: 28px;
  font-size: clamp(21px, 2.3vw, 40px);
  line-height: 1;
  letter-spacing: -0.06em;
  color: var(--muted);
  max-width: 680px;
}

.contact-hero .button { margin-top: 26px; }

.contact-form {
  position: sticky;
  top: 94px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(20px, 3vw, 36px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.28);
}

.contact-form label {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact-form span {
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--line);
  padding: 12px 0;
  background: transparent;
  outline: none;
  color: var(--ink);
  font-size: 18px;
  letter-spacing: -0.035em;
  resize: vertical;
}

.contact-form input:focus,
.contact-form textarea:focus { border-bottom-color: var(--black); }

.honeypot {
  position: absolute !important;
  left: -99999px !important;
  opacity: 0 !important;
}

.form-submit { width: 100%; margin-top: 12px; }
.form-status { min-height: 24px; color: var(--muted); font-size: 14px; line-height: 1.25; }
.form-status.is-error { color: #a22; }
.form-status.is-success { color: #176b34; }

.site-footer {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: end;
  padding: 34px var(--pad);
  border-top: 1px solid var(--line);
  background: var(--paper);
  font-size: 14px;
  color: var(--muted);
}

.site-footer div { display: flex; flex-direction: column; gap: 6px; }
.site-footer strong { color: var(--ink); }
.footer-links { align-items: flex-end; }
.footer-links a:hover { color: var(--ink); }

@media (max-width: 1100px) {
  .nav { display: none; }
  .site-header { grid-template-columns: 1fr auto; }
  .hero-grid,
  .statement-inner,
  .split-section,
  .pay-grid,
  .about-layout,
  .contact-section { grid-template-columns: 1fr; }
  .grid-four { grid-template-columns: repeat(2, 1fr); }
  .service-row { grid-template-columns: 1fr; }
  .contact-form { position: static; }
}

@media (max-width: 760px) {
  :root { --pad: 16px; }
  .brand { flex-direction: column; gap: 0; line-height: 0.95; }
  .eyebrow { flex-direction: column; gap: 8px; margin-bottom: 46px; }
  .hero-grid { gap: 24px; }
  h1 { font-size: clamp(56px, 18vw, 96px); }
  .lead { font-size: 30px; }
  .grid-four,
  .comparison,
  .benefit-list,
  .steps { grid-template-columns: 1fr; }
  .mini-card,
  .compare-col,
  .steps article { min-height: 220px; }
  .statement h2,
  .value-strip h2,
  .contact-hero h2 { font-size: clamp(48px, 15vw, 84px); }
  .section-title h2,
  .work-header h2,
  .about-layout h2 { font-size: clamp(42px, 13vw, 76px); }
  .big-copy { font-size: 34px; }
  .work-meta { flex-direction: column; gap: 8px; }
  .site-footer { grid-template-columns: 1fr; }
  .footer-links { align-items: flex-start; }
}
@keyframes drift {
  from { transform: translate3d(0, 0, 0) rotate(0deg); }
  to { transform: translate3d(18px, -18px, 0) rotate(8deg); }
}

@keyframes spin-ring {
  from { transform: rotateX(72deg) rotateZ(0deg); }
  to { transform: rotateX(72deg) rotateZ(360deg); }
}



@media (max-width: 860px) {
  .hero-backdrop { inset: 0; }
  .mesh-grid { inset: 22% 0 auto; height: 58%; opacity: 0.12; }
  .orb-a { right: -8%; top: 20%; }
  .orb-b { left: -10%; bottom: 14%; }
  .ring-a { right: -14%; top: 18%; }
  .ring-b { left: -12%; bottom: 8%; }
  .slab-a, .slab-b { opacity: 0.6; }
  .showreel-bar { flex-direction: column; align-items: flex-start; }
  .showreel-overlay strong, .showreel-fallback strong, .video-placeholder strong { max-width: 100%; }
  .statement .section-art { display: none; }
}

/* Mobile refinement: keep the agency feel, but prevent oversized hero typography on phones. */
@media (max-width: 760px) {
  :root { --pad: 16px; }

  .site-header {
    padding: 14px var(--pad);
    gap: 14px;
  }

  .brand {
    font-size: 18px;
    letter-spacing: -0.045em;
  }

  .lang-button {
    padding: 8px 9px;
    font-size: 11px;
  }

  .section {
    padding-top: 54px;
    padding-bottom: 54px;
  }

  .hero {
    padding-top: 34px;
    padding-bottom: 54px;
  }

  .eyebrow {
    margin-bottom: 30px;
    font-size: 11px;
    line-height: 1.35;
    letter-spacing: 0.055em;
  }

  h1 {
    font-size: clamp(42px, 13.6vw, 56px);
    line-height: 0.9;
    letter-spacing: -0.082em;
    max-width: 100%;
  }

  .hero-grid {
    gap: 22px;
  }

  .hero-side {
    gap: 14px;
    padding-bottom: 0;
  }

  .lead {
    font-size: clamp(24px, 7.4vw, 30px);
    line-height: 1;
    letter-spacing: -0.055em;
    max-width: 94%;
  }

  .muted {
    font-size: 15px;
    line-height: 1.24;
    letter-spacing: -0.025em;
    max-width: 92%;
  }

  .button {
    min-height: 42px;
    padding: 11px 15px;
    font-size: 11px;
    letter-spacing: 0.015em;
  }

  .showreel {
    margin-top: 30px;
    border-radius: 18px;
    min-height: 205px;
  }

  .showreel-bar {
    top: 14px;
    left: 14px;
    right: 14px;
    flex-direction: row;
    align-items: center;
  }

  .showreel-bar > span {
    font-size: 10px;
  }

  .reel-control {
    min-height: 36px;
    padding: 0 12px;
    font-size: 10px;
  }

  .showreel-overlay,
  .showreel-fallback,
  .video-placeholder {
    padding: 18px;
  }

  .showreel-overlay strong,
  .showreel-fallback strong,
  .video-placeholder strong {
    font-size: clamp(28px, 9vw, 38px);
    line-height: 0.92;
    letter-spacing: -0.07em;
  }

  .hero-backdrop {
    opacity: 0.78;
  }

  .mesh-grid {
    inset: 28% -10% auto;
    height: 48%;
    opacity: 0.09;
    background-size: 28px 28px;
  }

  .orb-a {
    width: clamp(128px, 42vw, 178px);
    right: -18%;
    top: 27%;
  }

  .orb-b {
    width: 92px;
    left: -14%;
    bottom: 23%;
    opacity: 0.42;
  }

  .ring-a {
    width: 230px;
    right: -34%;
    top: 27%;
    opacity: 0.45;
  }

  .ring-b,
  .slab-a,
  .slab-b {
    display: none;
  }

  .statement,
  .two-columns {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .statement h2,
  .value-strip h2,
  .contact-hero h2 {
    font-size: clamp(36px, 11.5vw, 52px);
    line-height: 0.92;
    letter-spacing: -0.075em;
  }

  .statement p {
    font-size: 22px;
    line-height: 1.05;
  }

  .section-title h2,
  .work-header h2,
  .about-layout h2 {
    font-size: clamp(34px, 11.5vw, 52px);
    line-height: 0.92;
    letter-spacing: -0.075em;
  }

  .big-copy {
    font-size: 27px;
    line-height: 1;
    letter-spacing: -0.062em;
  }

  .grid-four,
  .comparison,
  .benefit-list,
  .steps {
    grid-template-columns: 1fr;
  }

  .mini-card,
  .compare-col,
  .steps article {
    min-height: auto;
    padding: 22px;
  }

  .mini-card {
    gap: 42px;
  }

  .compare-col ul,
  .pay-list,
  .service-copy ul {
    padding-left: 18px;
  }

  .benefit-list span {
    min-height: auto;
    padding: 18px;
    font-size: 24px;
  }

  .pay-grid {
    gap: 28px;
  }

  .pay-grid h3 {
    font-size: clamp(32px, 10vw, 48px);
    line-height: 0.96;
  }

  .service-row {
    padding-block: 26px;
  }

  .service-price {
    font-size: 32px;
  }

  .contact-form {
    padding: 18px;
  }

  .site-footer {
    gap: 18px;
  }
}

@media (max-width: 390px) {
  h1 {
    font-size: clamp(39px, 13vw, 50px);
    letter-spacing: -0.075em;
  }

  .lead {
    font-size: 25px;
  }

  .statement h2,
  .value-strip h2,
  .contact-hero h2,
  .section-title h2,
  .work-header h2,
  .about-layout h2 {
    font-size: 38px;
  }
}

/* Hide showreel title overlay until a real video file is loaded. Prevent duplicate text over fallback placeholder. */
.showreel-overlay { display: none; }

/* ===== V4 cinematic hero inspired by the reference ===== */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: transparent;
  border-bottom: 0;
  color: var(--white);
  transition: background 220ms ease, border-color 220ms ease, transform 220ms ease, color 220ms ease;
}

.site-header .brand span:last-child,
.site-header .nav a,
.site-header .lang-button {
  color: inherit;
}

.site-header .lang-switch {
  border-color: rgba(255,255,255,0.28);
}

.site-header .lang-button.is-active {
  background: var(--white);
  color: var(--black);
}

.site-header.is-scrolled {
  background: rgba(8, 8, 8, 0.68);
  border-bottom: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(18px);
}

main#top { overflow: clip; }

.hero-cinematic {
  max-width: none;
  min-height: 100svh;
  padding: 0;
  display: flex;
  align-items: stretch;
  position: relative;
  background: var(--black);
  color: var(--white);
}

.hero-cinematic .hero-media,
.hero-cinematic .hero-content {
  position: absolute;
  inset: 0;
}

.hero-video,
.hero-media-fallback,
.hero-media-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero-video { object-fit: cover; z-index: 1; }
.hero-media-fallback {
  z-index: 0;
  background:
    radial-gradient(circle at 72% 28%, rgba(255,255,255,0.10), transparent 18%),
    radial-gradient(circle at 30% 65%, rgba(255,255,255,0.08), transparent 30%),
    linear-gradient(120deg, #090909, #202020 44%, #0c0c0c 100%);
}
.hero-media-shade {
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.46) 0%, rgba(0,0,0,0.12) 22%, rgba(0,0,0,0.18) 55%, rgba(0,0,0,0.72) 100%),
    radial-gradient(circle at 50% 42%, rgba(255,255,255,0.06), transparent 25%);
}

.hero-cinematic .hero-content {
  z-index: 4;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: calc(88px + env(safe-area-inset-top)) clamp(16px, 4vw, 42px) clamp(22px, 3.5vw, 34px);
}

.hero-cinematic .hero-eyebrow {
  position: absolute;
  top: calc(96px + env(safe-area-inset-top));
  left: clamp(16px, 4vw, 42px);
  right: clamp(16px, 4vw, 42px);
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: rgba(255,255,255,0.78);
  margin: 0;
}

.hero-copy-overlay {
  position: relative;
  z-index: 5;
  max-width: min(720px, 90vw);
}

.hero-cinematic h1 {
  max-width: 820px;
  font-size: clamp(56px, 10.4vw, 170px);
  line-height: 0.82;
  color: var(--white);
  text-shadow: 0 20px 80px rgba(0,0,0,0.35);
}

.hero-cinematic .lead {
  margin-top: 22px;
  max-width: 640px;
  color: var(--white);
  font-size: clamp(21px, 2vw, 38px);
}

.hero-cinematic .muted {
  margin-top: 12px;
  max-width: 580px;
  color: rgba(255,255,255,0.76);
}

.hero-cta-row { margin-top: 22px; }

.button-ghost {
  background: rgba(255,255,255,0.08);
  color: var(--white);
  border-color: rgba(255,255,255,0.32);
  backdrop-filter: blur(14px);
}

.button-ghost:hover {
  background: var(--white);
  color: var(--black);
}


.hero-cursor {
  position: fixed;
  left: 0;
  top: 0;
  width: 110px;
  height: 110px;
  margin-left: -55px;
  margin-top: -55px;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  color: var(--black);
  display: none;
  place-items: center;
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  line-height: 0.92;
  letter-spacing: -0.05em;
  z-index: 15;
  pointer-events: none;
  box-shadow: 0 18px 60px rgba(0,0,0,0.2);
}

.hero-cinematic.is-cursor-active,
.hero-cinematic.is-cursor-active * { cursor: none; }

.hero-cinematic.is-cursor-active .hero-cursor { display: grid; }

.section,
.work-card,
.service-row,
.compare-col,
.mini-card,
.photo-card,
.steps article,
.value-strip,
.contact-wrap,
.about-layout,
.pay-grid {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms ease, transform 700ms ease;
}

.is-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.section-gallery .services-kicker { max-width: 760px; }

.photo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 1.8vw, 22px);
  margin-top: clamp(30px, 4vw, 50px);
}

.photo-card { min-width: 0; }

.photo-frame {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: 18px;
  background: linear-gradient(135deg, #181818, #3f3f3f 50%, #121212);
  box-shadow: 0 26px 70px rgba(0,0,0,0.12);
}

.photo-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.photo-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 18px;
  color: var(--paper);
  background:
    radial-gradient(circle at 70% 25%, rgba(255,255,255,0.14), transparent 18%),
    linear-gradient(135deg, #060606, #2b2b2b 48%, #0d0d0d);
}

.photo-fallback span {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.75;
}

.photo-fallback strong {
  font-size: clamp(24px, 2vw, 42px);
  line-height: 0.9;
  letter-spacing: -0.06em;
  text-transform: uppercase;
}

@media (max-width: 1100px) {
  .photo-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .site-header {
    grid-template-columns: 1fr auto;
    align-items: start;
    gap: 10px;
    padding-top: calc(12px + env(safe-area-inset-top));
  }

  .nav {
    display: none;
  }

  .hero-cinematic {
    min-height: 100svh;
  }

  .hero-cinematic .hero-content {
    justify-content: flex-end;
    padding: calc(86px + env(safe-area-inset-top)) 16px 20px;
  }

  .hero-cinematic .hero-eyebrow {
    top: calc(74px + env(safe-area-inset-top));
    left: 16px;
    right: 16px;
    flex-direction: column;
    gap: 4px;
    font-size: 10px;
  }

  .hero-cinematic h1 {
    font-size: clamp(38px, 11vw, 56px);
    max-width: 92%;
  }

  .hero-cinematic .lead {
    margin-top: 16px;
    font-size: 21px;
    max-width: 95%;
  }

  .hero-cinematic .muted {
    font-size: 14px;
    max-width: 92%;
  }

  .hero-cta-row {
    gap: 10px;
  }

  .hero-cursor { display: none !important; }

  .photo-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .photo-frame {
    aspect-ratio: 4 / 4.8;
  }
}

/* V8: two 9:16 promo examples */
.work-grid-vertical {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 420px));
  justify-content: center;
  align-items: start;
  gap: clamp(28px, 5vw, 84px);
}

.work-card-vertical {
  width: 100%;
  border-top: 1px solid var(--line-dark);
}

.video-card-vertical {
  aspect-ratio: 9 / 16;
  width: 100%;
  margin-inline: auto;
  border-radius: clamp(18px, 2vw, 30px);
}

.work-meta-vertical {
  width: 100%;
  margin-inline: auto;
  align-items: flex-start;
}

.work-meta-vertical h3 {
  max-width: 72%;
}

@media (max-width: 760px) {
  .work-grid-vertical {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .work-card-vertical,
  .video-card-vertical,
  .work-meta-vertical {
    width: 100%;
  }

  .video-card-vertical {
    max-height: 78svh;
  }

  .work-meta-vertical h3 {
    max-width: 100%;
  }
}
