/* Landing page — Bent-derived editorial index */

/* hero */
.hero { padding-top: calc(var(--nav-h) + clamp(28px, 5vw, 72px)); }
.hero h1 {
  font-size: clamp(52px, 10.6vw, 168px);
  font-weight: 750;
  letter-spacing: -0.038em;
  line-height: 0.95;
}
.hero h1 .dot { color: var(--accent); }
.hero__role { display: inline-block; transition: opacity .26s var(--ease), transform .26s var(--ease); }
.hero__role.swap { opacity: 0; transform: translateY(8px); }
/* entrance */
@keyframes heroRise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
.hero h1 { animation: heroRise .72s var(--ease) both; }
.hero__meta { animation: heroRise .72s var(--ease) .12s both; }
.hero__band img { will-change: transform; }
@media (prefers-reduced-motion: reduce) {
  .hero h1, .hero__meta { animation: none; }
  .hero__role { transition: none; }
}
.hero__meta {
  display: flex; justify-content: space-between; align-items: center; gap: 12px 16px;
  flex-wrap: wrap;
  padding: 18px 0 14px;
}
.hero__scroll { font-size: 14px; font-weight: 520; color: var(--ink-2); }
.hero__band {
  border-top: 1px solid var(--rule-strong);
  border-bottom: 1px solid var(--rule-strong);
}
.hero__band .media-frame {
  aspect-ratio: 16 / 8.2;
  max-height: 78vh;
}
.hero__band img { object-position: 63% 26%; }
@media (max-width: 760px) {
  .hero__band .media-frame { aspect-ratio: 1 / 0.74; max-height: 56vh; }
  .hero__band img { object-position: 61% 4%; }
}

/* statement */
.intro { display: grid; grid-template-columns: minmax(0, 8.4fr) minmax(200px, 3.6fr); gap: clamp(24px, 4vw, 72px); }
.intro__side { display: flex; flex-direction: column; align-items: flex-start; gap: 20px; border-left: 1px solid var(--rule); padding-left: clamp(18px, 2vw, 32px); }
.intro__side .links { display: flex; flex-direction: column; gap: 8px; font-size: 14.5px; font-weight: 520; }
.intro__side .links a { border-bottom: 1px solid var(--rule); padding: 7px 0; width: 100%; display: flex; justify-content: space-between; align-items: center; }
.intro__side .links a .ico { font-size: 17px; color: var(--ink-2); transition: color .2s, transform .25s var(--ease); }
.intro__side .links a:hover .ico { color: var(--ink); transform: translate(2px, -2px); }
@media (max-width: 760px) {
  .intro { grid-template-columns: 1fr; }
  .intro__side { border-left: 0; border-top: 1px solid var(--rule); padding-left: 0; padding-top: 22px; }
}

/* what i do */
.services { display: grid; grid-template-columns: minmax(180px, 3.2fr) minmax(0, 8.8fr); gap: clamp(24px, 4vw, 72px); }
.services__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.services__head .arr { font-size: 24px; color: var(--ink); line-height: 1; }
.services__grid { display: grid; grid-template-columns: 1fr 1fr; }
.services__grid > div { padding: clamp(18px, 2.4vw, 34px) clamp(18px, 2.4vw, 34px) clamp(20px, 2.6vw, 38px); border-top: 1px solid var(--rule); }
.services__grid > div:nth-child(odd) { border-right: 1px solid var(--rule); padding-left: 0; }
.services__grid > div:nth-child(-n+2) { border-top: 0; padding-top: 0; }
.services__grid h3 { font-size: clamp(18px, 1.7vw, 22px); font-weight: 640; letter-spacing: -0.02em; margin-bottom: 10px; }
.services__grid p { font-size: 14.5px; color: var(--ink-2); max-width: 40ch; }
@media (max-width: 760px) {
  .services { grid-template-columns: 1fr; gap: 20px; }
  .services__grid { grid-template-columns: 1fr; }
  .services__grid > div { border-right: 0 !important; padding-left: 0; }
  .services__grid > div:nth-child(2) { border-top: 1px solid var(--rule); padding-top: 20px; }
}

/* work marquee */
.marquee { overflow: clip; border-top: 1px solid var(--rule-strong); padding: clamp(10px, 1.6vw, 26px) 0; }
.marquee__track {
  display: flex; gap: .35em; white-space: nowrap; width: max-content;
  font-size: clamp(64px, 13vw, 210px); font-weight: 750; letter-spacing: -0.04em; line-height: 1;
  animation: marq 26s linear infinite;
  animation-play-state: paused;
}
.marquee.run .marquee__track { animation-play-state: running; }
.marquee__track span { display: inline-block; }
.marquee__track .o { color: transparent; -webkit-text-stroke: 1.5px var(--ink); }
@keyframes marq { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* featured project index */
.works { counter-reset: workn; }
.work-row {
  display: grid;
  grid-template-columns: minmax(54px, 1.2fr) minmax(0, 6.2fr) minmax(0, 4.6fr);
  gap: clamp(16px, 2.6vw, 48px);
  align-items: center;
  border-top: 1px solid var(--rule-strong);
  padding: clamp(22px, 3.2vw, 44px) var(--gutter);
  position: relative;
}
.work-row:last-child { border-bottom: 1px solid var(--rule-strong); }
.work-row__n { counter-increment: workn; font-size: clamp(15px, 1.4vw, 19px); font-weight: 560; color: var(--ink-2); }
.work-row__n::before { content: '(' counter(workn, decimal-leading-zero) ')'; }
.work-row__body h3 {
  font-size: clamp(30px, 4.6vw, 68px);
  font-weight: 700; letter-spacing: -0.032em; line-height: 1.02;
  transition: color .25s;
}
.work-row__body .meta { display: flex; flex-wrap: wrap; gap: 8px 20px; margin-top: 12px; font-size: 13.5px; color: var(--ink-2); }
.work-row__body .meta .tag { color: var(--ink); font-weight: 560; }
.work-row__body .meta .tag::before { content: ''; display: inline-block; width: 9px; height: 9px; border-radius: 2px; background: var(--wa, var(--accent)); margin-right: 7px; }
.work-row__media { aspect-ratio: 16 / 10.5; }
.work-row__media img { transition: transform .7s var(--ease); }
.work-row:hover .work-row__media img { transform: scale(1.035); }
.work-row:hover .work-row__body h3 { color: var(--wa, var(--accent)); }
.work-row__link::after { content: ''; position: absolute; inset: 0; }
@media (max-width: 760px) {
  .work-row { grid-template-columns: 1fr; gap: 14px; padding-top: 26px; padding-bottom: 30px; }
  .work-row__media { order: -1; aspect-ratio: 16 / 10; }
}

/* more strip */
.more-strip { display: grid; grid-template-columns: 1fr 1fr; }
.more-strip a {
  display: flex; justify-content: space-between; align-items: baseline; gap: 14px;
  padding: clamp(22px, 3vw, 40px) var(--gutter);
}
.more-strip a:first-child { border-right: 1px solid var(--rule-strong); }
.more-strip h3 { font-size: clamp(22px, 2.6vw, 38px); font-weight: 660; letter-spacing: -0.025em; }
.more-strip .plabel { color: var(--ink-2); }
.more-strip a:hover h3 { color: var(--accent); }
@media (max-width: 760px) {
  .more-strip { grid-template-columns: 1fr; }
  .more-strip a:first-child { border-right: 0; border-bottom: 1px solid var(--rule-strong); }
}
