/* ============================================================
   Morse Craft Design — dark / grotesque
   Display: Space Grotesk / Body: Switzer
   Palette: black #0A0A0A / white #FAFAFA / mute #6E6E6E
   ============================================================ */

:root {
  --bg:     #0A0A0A;
  --bg-2:   #131313;
  --fg:     #FAFAFA;
  --mute:   #909090;
  --mute-2: #5E5E5E;
  --mute-soft: #6A6A6A;
  --line:   #ffffff14;
  --line-2: #ffffff26;
  --accent: #FAFAFA;
  --hi:     #E6FF3D;          /* sharp accent — used very sparingly */

  --sans: "Switzer", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --display: "Space Grotesk", "Switzer", ui-sans-serif, system-ui, sans-serif;
  --mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace;

  --max: 1480px;
  --pad: clamp(20px, 4vw, 64px);
}

[data-mode="light"] {
  --bg: #FAFAFA; --bg-2: #F0F0F0;
  --fg: #0A0A0A;
  --mute: #6E6E6E; --mute-2: #BFBFBF;
  --line: #00000014; --line-2: #00000026;
  --accent: #0A0A0A;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: var(--bg); }
body {
  font-family: var(--sans);
  font-weight: 400;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
  line-height: 1.45;
  letter-spacing: -0.01em;
  overflow-x: hidden;
  cursor: none;
  transition: background .5s ease, color .5s ease;
}
@media (hover: none) { body { cursor: auto; } }

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: none; }
@media (hover: none) { button { cursor: pointer; } }

::selection { background: var(--hi); color: #0A0A0A; }

/* ---------- type primitives ---------- */
.up {
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.mono {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.cap {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mute);
}
.display {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.025em;
  line-height: 0.9;
  margin: 0;
}

/* ---------- layout ---------- */
.wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
  position: relative;
}
.section { padding-block: clamp(80px, 11vw, 160px); position: relative; }
.section-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(20px, 4vw, 80px);
  margin-bottom: clamp(56px, 8vw, 120px);
  align-items: start;
}
.section-num {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--mute);
  letter-spacing: 0.04em;
}
.section-label {
  font-family: var(--sans);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 13px;
  color: var(--mute);
}

/* ---------- cursor ---------- */
.cursor {
  position: fixed;
  top: 0; left: 0;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--fg);
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width .25s, height .25s, background .25s, border .25s;
  mix-blend-mode: difference;
}
.cursor.hover { width: 48px; height: 48px; background: transparent; border: 1px solid var(--fg); }
@media (hover: none) { .cursor { display: none; } }

/* ---------- reveal ---------- */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1);
}
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 20px var(--pad);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-bottom: 1px solid var(--line);
}
.nav-brand {
  display: flex; align-items: center; gap: 12px;
}
.nav-logo {
  display: block;
  height: 44px;
  width: auto;
}
.nav-logo--light { display: none; }
[data-mode="light"] .nav-logo--dark { display: none; }
[data-mode="light"] .nav-logo--light { display: block; }
.nav-links {
  display: flex; gap: 32px; justify-self: center;
  font-family: var(--sans);
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.06em;
  font-weight: 500;
}
.nav-links a { position: relative; padding: 4px 0; transition: color .3s; }
.nav-links a:hover { color: var(--mute); }
.nav-cta { justify-self: end; display: flex; gap: 16px; align-items: center; }
.nav-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  border: 1px solid var(--line-2);
  border-radius: 100px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--mute);
}
.nav-pill .live {
  width: 6px; height: 6px;
  background: var(--hi); border-radius: 50%;
  display: inline-block;
  animation: live 1.4s ease-in-out infinite;
}
@keyframes live {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: .5; transform: scale(.85); }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding-top: 140px;
  padding-bottom: 0;
  position: relative;
}
.hero-top {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--mute);
  margin-bottom: clamp(40px, 5vw, 80px);
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.hero-top .left, .hero-top .right { display: flex; gap: 24px; align-items: center; }
.hero-top .strong { color: var(--fg); }

/* ---- language switcher (BR · EN · ES) ---- */
.lang-switch { display: flex; align-items: center; gap: 1px; font-family: var(--mono); }
.lang-btn {
  appearance: none; background: none; border: 0; cursor: pointer;
  font: inherit; font-size: 11px; letter-spacing: 0.12em; line-height: 1;
  padding: 6px 6px; color: var(--mute-2);
  transition: color .2s ease;
}
.lang-btn:not(:last-of-type)::after {
  content: ''; /* hairline divider handled by gap; keep clean */
}
.lang-btn:hover { color: var(--fg); }
.lang-btn.on { color: var(--hi); }
.lang-btn:disabled { cursor: wait; opacity: .55; }
.lang-spin {
  width: 9px; height: 9px; border-radius: 50%;
  border: 1.5px solid var(--mute-2); border-top-color: var(--hi);
  animation: langspin .7s linear infinite; margin-left: 5px;
}
@keyframes langspin { to { transform: rotate(360deg); } }

/* ---- live morse signal (hero top-right) ---- */
.hero-signal {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
  user-select: none;
}
.sig-live {
  width: 6px; height: 6px; border-radius: 99px;
  background: var(--mute-2);
  flex: none;
  animation: sigBreathe 1.8s ease-in-out infinite;
}
@keyframes sigBreathe {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; box-shadow: 0 0 8px var(--hi); background: var(--hi); }
}
.sig-label { white-space: nowrap; }
.sig-stream { display: flex; align-items: center; gap: 9px; }
.sig-letter { display: flex; align-items: center; gap: 5px; }
.sig-dot, .sig-dash {
  height: 5px;
  border-radius: 99px;
  background: var(--mute-2);
  transition: background .14s ease, box-shadow .28s ease, transform .14s ease;
}
.sig-dot { width: 5px; }
.sig-dash { width: 15px; }
.sig-dot.on, .sig-dash.on {
  background: var(--hi);
  box-shadow: 0 0 10px var(--hi);
  transform: scaleY(1.25);
}
@media (max-width: 720px) {
  .sig-label { display: none; }
  .hero-signal { gap: 10px; }
}

.hero-title {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: clamp(64px, 14.5vw, 248px);
  line-height: 0.86;
  letter-spacing: -0.045em;
  margin: 0;
  margin-left: -0.06em;
}
.hero-title .row { display: block; }
.hero-title .row.indent { padding-left: clamp(40px, 12vw, 220px); }
.hero-title .thin { font-weight: 200; }
.hero-title .mute { color: var(--mute); }
.hero-title .outline {
  -webkit-text-stroke: 1.5px var(--fg);
  color: transparent;
}
.hero-title .hi {
  color: var(--hi);
}

.hero-meta {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 24px;
  border-top: 1px solid var(--line);
  padding-block: 24px;
  margin-top: clamp(48px, 6vw, 80px);
  color: var(--mute);
  font-family: var(--mono);
  font-size: 12px;
}
.hero-meta-stats {
  display: flex;
  gap: clamp(40px, 5vw, 72px);
}
.hero-meta .k { color: var(--mute-2); margin-bottom: 8px; }
.hero-meta .v { color: var(--fg); }
.hero-meta .lede {
  font-family: var(--sans);
  font-weight: 300;
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.45;
  letter-spacing: -0.005em;
  color: var(--fg);
  text-transform: none;
  max-width: 44ch;
}

/* marquee strip */
.marquee {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  padding-block: 18px;
}
.marquee-track {
  display: flex; gap: 56px;
  white-space: nowrap;
  animation: marquee 50s linear infinite;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  align-items: center;
}
.marquee-track .star { color: var(--hi); font-size: 18px; }
.marquee-track .item { display: inline-flex; gap: 18px; align-items: center; }
.marquee-track .item .mono-tag {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--mute);
  letter-spacing: 0.06em;
  text-transform: none;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   ABOUT — studio positioning
   ============================================================ */
.positioning {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: clamp(32px, 6vw, 110px);
  align-items: end;
}
.positioning-title {
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(34px, 5vw, 86px);
  line-height: 0.98;
  letter-spacing: -0.03em;
  margin: 0;
}
.positioning-title .line { display: block; }
.positioning-title .key { color: var(--fg); }
.positioning-title .mute { color: var(--mute); }
.positioning-body {
  margin: 0;
  font-size: clamp(15px, 1.05vw, 17px);
  line-height: 1.6;
  font-weight: 300;
  color: var(--fg);
  max-width: 42ch;
  padding-bottom: 10px;
}

.who {
  margin-top: clamp(64px, 9vw, 130px);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(32px, 5vw, 90px);
  border-top: 1px solid var(--line);
  padding-top: clamp(36px, 4vw, 56px);
  align-items: start;
}
.who-intro {
  margin: 18px 0 0;
  font-size: clamp(15px, 1.05vw, 17px);
  line-height: 1.55;
  font-weight: 300;
  color: var(--fg);
  max-width: 34ch;
}
.who-list {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.who-list li {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 18px 4px;
  border-top: 1px solid var(--line);
  font-family: var(--display);
  font-weight: 500;
  font-size: clamp(17px, 1.6vw, 26px);
  letter-spacing: -0.02em;
  color: var(--fg);
  transition: color .3s, padding-left .35s cubic-bezier(.7,0,.2,1);
}
.who-list li:nth-child(2n) { padding-left: clamp(8px, 2vw, 28px); }
.who-list li:nth-last-child(-n+2) { border-bottom: 1px solid var(--line); }
.who-list li:hover { color: var(--hi); padding-left: 18px; }
.who-list .who-num {
  color: var(--mute);
  font-size: 11px;
  flex: none;
  transition: color .3s;
}
.who-list li:hover .who-num { color: var(--hi); }

/* ============================================================
   SERVICES — orbit + clusters
   ============================================================ */
.svc-heading {
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(30px, 4.4vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.03em;
  margin: 18px 0 0;
  max-width: 16ch;
}
.svc-heading .key { color: var(--fg); }
.svc-heading .mute { color: var(--mute); }

/* ---- orbit ---- */
.orbit-wrap {
  display: flex;
  justify-content: center;
  margin: clamp(20px, 4vw, 64px) 0 clamp(64px, 9vw, 130px);
}
.orbit {
  position: relative;
  width: min(92vw, 940px);
  aspect-ratio: 1 / 1;
}
.orbit-lines {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  overflow: visible;
  animation: orbit-spin 90s linear infinite;
}
.orbit.is-hover .orbit-lines,
.orbit.is-hover .orbit-rotor { animation-play-state: paused; }
.oline { stroke: var(--line-2); stroke-width: 1; transition: stroke .3s; }
.oline.on { stroke: var(--hi); }
.oring { fill: none; stroke: var(--line); stroke-width: 1; }
.oring.faint { stroke-dasharray: 2 5; opacity: 0.6; }

.orbit-rotor {
  position: absolute; inset: 0;
  animation: orbit-spin 90s linear infinite;
}
@keyframes orbit-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes orbit-spin-rev {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

.orbit-node {
  position: absolute;
  width: clamp(92px, 12vw, 150px);
  height: clamp(92px, 12vw, 150px);
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.22);
  background: var(--bg-2);
  display: grid;
  place-items: center;
  text-align: center;
  cursor: none;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.03), 0 18px 40px -24px #000;
  transition: border-color .35s, background .35s, transform .5s cubic-bezier(.2,.7,.2,1);
  animation: node-in .7s cubic-bezier(.2,.8,.2,1) backwards;
}
.orbit-node:nth-child(1) { animation-delay: .05s; }
.orbit-node:nth-child(2) { animation-delay: .12s; }
.orbit-node:nth-child(3) { animation-delay: .19s; }
.orbit-node:nth-child(4) { animation-delay: .26s; }
.orbit-node:nth-child(5) { animation-delay: .33s; }
.orbit-node:nth-child(6) { animation-delay: .40s; }
.orbit-node:nth-child(7) { animation-delay: .47s; }
@keyframes node-in {
  from { opacity: 0; transform: translate(-50%, -50%) scale(.4); }
  to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}
.orbit-node-in {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 6px;
  animation: orbit-spin-rev 90s linear infinite;
}
.orbit.is-hover .orbit-node-in { animation-play-state: paused; }
.on-num { font-size: 10px; color: var(--mute); letter-spacing: 0.06em; }
.on-dash { color: var(--mute-2); font-size: 11px; line-height: 0.5; }
.on-name {
  font-family: var(--sans);
  font-weight: 500;
  font-size: clamp(13px, 1.35vw, 17px);
  line-height: 1.15;
  letter-spacing: 0.01em;
  white-space: pre-line;
  color: var(--fg);
}
.orbit-node.on, .orbit-node:hover {
  border-color: var(--hi);
  background: var(--bg-2);
  transform: translate(-50%, -50%) scale(1.06);
}
.orbit-node.on .on-name, .orbit-node:hover .on-name { color: var(--hi); }

.orbit-core {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: clamp(76px, 10vw, 128px);
  height: clamp(76px, 10vw, 128px);
  border-radius: 50%;
  display: grid; place-items: center;
  z-index: 2;
  background: var(--surface, #161616);
  border: 1px solid var(--line);
}
.orbit-mark {
  width: 30%; height: auto;
  opacity: 0.85;
  animation: core-pulse 4s ease-in-out infinite;
}
[data-mode="light"] .orbit-mark { filter: invert(1); }
@keyframes core-pulse {
  0%, 100% { transform: scale(1); opacity: 0.92; }
  50%      { transform: scale(1.08); opacity: 1; }
}

.orbit-readout {
  position: absolute;
  left: 50%;
  top: calc(50% + clamp(58px, 7vw, 92px));
  transform: translateX(-50%);
  width: min(70%, 320px);
  text-align: center;
  pointer-events: none;
  opacity: 0.55;
  transition: opacity .3s;
}
.orbit-readout.show { opacity: 1; }
.ro-name {
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(13px, 1.3vw, 17px);
  letter-spacing: -0.01em;
  color: var(--fg);
  margin-bottom: 6px;
}
.ro-desc {
  font-family: var(--mono);
  font-size: 11px;
  line-height: 1.45;
  color: var(--mute);
  text-transform: none;
}

/* ---- clusters accordion ---- */
.clusters { display: grid; gap: clamp(56px, 8vw, 100px); }
.cl-group-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 14px;
  margin-bottom: 8px;
}
.cl-group-sep { color: var(--mute-soft, var(--line)); font-weight: 300; }
.cl-group-intro {
  margin: 0;
  font-size: clamp(14px, 1vw, 16px);
  line-height: 1.5;
  font-weight: 300;
  color: var(--mute);
}
.cl-list { border-top: 1px solid var(--line); margin-top: 20px; }
.cl { border-bottom: 1px solid var(--line); }
.cl-head {
  display: grid;
  grid-template-columns: 56px minmax(220px, 1.1fr) 2fr 28px;
  gap: clamp(16px, 2.4vw, 40px);
  align-items: center;
  width: 100%;
  padding: clamp(22px, 2.6vw, 34px) 0;
  text-align: left;
  cursor: none;
}
@media (hover: none) { .cl-head { cursor: pointer; } }
.cl-num { color: var(--mute); align-self: start; padding-top: 6px; }
.cl-name {
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(22px, 2.6vw, 42px);
  line-height: 0.98;
  letter-spacing: -0.025em;
  transition: color .3s;
}
.cl-desc {
  font-size: clamp(13px, 0.95vw, 15px);
  line-height: 1.45;
  font-weight: 300;
  color: var(--mute);
  max-width: 46ch;
}
.cl:hover .cl-name, .cl.open .cl-name { color: var(--hi); }
.cl-toggle { position: relative; width: 22px; height: 22px; align-self: start; margin-top: 8px; }
.cl-toggle .bar {
  position: absolute; left: 50%; top: 50%;
  background: var(--fg);
  transition: transform .4s cubic-bezier(.7,0,.2,1), background .3s;
}
.cl-toggle .bar.h { width: 18px; height: 1.5px; transform: translate(-50%, -50%); }
.cl-toggle .bar.v { width: 1.5px; height: 18px; transform: translate(-50%, -50%); }
.cl.open .cl-toggle .bar.v { transform: translate(-50%, -50%) scaleY(0); }
.cl.open .cl-toggle .bar { background: var(--hi); }

.cl-body { overflow: hidden; transition: max-height .55s cubic-bezier(.4,0,.1,1); }
.cl-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 clamp(28px, 4vw, 72px);
  padding: 8px 0 clamp(28px, 3vw, 44px) 76px;
}
.cl-item {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  cursor: none;
}
@media (hover: none) { .cl-item { cursor: default; } }
.ci-name {
  font-family: var(--sans);
  font-weight: 500;
  font-size: clamp(14px, 1.1vw, 17px);
  letter-spacing: -0.005em;
  color: var(--fg);
  transition: color .3s, transform .35s cubic-bezier(.7,0,.2,1);
}
.ci-desc {
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.45;
  color: var(--mute);
  text-transform: none;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height .4s ease, opacity .35s ease, margin-top .4s ease;
}
.cl-item:hover .ci-name, .cl-item:focus .ci-name { color: var(--hi); transform: translateX(6px); }
.cl-item:hover .ci-desc, .cl-item:focus .ci-desc { max-height: 60px; opacity: 1; margin-top: 7px; }

/* ============================================================
   MANIFESTO — what we believe
   ============================================================ */
.manifesto { }
.film { display: grid; gap: 16px; margin: 0; }
.film-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--line-2);
  overflow: hidden;
  display: grid;
  place-items: center;
  background: var(--bg-2);
}
.film-stripes {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, transparent 0 16px, rgba(127,127,127,0.06) 16px 32px);
}
.film-trigger {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  display: grid; place-items: center;
  background: var(--bg-2);
  border: 0; padding: 0; margin: 0;
  cursor: pointer;
}
.film-poster {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.02) brightness(0.62);
  transition: filter .6s ease, transform 1.4s cubic-bezier(.2,.7,.2,1);
}
.film-trigger:hover .film-poster { filter: grayscale(0) brightness(0.74); transform: scale(1.03); }
.film-scrim {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 50%, #0A0A0A33 0%, #0A0A0A88 100%);
}
.film-embed {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0; display: block;
}
.film-play {
  position: relative;
  width: clamp(64px, 7vw, 108px);
  height: clamp(64px, 7vw, 108px);
  border-radius: 50%;
  border: 1px solid var(--line-2);
  display: grid; place-items: center;
  transition: border-color .4s, transform .4s;
}
.film-trigger:hover .film-play { border-color: var(--hi); transform: scale(1.04); background: #0A0A0A55; }
.film-play { backdrop-filter: blur(2px); }
.film-tri {
  width: 0; height: 0;
  border-style: solid;
  border-width: 11px 0 11px 18px;
  border-color: transparent transparent transparent var(--fg);
  margin-left: 5px;
  transition: border-left-color .4s;
}
.film-trigger:hover .film-tri { border-left-color: var(--hi); }
.film-meta {
  position: absolute; left: 0; right: 0; bottom: 0;
  display: flex; justify-content: space-between;
  padding: 18px 20px;
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--mute);
}
.film-cap { color: var(--mute); }

/* ============================================================
   HOW WE WORK — principles
   ============================================================ */
.principles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.principle {
  padding: clamp(28px, 3.4vw, 52px) clamp(22px, 2.4vw, 40px);
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  min-height: clamp(160px, 18vw, 240px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.principle::before {
  content: ""; position: absolute; inset: 0;
  background: var(--bg-2);
  transform: translateY(101%);
  transition: transform .55s cubic-bezier(.7,0,.2,1);
  z-index: -1;
}
.principle:hover::before { transform: translateY(0); }
.pr-k { color: var(--mute); transition: color .3s; }
.principle:hover .pr-k { color: var(--hi); }
.pr-v {
  font-family: var(--display);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(20px, 2.2vw, 34px);
  line-height: 1.0;
  letter-spacing: -0.025em;
  max-width: 16ch;
}

/* ============================================================
   CASES — vertical large list
   ============================================================ */
.cases-intro {
  margin: 2px 0 0;
  font-size: clamp(15px, 1.05vw, 17px);
  line-height: 1.55;
  font-weight: 300;
  color: var(--fg);
  max-width: 44ch;
}
.cases { border-top: 1px solid var(--line); position: relative; }
.case {
  display: grid;
  grid-template-columns: 60px 1.5fr 1fr 90px 90px;
  gap: 28px;
  padding: 32px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
  position: relative;
  transition: opacity .4s;
}
.cases.has-hover .case:not(.is-hover) { opacity: 0.32; }
.case .num { font-family: var(--mono); font-size: 12px; color: var(--mute); }
.case .title {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: clamp(28px, 3vw, 52px);
  letter-spacing: -0.025em;
  line-height: 0.95;
  transition: transform .5s cubic-bezier(.2,.7,.2,1), color .35s;
}
.case .meta { color: var(--mute); font-size: 14px; }
.case .meta .chip {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid var(--line-2);
  border-radius: 100px;
  margin-right: 4px;
  margin-bottom: 4px;
}
.case .year { color: var(--mute); font-family: var(--mono); font-size: 12px; }
.case .open {
  font-family: var(--mono);
  font-size: 12px;
  text-align: right;
  color: var(--mute);
  transition: transform .5s cubic-bezier(.2,.7,.2,1), color .35s;
}
.case:hover .title { transform: translateX(12px); }
.case:hover .open { transform: translateX(8px); color: var(--hi); }

/* hover preview — looks like a project thumbnail */
.preview {
  position: fixed;
  top: 0; left: 0;
  width: 360px;
  height: 460px;
  pointer-events: none;
  z-index: 80;
  opacity: 0;
  transform: translate(-50%, -50%) scale(.94);
  transition: opacity .35s, transform .5s cubic-bezier(.2,.8,.2,1);
  overflow: hidden;
  box-shadow: 0 30px 80px -20px #00000088;
}
.preview.show { opacity: 1; transform: translate(-50%, -50%) scale(1); }
.panel {
  position: absolute; inset: 0;
  background: var(--swatch, #1a1a1a);
  color: var(--swatch-fg, #FAFAFA);
  display: grid;
  overflow: hidden;
}
.panel .meta-row {
  position: absolute;
  inset: auto 14px 12px 14px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: inherit;
  opacity: 0.7;
  z-index: 2;
}
.panel .meta-row .pin {
  padding: 4px 8px;
  border: 1px solid currentColor;
  border-radius: 100px;
  opacity: 0.7;
}

/* Variant 1 — big typography (editorial / branding) */
.pv-type {
  display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
  padding: 28px;
  font-family: var(--sans);
}
.pv-type .lbl {
  font-family: var(--mono); font-size: 10px; opacity: 0.6;
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 14px;
}
.pv-type .big {
  font-weight: 700; text-transform: uppercase;
  font-size: 64px; line-height: 0.86; letter-spacing: -0.04em;
}
.pv-type .big .thin { font-weight: 200; }

/* Variant 2 — color grid (identity / system) */
.pv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
}
.pv-grid .cell { position: relative; }
.pv-grid .cell .lbl {
  position: absolute; left: 6px; bottom: 6px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  color: inherit;
  opacity: 0.65;
}

/* Variant 3 — editorial spread */
.pv-spread { display: grid; grid-template-columns: 1fr 1fr; gap: 0; padding: 0; }
.pv-spread .page {
  padding: 22px 16px;
  border-right: 1px solid currentColor;
}
.pv-spread .page:last-child { border-right: 0; }
.pv-spread .h {
  font-family: var(--sans);
  font-weight: 700; text-transform: uppercase;
  font-size: 22px; line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
}
.pv-spread .h .thin { font-weight: 200; }
.pv-spread .l {
  height: 4px;
  background: currentColor;
  margin-bottom: 8px;
  opacity: 0.85;
  border-radius: 2px;
}
.pv-spread .l.short { width: 60%; }
.pv-spread .l.mid   { width: 80%; }
.pv-spread .l.tiny  { width: 35%; opacity: 0.5; height: 3px; }

/* Variant 4 — app screen */
.pv-app { padding: 18px; display: flex; flex-direction: column; gap: 12px; }
.pv-app .bar {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.06em; text-transform: uppercase;
  opacity: 0.7;
}
.pv-app .balance {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 36px;
  letter-spacing: -0.03em;
  line-height: 1;
}
.pv-app .balance .thin { font-weight: 200; opacity: 0.6; }
.pv-app .balance-sub {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.06em; text-transform: uppercase;
  opacity: 0.6;
}
.pv-app .rows { display: grid; gap: 8px; margin-top: 8px; }
.pv-app .rows .row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 10px;
  border: 1px solid currentColor;
  border-radius: 6px;
  opacity: 0.85;
}
.pv-app .rows .row .l { font-family: var(--sans); font-weight: 500; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.pv-app .rows .row .v { font-family: var(--mono); font-size: 11px; }

/* Variant 5 — poster / stripes */
.pv-poster {
  display: grid; gap: 0;
  padding: 0;
}
.pv-poster .head {
  padding: 22px;
  font-family: var(--sans);
}
.pv-poster .head .lbl {
  font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.06em; opacity: 0.6;
  margin-bottom: 10px;
}
.pv-poster .head .big {
  font-weight: 700; text-transform: uppercase;
  font-size: 42px; line-height: 0.88; letter-spacing: -0.03em;
}
.pv-poster .head .big .thin { font-weight: 200; }
.pv-poster .stripes {
  display: grid; grid-auto-flow: row; gap: 0;
  margin-top: 0;
  flex: 1;
}
.pv-poster .stripes .s {
  height: 18px;
  border-top: 1px solid currentColor;
  opacity: 0.85;
}

/* Variant 6 — illustration / coop */
.pv-circle {
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 22px;
}
.pv-circle .top { font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; opacity: 0.7; display: flex; justify-content: space-between; }
.pv-circle .sun {
  position: absolute;
  width: 220px; height: 220px;
  border-radius: 50%;
  left: 50%; top: 52%; transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 50%, transparent 38%, currentColor 39% 41%, transparent 42%);
  opacity: 0.9;
}
.pv-circle .sun::before {
  content: ""; position: absolute; inset: 22%;
  border-radius: 50%; background: currentColor; opacity: 0.95;
}
.pv-circle .ttl {
  font-family: var(--sans);
  font-weight: 700; text-transform: uppercase;
  font-size: 22px; line-height: 1; letter-spacing: -0.02em;
  position: relative; z-index: 2;
}

/* ============================================================
   STACKING CARDS — portfolio
   ============================================================ */
.stack {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 7vw, 90px);
  padding-bottom: 10px;
}
.stack-card {
  position: sticky;
  top: var(--sc-top, 110px);
  height: min(74vh, 560px);
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 12px;
  overflow: hidden;
  display: block;
  box-shadow: 0 -20px 60px -30px #000000cc, 0 1px 0 0 #ffffff0a inset;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.stack-card .sc-bg {
  position: absolute; inset: 0;
  display: block; width: 100%; height: 100%;
  z-index: 0;
}
.stack-card .sc-scrim {
  position: absolute; inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(105deg, #0A0A0Aee 0%, #0A0A0Ab0 34%, #0A0A0A30 60%, #0A0A0A00 80%),
    linear-gradient(0deg, #0A0A0A66 0%, #0A0A0A00 40%);
}
.stack-card .sc-left {
  padding: clamp(28px, 3.4vw, 52px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  z-index: 2;
  height: 100%;
  pointer-events: none;
}
.stack-card .sc-left .sc-open { pointer-events: auto; }
.sc-top-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--mute);
  letter-spacing: 0.04em;
}
.sc-main { margin-top: auto; }
.sc-title {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: clamp(34px, 4.4vw, 76px);
  line-height: 0.9;
  letter-spacing: -0.03em;
  margin: 0 0 22px;
}
.sc-title .thin { font-weight: 200; }
.sc-meta {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  margin-bottom: 26px;
}
.sc-meta .chip {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--mute);
  padding: 5px 12px;
  border: 1px solid var(--line-2);
  border-radius: 100px;
}
.sc-foot {
  display: flex; align-items: center; gap: 16px;
}
.sc-open {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 13px 20px;
  border-radius: 100px;
  background: var(--fg);
  color: var(--bg);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: color .4s;
}
.sc-open::before {
  content: ""; position: absolute; inset: 0;
  background: var(--hi);
  transform: translateY(101%);
  transition: transform .45s cubic-bezier(.7,0,.2,1);
  z-index: -1;
}
.stack-card:hover .sc-open { color: #0A0A0A; }
.stack-card:hover .sc-open::before { transform: translateY(0); }
.sc-open .arr { transition: transform .35s; }
.stack-card:hover .sc-open .arr { transform: translate(3px,-3px); }
.sc-open.is-soon { cursor: default; }

.sc-art {
  position: relative;
  overflow: hidden;
  display: none;
}
.sc-art .panel { position: absolute; inset: 0; }

@media (max-width: 920px) {
  .stack-card {
    height: auto;
    min-height: 520px;
  }
  .sc-left { padding: 28px; }
}

/* ============================================================
   FOUNDER — editorial
   ============================================================ */
.fnd { display: grid; }
.fnd-cap { color: var(--mute); margin-bottom: 12px; }
.fnd-id {
  border-bottom: 1px solid var(--line);
  padding-bottom: 22px;
  margin-bottom: 4px;
}
.fnd-name {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(26px, 2.7vw, 42px);
  letter-spacing: -0.025em;
  line-height: 1.0;
  margin: 0;
}

.fnd-main {
  display: grid;
  grid-template-columns: 0.42fr 1.58fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
}
.fnd-figure { display: grid; gap: 14px; position: sticky; top: 110px; }
.fnd-slot {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  height: auto;
  border: 1px solid var(--line-2);
}
.fnd-photo { object-fit: cover; object-position: center top; filter: grayscale(1); }
.fnd-slot-cap {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--mute);
  border-top: 1px solid var(--line);
  padding-top: 12px;
}
.fnd-slot-cap .nm { color: var(--fg); }
.fnd-marks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  border-top: 1px solid var(--line);
  padding-top: 18px;
}
.fm { display: flex; flex-direction: column; gap: 4px; }
.fm-n {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(20px, 2vw, 30px);
  letter-spacing: -0.02em;
  color: var(--fg);
}
.fm-l { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--mute); }

.fnd-text { display: grid; gap: 22px; max-width: 42ch; padding-top: 6px; align-content: space-between; }
.fnd-text p { margin: 0; font-size: 16px; line-height: 1.62; font-weight: 300; color: var(--fg); }
.fnd-lede {
  font-family: var(--display) !important;
  font-weight: 400 !important;
  font-size: clamp(20px, 1.9vw, 30px) !important;
  line-height: 1.3 !important;
  letter-spacing: -0.015em;
  color: var(--fg) !important;
}
.fnd-ig {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 12px;
  align-self: start;
  padding: 14px 22px;
  border: 1px solid var(--line-2);
  border-radius: 100px;
  font-family: var(--mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--mute);
  transition: border-color .3s, color .3s;
}
.fnd-ig .ig-handle { color: var(--fg); transition: color .3s; }
.fnd-ig:hover { border-color: var(--hi); color: var(--hi); }
.fnd-ig:hover .ig-handle { color: var(--hi); }
.fnd-ig .arr { transition: transform .35s; }
.fnd-ig:hover .arr { transform: translate(3px, -3px); }

.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 22px;
  border: 1px solid var(--fg);
  border-radius: 100px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--fg);
  color: var(--bg);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: color .4s;
}
.btn::before {
  content: ""; position: absolute; inset: 0;
  background: var(--hi);
  transform: translateY(101%);
  transition: transform .45s cubic-bezier(.7,0,.2,1);
  z-index: -1;
}
.btn:hover { color: #0A0A0A; }
.btn:hover::before { transform: translateY(0); }
.btn.ghost { background: transparent; color: var(--fg); }
.btn.ghost:hover { color: #0A0A0A; }
.btn .arr { transition: transform .35s; }
.btn:hover .arr { transform: translate(3px, -3px); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact .cap { display: block; margin-bottom: 28px; }
.contact-headline {
  font-family: var(--display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: clamp(34px, 5vw, 68px);
  letter-spacing: -0.02em;
  line-height: 1.02;
  margin: 0;
}
.contact-headline .thin { font-weight: 700; }
.contact-headline .mute { color: var(--mute); }

/* CTA — editorial two-column */
.cta {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: end;
}
.cta-sub {
  margin: clamp(20px, 2.4vw, 30px) 0 0;
  max-width: 40ch;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.6;
  font-weight: 300;
  color: var(--fg);
}
.cta-action {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-end;
  text-align: right;
  justify-self: end;
}
.cta-action-row { display: inline-flex; align-items: flex-start; gap: 14px; }
.cta-verb {
  font-family: var(--display);
  font-weight: 500;
  font-size: clamp(28px, 3.4vw, 56px);
  letter-spacing: -0.03em;
  line-height: 0.98;
  position: relative;
  transition: color .35s;
}
.cta-verb::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -8px;
  height: 2px; background: currentColor;
  transform: scaleX(0); transform-origin: left;
  transition: transform .55s cubic-bezier(.7,0,.2,1);
}
.cta-action:hover .cta-verb { color: var(--hi); }
.cta-action:hover .cta-verb::after { transform: scaleX(1); }
.cta-arrow {
  font-size: clamp(22px, 2.2vw, 38px);
  line-height: 1;
  transition: transform .4s, color .35s;
}
.cta-action:hover .cta-arrow { transform: translate(5px, -5px); color: var(--hi); }
.cta-mail {
  align-self: flex-start;
  text-align: left;
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--mute); transition: color .35s;
}
.cta-action:hover .cta-mail { color: var(--fg); }

/* Transmit — Morse signal animation */
.transmit {
  margin-top: clamp(48px, 6vw, 88px);
  border-top: 1px solid var(--line);
  padding-top: clamp(22px, 2.6vw, 34px);
  display: flex;
  align-items: center;
  gap: clamp(20px, 4vw, 60px);
  flex-wrap: wrap;
}
.transmit-k, .transmit-word { color: var(--mute); font-size: 12px; letter-spacing: 0.14em; }
.transmit-k { text-transform: uppercase; }
.transmit-head { display: flex; align-items: center; gap: 12px; }
.transmit-word { margin-left: auto; }
.transmit-signal { display: flex; align-items: center; gap: clamp(14px, 1.6vw, 22px); }
.tx-letter { display: flex; align-items: center; gap: 8px; }
.tx {
  display: block;
  height: 9px;
  background: var(--mute-2);
  border-radius: 99px;
  transition: background .14s ease, box-shadow .28s ease, transform .14s ease;
}
.tx.dot { width: 9px; }
.tx.dash { width: 28px; }
.tx.on {
  background: var(--hi);
  box-shadow: 0 0 12px var(--hi);
  transform: scaleY(1.2);
}

.contact-email {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.2em;
  font-family: var(--display);
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(36px, 6vw, 96px);
  letter-spacing: -0.03em;
  position: relative;
  padding-bottom: 8px;
  line-height: 1;
}
.contact-email::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 2px; background: currentColor;
  transform: scaleX(1); transform-origin: left;
  transition: transform .55s cubic-bezier(.7,0,.2,1);
}
.contact-email:hover { color: var(--hi); }
.contact-email:hover::after { transform: scaleX(0); transform-origin: right; }
.contact-email .ce-arr { font-size: 0.42em; line-height: 1; transition: transform .35s; }
.contact-email:hover .ce-arr { transform: translate(4px, -4px); }

.contact-grid {
  margin-top: 96px;
  display: grid;
  grid-template-columns: repeat(4, max-content);
  justify-content: start;
  gap: clamp(48px, 6vw, 96px);
  border-top: 1px solid var(--line);
  padding-top: 32px;
}
.contact-card .k {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
}
.contact-card .v {
  font-family: var(--sans);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(16px, 1.2vw, 19px);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.contact-card a.v { display: inline-flex; align-items: baseline; gap: 6px; transition: color .25s; }
.contact-card a.v:hover { color: var(--hi); }
.contact-card a.v .arr { transition: transform .35s; font-size: 0.85em; }
.contact-card a.v:hover .arr { transform: translate(3px, -3px); }

/* ============================================================
   OUTRO + FOOTER
   ============================================================ */
.outro {
  padding-block: clamp(40px, 6vw, 96px);
  position: relative;
}
.outro .word {
  font-family: var(--display);
  font-weight: 800;
  text-transform: uppercase;
  font-size: clamp(120px, 27vw, 408px);
  line-height: 0.82;
  letter-spacing: -0.06em;
  margin: 0;
  text-align: center;
  transform: translateX(-0.064em);
  white-space: nowrap;
}
.outro .sub {
  margin-top: 16px;
  display: flex; justify-content: space-between;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--mute);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.foot {
  padding-block: clamp(36px, 5vw, 64px) 28px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: 1.2fr 1.4fr 1fr 1fr;
  gap: 24px 32px;
  align-items: start;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--mute);
  letter-spacing: 0.04em;
}
.foot-col { display: flex; flex-direction: column; gap: 10px; }
.foot-end { align-items: flex-end; text-align: right; }
.foot-k {
  font-family: var(--sans);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 11px;
  color: var(--fg);
  margin-bottom: 4px;
}
.foot-v { color: var(--mute); text-transform: none; letter-spacing: 0.02em; }
.foot-v.link { transition: color .25s; }
.foot-v.link:hover { color: var(--hi); }

/* ============================================================
   responsive
   ============================================================ */
@media (max-width: 920px) {
  .nav-links { display: none; }
  .nav-cta .nav-pill { display: none; }
  .hero-meta { grid-template-columns: 1fr; }
  .hero-meta-stats { flex-wrap: wrap; gap: 28px 40px; }
  .positioning { grid-template-columns: 1fr; gap: 28px; }
  .who { grid-template-columns: 1fr; gap: 24px; }
  .who-list { grid-template-columns: 1fr; }
  .who-list li:nth-child(2n) { padding-left: 4px; }
  .cl-head { grid-template-columns: 40px 1fr 24px; }
  .cl-head .cl-desc { display: none; }
  .cl-grid { grid-template-columns: 1fr; padding-left: 40px; }
  .cl-group-head { grid-template-columns: 1fr; gap: 12px; }
  .ci-desc { max-height: 60px; opacity: 0.7; margin-top: 6px; }
  .principles { grid-template-columns: 1fr 1fr; }
  .belief { max-width: none; }
  .case { grid-template-columns: 30px 1fr 70px; gap: 16px; }
  .case .meta, .case .year { display: none; }
  .fnd-main { grid-template-columns: 1fr; }
  .fnd-figure { max-width: 420px; }
  .fnd-top { grid-template-columns: 1fr; align-items: start; gap: 8px; }
  .fnd-name { text-align: left; }
  .cta { grid-template-columns: 1fr; align-items: start; gap: 36px; }
  .transmit-word { margin-left: 0; }
  .contact-grid { grid-template-columns: 1fr 1fr; }
  .foot { grid-template-columns: 1fr 1fr; }
  .foot-end { align-items: flex-start; text-align: left; }
  .hero-title .row.indent, .contact-headline .indent { padding-left: 0; }
}
