:root {
  --night: #161616;
  --night-soft: #202020;
  --orange: #ff6000;
  --orange-2: #ff7900;
  --orange-3: #ff9100;
  --white: #ffffff;
  --gray: #a7a7a7;
  --gray-light: #ececec;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--white);
  background: var(--night);
  font-family: "Inter", sans-serif;
  line-height: 1.55;
}

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

.topbar,
main,
footer {
  width: min(1180px, calc(100% - 48px));
  margin-inline: auto;
}

.topbar {
  min-height: 92px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgb(255 255 255 / 12%);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.brand img {
  width: 44px;
  height: 44px;
  object-fit: contain;
}

.brand strong {
  color: var(--orange);
}

.top-link {
  padding: 11px 18px;
  border: 1px solid rgb(255 255 255 / 24%);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

.hero {
  min-height: 650px;
  display: grid;
  grid-template-columns: 1.14fr 0.86fr;
  gap: 70px;
  align-items: center;
  padding: 82px 0 96px;
}

.eyebrow {
  margin: 0 0 18px;
  color: var(--orange-2);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

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

h1,
h2,
h3 {
  letter-spacing: -0.055em;
}

h1 {
  max-width: 760px;
  margin-bottom: 28px;
  font-size: clamp(48px, 6.2vw, 82px);
  line-height: 0.98;
  font-weight: 900;
}

h1 span {
  color: var(--orange);
}

.provocative-title {
  max-width: 790px;
  font-size: clamp(42px, 5.1vw, 68px);
  line-height: 1.04;
}

h2 {
  margin-bottom: 20px;
  font-size: clamp(34px, 4.2vw, 54px);
  line-height: 1.05;
  font-weight: 850;
}

.lead {
  max-width: 640px;
  margin-bottom: 34px;
  color: #c9c9c9;
  font-size: 18px;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 22px;
}

.hero-actions > span {
  color: var(--gray);
  font-size: 13px;
}

.button {
  min-height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 25px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 800;
}

.primary {
  background: linear-gradient(135deg, var(--orange), var(--orange-3));
  box-shadow: 0 12px 34px rgb(255 96 0 / 22%);
}

.hero-panel {
  position: relative;
  overflow: hidden;
  padding: 38px;
  background: linear-gradient(145deg, #242424, #191919);
  border: 1px solid rgb(255 255 255 / 13%);
  border-radius: 20px;
  box-shadow: 0 34px 80px rgb(0 0 0 / 35%);
}

.panel-glow {
  position: absolute;
  width: 190px;
  height: 190px;
  top: -105px;
  right: -70px;
  background: var(--orange);
  border-radius: 50%;
  filter: blur(58px);
  opacity: 0.28;
}

.hero-panel > p {
  margin-bottom: 16px;
  color: var(--orange-2);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.hero-panel > strong {
  display: block;
  margin-bottom: 35px;
  font-size: 28px;
  line-height: 1.2;
  letter-spacing: -0.04em;
}

.hero-panel ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero-panel li {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 12px;
  padding: 17px 0;
  border-top: 1px solid rgb(255 255 255 / 11%);
  font-weight: 600;
}

.hero-panel li span {
  color: var(--orange);
  font-weight: 800;
}

.provocation {
  position: relative;
  overflow: hidden;
}

.provocation-first {
  display: grid;
  grid-template-columns: 0.35fr 1.65fr;
  gap: 48px;
  align-items: center;
  margin-bottom: 90px;
  padding: 30px 34px;
  background: #202020;
  border: 1px solid rgb(255 96 0 / 34%);
  border-left: 5px solid var(--orange);
  border-radius: 8px;
}

.provocation-first::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  right: -80px;
  top: -110px;
  background: var(--orange);
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.18;
}

.provocation > span,
.provocation-growth span {
  color: var(--orange);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.provocation-first p {
  margin: 0;
  font-size: clamp(22px, 2.5vw, 32px);
  font-weight: 750;
  line-height: 1.25;
  letter-spacing: -0.035em;
}

.provocation-first strong {
  color: var(--orange);
}

.context {
  width: calc(100% + 80px);
  margin-left: -40px;
  display: grid;
  grid-template-columns: 70px 1fr 0.8fr;
  gap: 54px;
  align-items: start;
  padding: 90px 40px;
  color: var(--night);
  background: var(--white);
  border-radius: 24px;
}

.section-number {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  color: var(--white);
  background: var(--orange);
  border-radius: 50%;
  font-size: 13px;
  font-weight: 800;
}

.eyebrow.dark {
  color: var(--orange);
}

.section-text {
  padding-top: 37px;
  color: #5a5a5a;
  font-size: 17px;
}

.work {
  padding: 110px 0;
}

.section-heading {
  display: grid;
  grid-template-columns: 1.2fr 0.65fr;
  gap: 80px;
  align-items: end;
  margin-bottom: 50px;
}

.section-heading > p {
  color: var(--gray);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.card-grid article {
  min-height: 280px;
  display: flex;
  flex-direction: column;
  padding: 30px;
  background: var(--night-soft);
  border: 1px solid rgb(255 255 255 / 10%);
  border-radius: 10px;
}

.card-number {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  margin-bottom: auto;
  color: var(--orange);
  border: 1px solid rgb(255 96 0 / 45%);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 800;
}

.card-grid h3 {
  margin: 40px 0 10px;
  font-size: 22px;
  line-height: 1.2;
}

.card-grid p {
  margin-bottom: 0;
  color: var(--gray);
  font-size: 15px;
}

.journey {
  width: calc(100% + 80px);
  margin: 0 0 110px -40px;
  padding: 88px 40px 42px;
  color: var(--night);
  background: var(--white);
  border-radius: 24px;
}

.journey-intro {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 80px;
  align-items: end;
  margin-bottom: 52px;
}

.journey-intro h2 {
  max-width: 720px;
  margin-bottom: 0;
}

.journey-intro > p {
  margin-bottom: 5px;
  color: #565656;
  font-size: 17px;
}

.journey-flow {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1px solid #dadada;
  border-radius: 14px;
  overflow: hidden;
}

.journey-flow article {
  min-width: 0;
  padding: 24px 20px 26px;
  background: #fafafa;
  border-right: 1px solid #dadada;
}

.journey-flow article:last-child {
  border-right: 0;
}

.journey-flow article:nth-child(even) {
  background: #f4f4f4;
}

.journey-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 28px;
}

.journey-topline span {
  color: var(--orange);
  font-size: 13px;
  font-weight: 900;
}

.journey-topline small {
  padding: 6px 9px;
  color: var(--white);
  background: var(--night);
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  white-space: nowrap;
}

.journey-flow h3 {
  margin-bottom: 12px;
  font-size: 23px;
  line-height: 1.1;
}

.journey-flow p {
  min-height: 105px;
  margin-bottom: 24px;
  color: #5f5f5f;
  font-size: 13px;
  line-height: 1.45;
}

.journey-flow strong {
  display: block;
  margin-bottom: 10px;
  color: var(--orange);
  font-size: 10px;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.journey-flow ul {
  margin: 0;
  padding: 0 0 0 17px;
}

.journey-flow li {
  margin-bottom: 9px;
  color: #323232;
  font-size: 12px;
  line-height: 1.4;
}

.journey-flow li::marker {
  color: var(--orange);
}

.journey-principles {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  margin-top: 18px;
  overflow: hidden;
  background: #dedede;
  border: 1px solid #dedede;
  border-radius: 8px;
}

.journey-principles span {
  padding: 13px 10px;
  color: var(--night);
  background: var(--white);
  font-size: 10px;
  font-weight: 850;
  text-align: center;
  text-transform: uppercase;
}

.provocation-growth {
  display: grid;
  grid-template-columns: 1fr 0.9fr;
  gap: 70px;
  align-items: center;
  margin-bottom: 22px;
  padding: 42px;
  background: linear-gradient(130deg, var(--orange), var(--orange-3));
  border-radius: 14px;
  box-shadow: 0 22px 60px rgb(255 96 0 / 17%);
}

.provocation-growth span {
  color: var(--night);
}

.provocation-growth p {
  max-width: 600px;
  margin: 10px 0 0;
  color: rgb(22 22 22 / 78%);
  font-size: 17px;
}

.provocation-growth > strong {
  padding-left: 34px;
  color: var(--night);
  border-left: 1px solid rgb(22 22 22 / 28%);
  font-size: 21px;
  line-height: 1.35;
  letter-spacing: -0.025em;
}

.iceberg {
  margin-bottom: 110px;
  padding: 88px 0 0;
}

.iceberg-heading {
  display: grid;
  grid-template-columns: 1.15fr 0.7fr;
  gap: 90px;
  align-items: end;
  margin-bottom: 55px;
}

.iceberg-heading h2 {
  margin-bottom: 0;
}

.iceberg-heading h2 span {
  color: var(--orange);
}

.iceberg-heading > p {
  margin-bottom: 6px;
  color: var(--gray);
  font-size: 16px;
}

.iceberg-board {
  margin: 0;
}

.iceberg-board a {
  display: block;
  overflow: hidden;
  background: var(--white);
  border: 1px solid rgb(255 255 255 / 16%);
  border-radius: 16px;
  box-shadow: 0 32px 90px rgb(0 0 0 / 36%);
}

.iceberg-board img {
  width: 100%;
  height: auto;
  display: block;
}

.iceberg-board figcaption {
  margin-top: 13px;
  color: var(--gray);
  font-size: 12px;
  text-align: center;
}

.iceberg-layout {
  display: grid;
  grid-template-columns: 0.76fr 1.24fr;
  overflow: hidden;
  background: var(--night-soft);
  border: 1px solid rgb(255 255 255 / 11%);
  border-radius: 20px;
}

.iceberg-visual {
  position: relative;
  min-height: 690px;
  overflow: hidden;
  background: #0e0e0e;
  border-right: 1px solid rgb(255 255 255 / 11%);
}

.iceberg-sky {
  position: relative;
  height: 33%;
  background:
    radial-gradient(circle at 50% 120%, rgb(255 121 0 / 20%), transparent 55%),
    linear-gradient(#202020, #161616);
}

.iceberg-tip {
  position: absolute;
  width: 62%;
  height: 74%;
  left: 19%;
  bottom: -2px;
  background: linear-gradient(145deg, var(--orange-3), var(--orange));
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  filter: drop-shadow(0 0 28px rgb(255 96 0 / 22%));
}

.waterline {
  position: relative;
  z-index: 3;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--orange-2), transparent);
  box-shadow: 0 0 22px rgb(255 96 0 / 55%);
}

.waterline span {
  position: absolute;
  right: 16px;
  top: -23px;
  color: var(--orange-3);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.iceberg-depth {
  position: relative;
  height: 67%;
  background:
    radial-gradient(circle at 50% 0, rgb(255 96 0 / 12%), transparent 58%),
    linear-gradient(#151515, #090909);
}

.iceberg-base {
  position: absolute;
  width: 78%;
  height: 92%;
  left: 11%;
  top: 0;
  background: linear-gradient(160deg, #3a3a3a 0%, #202020 46%, #111 100%);
  clip-path: polygon(0 0, 100% 0, 78% 100%, 23% 88%);
  border-top: 1px solid var(--orange);
}

.iceberg-base::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, transparent 30%, rgb(255 96 0 / 13%) 50%, transparent 68%);
}

.iceberg-percent {
  position: absolute;
  z-index: 4;
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.iceberg-percent strong {
  font-size: 47px;
  font-weight: 900;
  letter-spacing: -0.06em;
}

.iceberg-percent span {
  margin-top: 8px;
  color: var(--orange-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.visible-percent {
  left: 25px;
  bottom: 24px;
}

.hidden-percent {
  right: 24px;
  bottom: 42px;
  align-items: flex-end;
}

.iceberg-content {
  padding: 34px;
}

.iceberg-content article {
  padding: 26px;
  border-radius: 12px;
}

.visible-layer {
  margin-bottom: 18px;
  background: #292929;
  border: 1px solid rgb(255 255 255 / 10%);
}

.hidden-layer {
  background: #181818;
  border: 1px solid rgb(255 96 0 / 24%);
}

.layer-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 15px;
  margin-bottom: 22px;
}

.layer-title span {
  color: var(--gray);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.layer-title strong {
  color: var(--orange);
  font-size: 12px;
}

.layer-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.layer-tags span {
  padding: 9px 12px;
  background: #171717;
  border: 1px solid rgb(255 255 255 / 12%);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
}

.system-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 22px;
}

.system-grid div {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  padding: 10px 0;
  border-bottom: 1px solid rgb(255 255 255 / 8%);
}

.system-grid b {
  color: var(--white);
  font-size: 12px;
}

.system-grid small {
  color: #909090;
  font-size: 10px;
}

.iceberg-conclusion {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  margin-top: 18px;
  padding: 22px 26px;
  color: var(--night);
  background: linear-gradient(135deg, var(--orange), var(--orange-3));
  border-radius: 10px;
}

.iceberg-conclusion strong {
  font-size: 17px;
}

.iceberg-conclusion p {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
}

.conversation {
  position: relative;
  display: grid;
  grid-template-columns: 70px 1fr 0.85fr;
  gap: 45px;
  align-items: center;
  margin-bottom: 100px;
  padding: 58px;
  background: linear-gradient(130deg, var(--orange), var(--orange-3));
  border-radius: 20px;
}

.conversation-icon {
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  background: var(--night);
  border-radius: 12px;
}

.conversation-icon img {
  width: 50px;
  height: 50px;
  object-fit: contain;
}

.conversation .eyebrow {
  color: var(--night);
}

.conversation-copy h2 {
  font-size: clamp(34px, 4vw, 50px);
}

.conversation-copy > p:not(.eyebrow) {
  color: rgb(22 22 22 / 75%);
}

.conversation-copy .note {
  margin-bottom: 0;
  color: var(--night) !important;
  font-weight: 800;
}

.cta-card {
  padding: 30px;
  color: var(--night);
  background: var(--white);
  border-radius: 12px;
  box-shadow: 0 18px 48px rgb(45 18 0 / 18%);
}

.cta-card span {
  display: block;
  margin-bottom: 12px;
  color: var(--orange);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.cta-card strong {
  display: block;
  margin-bottom: 14px;
  font-size: 21px;
  line-height: 1.3;
  letter-spacing: -0.03em;
}

.cta-card p {
  margin-bottom: 0;
  color: #666;
  font-size: 14px;
}

footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 30px 0 45px;
  border-top: 1px solid rgb(255 255 255 / 12%);
}

footer p {
  margin: 0;
  color: var(--gray);
  font-size: 13px;
}

@media (max-width: 820px) {
  .topbar,
  main,
  footer {
    width: min(100% - 28px, 1180px);
  }

  .hero,
  .context,
  .section-heading,
  .conversation {
    grid-template-columns: 1fr;
  }

  .topbar {
    min-height: 78px;
  }

  .brand {
    font-size: 16px;
  }

  .brand img {
    width: 38px;
    height: 38px;
  }

  .top-link {
    padding: 9px 12px;
    font-size: 11px;
  }

  .hero {
    min-height: auto;
    gap: 50px;
    padding: 62px 0 76px;
  }

  h1 {
    font-size: 48px;
  }

  .provocative-title {
    font-size: 39px;
  }

  .hero-actions {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
  }

  .hero-panel {
    padding: 28px 24px;
  }

  .provocation-first,
  .provocation-growth {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .provocation-first {
    margin-bottom: 70px;
    padding: 25px 22px;
  }

  .provocation-first p {
    font-size: 24px;
  }

  .provocation-growth {
    padding: 30px 22px;
  }

  .provocation-growth > strong {
    padding: 20px 0 0;
    border-top: 1px solid rgb(22 22 22 / 28%);
    border-left: 0;
    font-size: 19px;
  }

  .context {
    width: calc(100% + 28px);
    margin-left: -14px;
    gap: 22px;
    padding: 65px 20px;
    border-radius: 16px;
  }

  .section-text {
    padding-top: 0;
  }

  .work {
    padding: 80px 0;
  }

  .section-heading {
    gap: 15px;
  }

  .card-grid {
    grid-template-columns: 1fr;
  }

  .card-grid article {
    min-height: 245px;
  }

  .journey {
    width: calc(100% + 28px);
    margin: 0 0 80px -14px;
    padding: 68px 14px 24px;
    border-radius: 16px;
  }

  .journey-intro {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-bottom: 38px;
  }

  .journey-flow {
    grid-template-columns: 1fr;
    border-radius: 10px;
  }

  .journey-flow article,
  .journey-flow article:last-child {
    padding: 26px 22px;
    border-right: 0;
    border-bottom: 1px solid #dadada;
  }

  .journey-flow article:last-child {
    border-bottom: 0;
  }

  .journey-flow p {
    min-height: auto;
  }

  .journey-principles {
    grid-template-columns: 1fr;
  }

  .iceberg {
    margin-bottom: 80px;
    padding-top: 72px;
  }

  .iceberg-heading,
  .iceberg-layout {
    grid-template-columns: 1fr;
  }

  .iceberg-heading {
    gap: 18px;
    margin-bottom: 38px;
  }

  .iceberg-board a {
    border-radius: 10px;
  }

  .iceberg-visual {
    min-height: 520px;
    border-right: 0;
    border-bottom: 1px solid rgb(255 255 255 / 11%);
  }

  .iceberg-content {
    padding: 16px;
  }

  .iceberg-content article {
    padding: 22px 18px;
  }

  .layer-title {
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
  }

  .system-grid {
    grid-template-columns: 1fr;
  }

  .iceberg-conclusion {
    align-items: flex-start;
    flex-direction: column;
    gap: 7px;
  }

  .conversation {
    gap: 28px;
    margin-bottom: 75px;
    padding: 34px 22px;
  }

  .conversation-icon {
    width: 54px;
    height: 54px;
  }

  footer {
    align-items: flex-start;
    flex-direction: column;
    gap: 18px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .button,
  .top-link,
  .card-grid article {
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
  }

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

  .card-grid article:hover {
    transform: translateY(-4px);
    border-color: rgb(255 96 0 / 50%);
  }
}
