﻿/* hurtblast.ru вЂ” full-width fluid canvas based on a 1440 Г— 2675 design */

/* ===== Reset & base ============================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior-x: none;
  scrollbar-gutter: auto;
  scrollbar-width: none;
  scrollbar-color: transparent transparent;
  --about-chrome-color: #000;
  --about-mobile-bar-bg: #fff;
}
html.project-open {
  overflow: hidden;
  scrollbar-gutter: auto;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar,
.project-page::-webkit-scrollbar {
  width: 0;
  height: 0;
}
html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track,
.project-page::-webkit-scrollbar-track {
  background: transparent;
}
html::-webkit-scrollbar-button,
body::-webkit-scrollbar-button,
.project-page::-webkit-scrollbar-button {
  display: none;
  width: 0;
  height: 0;
}
html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb,
.project-page::-webkit-scrollbar-thumb {
  background: transparent;
  border: 0;
  border-radius: 999px;
}
html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover,
.project-page::-webkit-scrollbar-thumb:hover {
  background: transparent;
}

body {
  background: #fff;
  color: #000;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 15px;
  line-height: 20px;
  font-weight: 400;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  overscroll-behavior-x: none;
  scrollbar-width: none;
  scrollbar-color: transparent transparent;
}
body::before {
  content: "";
  position: fixed;
  inset: 0 auto 0 0;
  width: 100dvw;
  z-index: 150;
  background: #000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 520ms cubic-bezier(.16,.82,.18,1);
}
body.project-open::before {
  opacity: .12;
}

a { color: inherit; text-decoration: none; }
a:focus-visible,
button:focus-visible {
  outline: 2px solid #000;
  outline-offset: 4px;
  border-radius: 2px;
}

img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; }

::selection { background: #000; color: #fff; }

/* ===== Reference-style hover scrollbar ========================= */
.c-scrollbar {
  position: fixed;
  top: 0;
  right: 0;
  width: 11px;
  height: 100dvh;
  z-index: 230;
  opacity: 0;
  pointer-events: none;
  cursor: default;
  touch-action: none;
  transform-origin: 100% 50%;
  transform: scaleX(1);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
  will-change: opacity, transform;
}
.c-scrollbar.is-scrollable {
  pointer-events: auto;
}
.c-scrollbar.is-scrollable:hover,
.c-scrollbar.is-scrollable.is-hovered,
.c-scrollbar.is-scrollable.is-dragging {
  opacity: 1;
  transform: scaleX(1.45);
}
.c-scrollbar.is-scrollable.is-scrolling {
  opacity: .82;
}
.c-scrollbar.is-scrollable.is-scrolling:hover,
.c-scrollbar.is-scrollable.is-scrolling.is-hovered {
  opacity: 1;
}
.c-scrollbar:not(.is-scrollable) {
  pointer-events: none;
}
.c-scrollbar_thumb {
  position: absolute;
  top: 0;
  left: 2px;
  right: 2px;
  height: var(--scroll-thumb-h, 48px);
  min-height: 28px;
  border-radius: 999px;
  background: #000;
  opacity: .5;
  cursor: grab;
  transform: translate3d(0, var(--scroll-thumb-y, 2px), 0);
  will-change: transform, height;
}
.c-scrollbar.is-dragging .c-scrollbar_thumb {
  cursor: grabbing;
}
html.is-scrollbar-dragging,
html.is-scrollbar-dragging * {
  user-select: none;
  cursor: grabbing !important;
}
html.is-scrollbar-dragging {
  scroll-behavior: auto;
}
.c-scrollbar.is-dragging {
  transition: none;
}

/* ===== Fluid units =============================================
   --u : 1 design pixel, scales with viewport (content area width / 1392)
   --o : zero-x offset so the 24px gutter stays a fixed 24px regardless of --u
   ================================================================ */
:root {
  --vw: 100vw;
  --u: calc((var(--vw) - 48px) / 1392);
  --o: calc(24px - 24 * var(--u));
  --footer-h: calc(68 * var(--u));
  --project-bg-blur: calc(12 * var(--u));
}

/* Lock to design size on wide displays вЂ” no upscaling beyond Figma 1440 */
@media (min-width: 1440px) {
  :root { --u: 1px; --o: 0px; }
  .canvas { display: block; width: var(--vw); }
}

/* Below ~720 we switch to a stacked flow layout (see bottom of file) */
/* ===== Footer =================================================== */
.footer {
  position: absolute;
  left: calc(var(--o) + 24 * var(--u));
  right: calc(var(--o) + 24 * var(--u));
  top: calc(var(--o) + 2379 * var(--u));
  height: var(--footer-h);
  z-index: 20;
  background: #fff;
}
.footer-rule {
  border: 0;
  border-top: 1px solid #000;
  margin: 0;
  width: 100%;
}

.footer-meta {
  position: absolute;
  top: calc(48 * var(--u));
  left: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
}

/* ===== Contact drawer =========================================== */
.drawer-scrim {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0);
  z-index: 240;
  pointer-events: none;
  transition: none;
}
.drawer-scrim.is-open {
  background: transparent;
  backdrop-filter: none;
  pointer-events: auto;
}

.drawer {
  position: fixed;
  top: calc(var(--o) + 52 * var(--u));
  right: 24px;
  width: calc(280 * var(--u));
  min-width: 280px;
  height: auto;
  background: #000;
  color: #fff;
  z-index: 250;
  border-radius: calc(6 * var(--u));
  padding: calc(16 * var(--u));
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: calc(24 * var(--u));
  opacity: 1;
  pointer-events: none;
  overflow: hidden;
  clip-path: inset(0 0 100% 0 round calc(6 * var(--u)));
  filter: blur(calc(2 * var(--u)));
  transform-origin: 50% 0;
  will-change: clip-path, filter;
  transition:
    clip-path 360ms cubic-bezier(.32,0,.24,1),
    filter 360ms cubic-bezier(.32,0,.24,1);
  box-shadow: none;
}
.drawer.is-open {
  pointer-events: auto;
  clip-path: inset(0 0 0 0 round calc(6 * var(--u)));
  filter: blur(0);
  transition:
    clip-path 520ms cubic-bezier(.16,.82,.18,1),
    filter 520ms cubic-bezier(.16,.82,.18,1);
}

.drawer ::selection { background: #fff; color: #000; }

.drawer-head {
  display: none;
}
.drawer-title {
  margin: 0;
  color: #fff;
  font-size: 15px;
  line-height: 20px;
  font-weight: 400;
}

.drawer-main {
  position: relative;
  display: block;
  width: 100%;
  opacity: 0;
  filter: blur(calc(3 * var(--u)));
  transition:
    opacity 260ms ease,
    filter 260ms ease;
}

.drawer-links {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(2 * var(--u));
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
}
.drawer-links a {
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: calc(40 * var(--u));
  line-height: calc(44 * var(--u));
  letter-spacing: 0;
  color: #fff;
  width: max-content;
  max-width: 100%;
  transition: opacity 180ms ease;
}
.drawer-links:has(a:hover) a:not(:hover),
.drawer-links:has(a:focus-visible) a:not(:focus-visible) {
  opacity: .62;
}
.drawer-links a:hover,
.drawer-links a:focus-visible {
  opacity: 1;
  box-shadow: none;
}
.drawer-links a:focus-visible {
  outline-color: #fff;
}

.drawer-foot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: calc(4 * var(--u));
  padding-top: 0;
  opacity: 0;
  filter: blur(calc(3 * var(--u)));
  transition:
    opacity 260ms ease,
    filter 260ms ease;
}
.drawer.is-open .drawer-main {
  opacity: 1;
  filter: blur(0);
  transition-delay: 140ms, 140ms;
}
.drawer.is-open .drawer-foot {
  opacity: 1;
  filter: blur(0);
  transition-delay: 220ms, 220ms;
}
.drawer-talk {
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
}
.drawer-email {
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  box-shadow: inset 0 -1px 0 #fff;
  transition: opacity 200ms ease;
}
.drawer-email:hover,
.drawer-email:focus-visible {
  opacity: .74;
}
.drawer-socials {
  display: none;
}


@media (max-width: 1024px) {
  :root { --u: 1px; --o: 0px; }
}

/* ===== Canvas =================================================== */
.canvas {
  display: block;
  position: relative;
  width: var(--vw);
  height: calc(var(--o) + 2379 * var(--u) + var(--footer-h) + 24 * var(--u));
  background: transparent;
}

/* ===== Header (logo, nav, contact) ============================== */
.logo,
.nav a,
.contact-top {
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  color: var(--about-chrome-color);
}

.logo {
  position: fixed;
  left: calc(var(--o) + 24 * var(--u));
  top: calc(var(--o) + 24 * var(--u));
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-weight: 700;
  font-size: calc(20 * var(--u));
  letter-spacing: calc(-0.4 * var(--u));
  line-height: calc(20 * var(--u));
  z-index: 220;
}

.nav {
  position: fixed;
  left: 50%;
  top: calc(var(--o) + 24 * var(--u));
  display: flex;
  gap: calc(32 * var(--u));
  z-index: 220;
}
.nav a {
  position: relative;
  padding-bottom: 1px;
  transition: opacity 180ms ease;
}
.nav:hover a,
.nav:focus-within a {
  opacity: .62;
}
.nav a:hover,
.nav a:focus-visible {
  opacity: 1;
}

.contact-top {
  position: fixed;
  right: 24px;
  top: calc(var(--o) + 24 * var(--u));
  display: inline-flex;
  align-items: baseline;
  gap: calc(4 * var(--u));
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  z-index: 220;
}
.contact-top.is-open {
  z-index: 270;
}
.contact-arrow {
  font-family: 'Inter', system-ui, sans-serif;
  display: inline-block;
  /* user request: no hover transform on the arrow */
}
.contact-label {
  transition: opacity 180ms ease;
}

/* ===== Hero text + email ======================================== */
.hero {
  --hero-blur-progress: 0;
  position: absolute;
  left: 50%;
  top: calc(var(--o) + 92 * var(--u));
  width: calc(324 * var(--u));
  z-index: 20;
  opacity: calc(1 - var(--hero-blur-progress));
  filter: blur(calc(var(--hero-blur-progress) * 12px));
  will-change: opacity, filter;
}
.hero-text {
  margin: 0;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  width: calc(324 * var(--u));
}
.hero-contact {
  position: absolute;
  top: calc(148 * var(--u));
  left: 0;
  display: flex;
  flex-direction: column;
  gap: calc(4 * var(--u));
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
}
.hero-contact a {
  align-self: flex-start;
  border-bottom: 1px solid #000;
  transition: opacity 200ms ease;
}
.hero-contact a:hover { opacity: 0.6; }

/* ===== Center star =============================================
   The star stays fixed in the viewport center while the page scrolls.
   ================================================================ */
.hero-star {
  position: fixed;
  top: 50%;
  left: calc(var(--vw) / 2);
  z-index: 5;
  pointer-events: none;
  width: calc(263 * var(--u));
  height: calc(248 * var(--u));
  margin: calc(-124 * var(--u)) 0 0 calc(-131.5 * var(--u));
  background: transparent;
  -webkit-mask: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjYzIiBoZWlnaHQ9IjI0OCIgdmlld0JveD0iMCAwIDI2MyAyNDgiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xMTkuNzEyIDg0LjE0NjZDMTIxLjczMyA4MC4yNzU3IDEyMS45NSA3Ni4xMjY3IDEyMi42NjYgNzIuMTIxNkMxMjQuOTI2IDU5LjQ3ODcgMTI2LjI4NSA0Ni43MTQzIDEyNy41NjEgMzMuOTQxNkMxMjguNjcgMjIuODQ2NCAxMjkuNzk5IDExLjc1MzMgMTMwLjkyOSAwLjY2MDIwNUMxMzAuOTUxIDAuNDM4MDU1IDEzMS4wOTEgMC4yMjc4MzkgMTMxLjE4MSAwQzEzMi4xMDggMC4xNTI1MjcgMTMyLjAzOCAwLjkwMTkyMyAxMzIuMDg0IDEuNDgxMjRDMTMyLjYxNSA4LjEyMDMyIDEzMy4wNDkgMTQuNzY3OSAxMzMuNjQ3IDIxLjQwMDhDMTM0LjI0NCAyOC4wMyAxMzQuOTQgMzQuNjUxOCAxMzUuNjk2IDQxLjI2NUMxMzYuNjQzIDQ5LjU0ODQgMTM3LjU0NCA1Ny44Mzg2IDEzOC45MDggNjYuMDY5NUMxMzkuNzYxIDcxLjIxNjUgMTQwLjUwOSA3Ni4zODQyIDE0MS44NzIgODEuNDI4OUMxNDIuOTQzIDg1LjM5MzEgMTQ0LjI1MiA4Ni4wMDI5IDE0Ny45MzkgODQuMDMxMkMxNTUuNzggNzkuODM5MSAxNjIuODE3IDc0LjQ1MjkgMTY5LjczNyA2OC45Mjg1QzE4My4yMDkgNTguMTczMiAxOTUuNzUyIDQ2LjM3MjkgMjA4LjI0IDM0LjUxMTZDMjA5LjQwOSAzMy40MDEgMjEwLjIzMyAzMS44Njk5IDIxMS45NDEgMzEuMDgyNUMyMTIuMDIgMzIuNDA1NCAyMTEuMTY5IDMzLjAwNSAyMTAuNjI0IDMzLjcyOTNDMTk2LjY5OCA1Mi4yNTE0IDE4Mi42OTYgNzAuNzE4OCAxNjkuODk4IDkwLjA1NDRDMTY3LjkwMiA5My4wNjk3IDE2Ni4wNTggOTYuMTk2MyAxNjQuMzIyIDk5LjM2ODlDMTYyLjk3NyAxMDEuODI2IDE2My40NTUgMTAzLjIxNSAxNjUuOTYgMTA0LjQ3OUMxNzAuNTQzIDEwNi43OTMgMTc1LjU4NCAxMDcuNTA5IDE4MC41NTYgMTA4LjQyNUMxOTMuNTg5IDExMC44MjUgMjA2Ljc1NyAxMTIuMTA2IDIxOS45NDEgMTEzLjMyNkMyMjkuNjEyIDExNC4yMjEgMjM5LjI4MyAxMTUuMDU0IDI0OC45NzQgMTE1LjY5QzI1My41OTYgMTE1Ljk5MyAyNTguMjA5IDExNi40MzcgMjYzIDExNi44MzJDMjYyLjM1OSAxMTguMjI5IDI2MS4yNzcgMTE3Ljg1NyAyNjAuNDI2IDExNy44NzdDMjUwLjU0NCAxMTguMTA2IDI0MC43MzUgMTE5LjI3IDIzMC45MDkgMTIwLjE5NkMyMjAuNzY2IDEyMS4xNTIgMjEwLjYwOSAxMjIuMDIxIDIwMC41IDEyMy4yNjhDMTg4LjcyMSAxMjQuNzIxIDE3Ni44ODkgMTI1LjkzOCAxNjUuMzU4IDEyOC45NjJDMTY0LjU4MiAxMjkuMTY1IDE2My43OTYgMTI5LjM2NiAxNjMuMDU1IDEyOS42NjhDMTYwLjcwOSAxMzAuNjI1IDE2MC4yODMgMTMxLjY3MiAxNjEuNDE0IDEzMy45NDZDMTY0LjY4NyAxNDAuNTI1IDE2OC45NzkgMTQ2LjQ3OSAxNzMuMDQ4IDE1Mi41NThDMTg1LjE4MSAxNzAuNjg3IDE5Ny45NDkgMTg4LjM1OSAyMTEuNDQzIDIwNS41MDNDMjExLjY3OSAyMDUuODAzIDIxMS44MzQgMjA2LjE2NiAyMTIuMzgzIDIwNy4xMTlDMjEwLjUzMSAyMDYuMzAzIDIwOS43OCAyMDUuMTY0IDIwOC44OTUgMjA0LjI2N0MxOTIuOTA5IDE4OC4wNDQgMTc2Ljc3NiAxNzEuOTc3IDE1OS40MTUgMTU3LjIwMUMxNTUuNTQ5IDE1My45MSAxNTEuNTI5IDE1MC44MjMgMTQ3LjEzOSAxNDguMjUxQzE0NC4zNzQgMTQ2LjYzMSAxNDIuNzY3IDE0Ny4xOTggMTQxLjg3IDE1MC4yNEMxNDAuMjc0IDE1NS42NTEgMTM5LjU4NyAxNjEuMjM4IDEzOC45MyAxNjYuODE5QzEzOC4xMTQgMTczLjc0NiAxMzcuMzM3IDE4MC42OCAxMzYuNjU5IDE4Ny42MjJDMTM2LjA0MyAxOTMuOTMgMTM1LjU3OSAyMDAuMjUyIDEzNS4wNTQgMjA2LjU2OEMxMzQuNDQyIDIxMy45MjggMTMzLjgyIDIyMS4yODYgMTMzLjIzNSAyMjguNjQ3QzEzMi44NDggMjMzLjUzMiAxMzIuNDc3IDIzOC40MTggMTMyLjE4OCAyNDMuMzA5QzEzMi4wOTMgMjQ0LjkwNiAxMzEuOTY1IDI0Ni40NjYgMTMxLjExMiAyNDhDMTMwLjg5NSAyNDYuMDg5IDEzMC42MDkgMjQ0LjE4MyAxMzAuNDcxIDI0Mi4yNjZDMTI5Ljc4MyAyMzIuNzMyIDEyOS4yMTMgMjIzLjE4OSAxMjguNDQ5IDIxMy42NjFDMTI3Ljc3IDIwNS4xODggMTI2LjgzNCAxOTYuNzM1IDEyNi4xMTcgMTg4LjI2NEMxMjUuMTEzIDE3Ni40MiAxMjMuNjk4IDE2NC42MzkgMTIxLjI0OCAxNTIuOTk2QzExOS45NDkgMTQ2LjgyMyAxMTguMTk2IDE0Ni4wOTQgMTEzLjA0MSAxNDkuODk5QzEwNC43NDQgMTU2LjAyMSA5Ni45ODg4IDE2Mi43OTcgODkuNDc2NyAxNjkuODQ4Qzc2Ljg1NyAxODEuNjk0IDY0LjcwNTcgMTk0LjAxMyA1Mi42NTA1IDIwNi40MjlDNTIuNDQxIDIwNi42NDUgNTIuMTQ5OSAyMDYuNzgxIDUxLjcxODMgMjA3LjA3N0M5MS40ODU3IDIwNS44NTkgNTIuMjg5MiAyMDUuMzQzIDUyLjc3MTkgMjA0LjcxQzY4LjE5ODggMTg0LjQ4NCA4My4yNzQgMTY0LjAxMiA5Ni42MDUxIDE0Mi4zMTRDOTcuOTk0OSAxNDAuMDUyIDk5LjM3NDIgMTM3Ljc3NyAxMDAuNjE2IDEzNS40MzNDMTAyLjM2NSAxMzIuMTMzIDEwMS43OTQgMTMwLjc3NCA5OC4yODYzIDEyOS42OThDOTEuMjcwMiAxMjcuNTQ3IDgzLjk5OTggMTI2LjY4NCA3Ni43NzQzIDEyNS42NjZDNjguMDM5MiAxMjQuNDM1IDU5LjI4MTUgMTIzLjM0MyA1MC41MTMyIDEyMi4zNzdDNDEuNjYyOCAxMjEuNDAxIDMyLjc4NjcgMTIwLjY2MSAyMy45MjM0IDExOS44MDJDMTguMTcwNSAxMTkuMjQ1IDEyLjQyMTggMTE4LjY0NCA2LjY2ODAyIDExOC4wOThDNS4yMzA1OCAxMTcuOTYxIDMuNzc4MzUgMTE3Ljk4NyAyLjMzNyAxMTcuODgyQzEuNTk5ODYgMTE3LjgyOSAwLjcwNTgwOSAxMTguMTc4IDAgMTE2Ljg3OUMyLjk4MTk2IDExNi42NTIgNS43NzczOCAxMTYuNDA2IDguNTc3MjIgMTE2LjIzMUMxNy4wNzE1IDExNS43IDI1LjU4ODMgMTE1LjQyMSAzNC4wNTc5IDExNC42MzFDNDcuMzEzMiAxMTMuMzk2IDYwLjU5OTEgMTEyLjQzNyA3My43ODM5IDExMC40NzJDODAuNjg4NiAxMDkuNDQzIDg3LjYwMjMgMTA4LjUwNSA5NC40MTE5IDEwNi45NDNDOTUuNTg0MyAxMDYuNjc0IDk2Ljc1MiAxMDYuMzQ0IDk3Ljg3OTIgMTA1LjkyN0MxMDEuMDc5IDEwNC43NDQgMTAxLjg3OSAxMDIuNjg3IDEwMC4xNTcgOTkuNjcyOEM5OC43MjIzIDk3LjE2MDggOTcuMTIyOSA5NC43MzY2IDk1LjQ5NjQgOTIuMzQxNEM4My43Nzk1IDc1LjA4NjUgNzEuMTE3MSA1OC41MzM5IDU4LjE5ODggNDIuMTcxM0M1NS40Mjg5IDM4LjY2MyA1Mi43MzA5IDM1LjA5OCA0OS44NDk1IDMxLjM2NDRDNTEuMTE5IDMxLjEwNTcgNTEuNDc5MyAzMS44NDE1IDUxLjk0NzcgMzIuMjkyNEM2Ny40OTI5IDQ3LjI1NjMgODMuNDE4NyA2MS43ODQ4IDEwMC42MDUgNzQuODcyNEMxMDUuMTU4IDc4LjM0IDEwOS45MjUgODEuNDg5MyAxMTUuMDA0IDg0LjEzMjNDMTE2LjQ0NSA4NC44ODIzIDExOC4wMTggODUuOTg2NSAxMTkuNzEyIDg0LjE0NjZaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K") center center / 100% 100% no-repeat;
          mask: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjYzIiBoZWlnaHQ9IjI0OCIgdmlld0JveD0iMCAwIDI2MyAyNDgiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xMTkuNzEyIDg0LjE0NjZDMTIxLjczMyA4MC4yNzU3IDEyMS45NSA3Ni4xMjY3IDEyMi42NjYgNzIuMTIxNkMxMjQuOTI2IDU5LjQ3ODcgMTI2LjI4NSA0Ni43MTQzIDEyNy41NjEgMzMuOTQxNkMxMjguNjcgMjIuODQ2NCAxMjkuNzk5IDExLjc1MzMgMTMwLjkyOSAwLjY2MDIwNUMxMzAuOTUxIDAuNDM4MDU1IDEzMS4wOTEgMC4yMjc4MzkgMTMxLjE4MSAwQzEzMi4xMDggMC4xNTI1MjcgMTMyLjAzOCAwLjkwMTkyMyAxMzIuMDg0IDEuNDgxMjRDMTMyLjYxNSA4LjEyMDMyIDEzMy4wNDkgMTQuNzY3OSAxMzMuNjQ3IDIxLjQwMDhDMTM0LjI0NCAyOC4wMyAxMzQuOTQgMzQuNjUxOCAxMzUuNjk2IDQxLjI2NUMxMzYuNjQzIDQ5LjU0ODQgMTM3LjU0NCA1Ny44Mzg2IDEzOC45MDggNjYuMDY5NUMxMzkuNzYxIDcxLjIxNjUgMTQwLjUwOSA3Ni4zODQyIDE0MS44NzIgODEuNDI4OUMxNDIuOTQzIDg1LjM5MzEgMTQ0LjI1MiA4Ni4wMDI5IDE0Ny45MzkgODQuMDMxMkMxNTUuNzggNzkuODM5MSAxNjIuODE3IDc0LjQ1MjkgMTY5LjczNyA2OC45Mjg1QzE4My4yMDkgNTguMTczMiAxOTUuNzUyIDQ2LjM3MjkgMjA4LjI0IDM0LjUxMTZDMjA5LjQwOSAzMy40MDEgMjEwLjIzMyAzMS44Njk5IDIxMS45NDEgMzEuMDgyNUMyMTIuMDIgMzIuNDA1NCAyMTEuMTY5IDMzLjAwNSAyMTAuNjI0IDMzLjcyOTNDMTk2LjY5OCA1Mi4yNTE0IDE4Mi42OTYgNzAuNzE4OCAxNjkuODk4IDkwLjA1NDRDMTY3LjkwMiA5My4wNjk3IDE2Ni4wNTggOTYuMTk2MyAxNjQuMzIyIDk5LjM2ODlDMTYyLjk3NyAxMDEuODI2IDE2My40NTUgMTAzLjIxNSAxNjUuOTYgMTA0LjQ3OUMxNzAuNTQzIDEwNi43OTMgMTc1LjU4NCAxMDcuNTA5IDE4MC41NTYgMTA4LjQyNUMxOTMuNTg5IDExMC44MjUgMjA2Ljc1NyAxMTIuMTA2IDIxOS45NDEgMTEzLjMyNkMyMjkuNjEyIDExNC4yMjEgMjM5LjI4MyAxMTUuMDU0IDI0OC45NzQgMTE1LjY5QzI1My41OTYgMTE1Ljk5MyAyNTguMjA5IDExNi40MzcgMjYzIDExNi44MzJDMjYyLjM1OSAxMTguMjI5IDI2MS4yNzcgMTE3Ljg1NyAyNjAuNDI2IDExNy44NzdDMjUwLjU0NCAxMTguMTA2IDI0MC43MzUgMTE5LjI3IDIzMC45MDkgMTIwLjE5NkMyMjAuNzY2IDEyMS4xNTIgMjEwLjYwOSAxMjIuMDIxIDIwMC41IDEyMy4yNjhDMTg4LjcyMSAxMjQuNzIxIDE3Ni44ODkgMTI1LjkzOCAxNjUuMzU4IDEyOC45NjJDMTY0LjU4MiAxMjkuMTY1IDE2My43OTYgMTI5LjM2NiAxNjMuMDU1IDEyOS42NjhDMTYwLjcwOSAxMzAuNjI1IDE2MC4yODMgMTMxLjY3MiAxNjEuNDE0IDEzMy45NDZDMTY0LjY4NyAxNDAuNTI1IDE2OC45NzkgMTQ2LjQ3OSAxNzMuMDQ4IDE1Mi41NThDMTg1LjE4MSAxNzAuNjg3IDE5Ny45NDkgMTg4LjM1OSAyMTEuNDQzIDIwNS41MDNDMjExLjY3OSAyMDUuODAzIDIxMS44MzQgMjA2LjE2NiAyMTIuMzgzIDIwNy4xMTlDMjEwLjUzMSAyMDYuMzAzIDIwOS43OCAyMDUuMTY0IDIwOC44OTUgMjA0LjI2N0MxOTIuOTA5IDE4OC4wNDQgMTc2Ljc3NiAxNzEuOTc3IDE1OS40MTUgMTU3LjIwMUMxNTUuNTQ5IDE1My45MSAxNTEuNTI5IDE1MC44MjMgMTQ3LjEzOSAxNDguMjUxQzE0NC4zNzQgMTQ2LjYzMSAxNDIuNzY3IDE0Ny4xOTggMTQxLjg3IDE1MC4yNEMxNDAuMjc0IDE1NS42NTEgMTM5LjU4NyAxNjEuMjM4IDEzOC45MyAxNjYuODE5QzEzOC4xMTQgMTczLjc0NiAxMzcuMzM3IDE4MC42OCAxMzYuNjU5IDE4Ny42MjJDMTM2LjA0MyAxOTMuOTMgMTM1LjU3OSAyMDAuMjUyIDEzNS4wNTQgMjA2LjU2OEMxMzQuNDQyIDIxMy45MjggMTMzLjgyIDIyMS4yODYgMTMzLjIzNSAyMjguNjQ3QzEzMi44NDggMjMzLjUzMiAxMzIuNDc3IDIzOC40MTggMTMyLjE4OCAyNDMuMzA5QzEzMi4wOTMgMjQ0LjkwNiAxMzEuOTY1IDI0Ni40NjYgMTMxLjExMiAyNDhDMTMwLjg5NSAyNDYuMDg5IDEzMC42MDkgMjQ0LjE4MyAxMzAuNDcxIDI0Mi4yNjZDMTI5Ljc4MyAyMzIuNzMyIDEyOS4yMTMgMjIzLjE4OSAxMjguNDQ5IDIxMy42NjFDMTI3Ljc3IDIwNS4xODggMTI2LjgzNCAxOTYuNzM1IDEyNi4xMTcgMTg4LjI2NEMxMjUuMTEzIDE3Ni40MiAxMjMuNjk4IDE2NC42MzkgMTIxLjI0OCAxNTIuOTk2QzExOS45NDkgMTQ2LjgyMyAxMTguMTk2IDE0Ni4wOTQgMTEzLjA0MSAxNDkuODk5QzEwNC43NDQgMTU2LjAyMSA5Ni45ODg4IDE2Mi43OTcgODkuNDc2NyAxNjkuODQ4Qzc2Ljg1NyAxODEuNjk0IDY0LjcwNTcgMTk0LjAxMyA1Mi42NTA1IDIwNi40MjlDNTIuNDQxIDIwNi42NDUgNTIuMTQ5OSAyMDYuNzgxIDUxLjcxODMgMjA3LjA3N0M5MS40ODU3IDIwNS44NTkgNTIuMjg5MiAyMDUuMzQzIDUyLjc3MTkgMjA0LjcxQzY4LjE5ODggMTg0LjQ4NCA4My4yNzQgMTY0LjAxMiA5Ni42MDUxIDE0Mi4zMTRDOTcuOTk0OSAxNDAuMDUyIDk5LjM3NDIgMTM3Ljc3NyAxMDAuNjE2IDEzNS40MzNDMTAyLjM2NSAxMzIuMTMzIDEwMS43OTQgMTMwLjc3NCA5OC4yODYzIDEyOS42OThDOTEuMjcwMiAxMjcuNTQ3IDgzLjk5OTggMTI2LjY4NCA3Ni43NzQzIDEyNS42NjZDNjguMDM5MiAxMjQuNDM1IDU5LjI4MTUgMTIzLjM0MyA1MC41MTMyIDEyMi4zNzdDNDEuNjYyOCAxMjEuNDAxIDMyLjc4NjcgMTIwLjY2MSAyMy45MjM0IDExOS44MDJDMTguMTcwNSAxMTkuMjQ1IDEyLjQyMTggMTE4LjY0NCA2LjY2ODAyIDExOC4wOThDNS4yMzA1OCAxMTcuOTYxIDMuNzc4MzUgMTE3Ljk4NyAyLjMzNyAxMTcuODgyQzEuNTk5ODYgMTE3LjgyOSAwLjcwNTgwOSAxMTguMTc4IDAgMTE2Ljg3OUMyLjk4MTk2IDExNi42NTIgNS43NzczOCAxMTYuNDA2IDguNTc3MjIgMTE2LjIzMUMxNy4wNzE1IDExNS43IDI1LjU4ODMgMTE1LjQyMSAzNC4wNTc5IDExNC42MzFDNDcuMzEzMiAxMTMuMzk2IDYwLjU5OTEgMTEyLjQzNyA3My43ODM5IDExMC40NzJDODAuNjg4NiAxMDkuNDQzIDg3LjYwMjMgMTA4LjUwNSA5NC40MTE5IDEwNi45NDNDOTUuNTg0MyAxMDYuNjc0IDk2Ljc1MiAxMDYuMzQ0IDk3Ljg3OTIgMTA1LjkyN0MxMDEuMDc5IDEwNC43NDQgMTAxLjg3OSAxMDIuNjg3IDEwMC4xNTcgOTkuNjcyOEM5OC43MjIzIDk3LjE2MDggOTcuMTIyOSA5NC43MzY2IDk1LjQ5NjQgOTIuMzQxNEM4My43Nzk1IDc1LjA4NjUgNzEuMTE3MSA1OC41MzM5IDU4LjE5ODggNDIuMTcxM0M1NS40Mjg5IDM4LjY2MyA1Mi43MzA5IDM1LjA5OCA0OS44NDk1IDMxLjM2NDRDNTEuMTE5IDMxLjEwNTcgNTEuNDc5MyAzMS44NDE1IDUxLjk0NzcgMzIuMjkyNEM2Ny40OTI5IDQ3LjI1NjMgODMuNDE4NyA2MS43ODQ4IDEwMC42MDUgNzQuODcyNEMxMDUuMTU4IDc4LjM0IDEwOS45MjUgODEuNDg5MyAxMTUuMDA0IDg0LjEzMjNDMTE2LjQ0NSA4NC44ODIzIDExOC4wMTggODUuOTg2NSAxMTkuNzEyIDg0LjE0NjZaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K") center center / 100% 100% no-repeat;
  transform-origin: 50% 50%;
  -webkit-mask: url("assets/star.svg?v=20260531-star-tip") center center / 100% 100% no-repeat;
          mask: url("assets/star.svg?v=20260531-star-tip") center center / 100% 100% no-repeat;
}
.hero-star-shape {
  position: absolute;
  inset: 0;
  display: block;
  background: #000;
  -webkit-mask: inherit;
          mask: inherit;
  opacity: 0;
  transform: scale(0);
  transform-origin: 50% 50%;
  animation: starAppear 680ms cubic-bezier(.22, .72, .18, 1) 120ms forwards;
  will-change: transform, opacity;
  transition: transform 820ms cubic-bezier(.16,.82,.18,1), filter 820ms ease;
}
@keyframes starAppear {
  0% { opacity: 0; transform: scale(0); }
  100% { opacity: 1; transform: scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-star-shape { animation: none; opacity: 1; transform: scale(1); }
}

/* ===== Project cards =========================================== */
.works { display: contents; }

.card {
  position: absolute;
  display: block;
  color: #000;
  z-index: 10;
  filter: blur(0);
  opacity: 1;
  transition:
    filter 320ms ease,
    opacity 320ms ease;
}
.works.is-card-hovering .card:not(.is-active-card),
body:has(.card:hover) .card:not(:hover),
body:has(.card:focus-visible) .card:not(:focus-visible) {
  filter: blur(var(--project-bg-blur));
  opacity: .48;
}
.card-img {
  display: block;
  overflow: hidden;
  background: #f2f2f2;
}
.card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 700ms cubic-bezier(.2,.6,.2,1);
}
.card:hover .card-img img { transform: scale(1.03); }
.card-label {
  display: inline-block;
  margin-top: calc(8 * var(--u));
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  padding-bottom: 1px;
}

/* exact Figma positions */
.card-1 { left: calc(var(--o) + 489 * var(--u)); top: calc(var(--o) + 623 * var(--u)); width: calc(280 * var(--u)); }
.card-1 .card-img { width: calc(280 * var(--u)); height: calc(300 * var(--u)); }

.card-2 { left: calc(var(--o) + 24  * var(--u)); top: calc(var(--o) + 973 * var(--u)); width: calc(360 * var(--u)); }
.card-2 .card-img { width: calc(360 * var(--u)); height: calc(300 * var(--u)); }

.card-3 { right: calc(var(--o) + 24 * var(--u)); left: auto; top: calc(var(--o) + 973 * var(--u)); width: calc(320 * var(--u)); }
.card-3 .card-img { width: calc(320 * var(--u)); height: calc(300 * var(--u)); }

.card-4 { left: calc(var(--o) + 588 * var(--u)); top: calc(var(--o) + 1215 * var(--u)); width: calc(400 * var(--u)); }
.card-4 .card-img { width: calc(400 * var(--u)); height: calc(400 * var(--u)); }

.card-5 { left: calc(var(--o) + 24  * var(--u)); top: calc(var(--o) + 1531 * var(--u)); width: calc(280 * var(--u)); }
.card-5 .card-img { width: calc(280 * var(--u)); height: calc(300 * var(--u)); }

.card-6 { right: calc(var(--o) + 24 * var(--u)); left: auto; top: calc(var(--o) + 1790 * var(--u)); width: calc(360 * var(--u)); }
.card-6 .card-img { width: calc(360 * var(--u)); height: calc(300 * var(--u)); }

.card-7 { left: calc(var(--o) + 489 * var(--u)); top: calc(var(--o) + 1899 * var(--u)); width: calc(320 * var(--u)); }
.card-7 .card-img { width: calc(320 * var(--u)); height: calc(300 * var(--u)); }


/* ===== Fixed bottom projects bar ================================ */
.projects-bar {
  position: fixed;
  left: 24px;
  right: 24px;
  bottom: 24px;
  height: calc(32 * var(--u));
  min-height: 32px;
  z-index: 40;

  display: flex;
  align-items: center;
  justify-content: space-between;
  background: transparent;
  border: 0;

  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));

  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}
.projects-bar.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.projects-label,
.projects-count {
  font-size: calc(15 * var(--u));
}
.projects-count {
  font-variant-numeric: tabular-nums;
  min-width: calc(36 * var(--u));
  text-align: right;
}

/* ===== Project page overlay ===================================== */
.hero,
.card,
.footer,
.projects-bar {
  transform-origin: 50% 20%;
  transition:
    transform 720ms cubic-bezier(.16,.82,.18,1),
    filter 520ms cubic-bezier(.16,.82,.18,1),
    opacity 520ms cubic-bezier(.16,.82,.18,1);
}
.hero-star {
  transition:
    opacity 520ms cubic-bezier(.16,.82,.18,1);
  will-change: opacity;
}
html.project-open,
body.project-open {
  overflow: hidden;
}
body.project-open .hero,
body.project-open .card,
body.project-open .footer,
body.project-open .projects-bar {
  transform: scale(.94);
  filter: blur(var(--project-bg-blur));
  opacity: .72;
  pointer-events: none;
}
body.project-open .hero-star {
  opacity: 0;
}
body.project-open:has(.card:hover) .card,
body.project-open .works.is-card-hovering .card {
  filter: blur(var(--project-bg-blur));
  opacity: .48;
}
body.project-open .card {
  filter: blur(var(--project-bg-blur));
  opacity: .48;
}

.project-page {
  position: fixed;
  inset: 0 auto 0 0;
  width: 100dvw;
  z-index: 160;
  background: #fff;
  color: #000;
  overflow-y: scroll;
  scrollbar-gutter: auto;
  scrollbar-width: none;
  scrollbar-color: transparent transparent;
  overscroll-behavior: contain;
  clip-path: inset(100% 0 0 0);
  visibility: hidden;
  pointer-events: none;
  transition:
    clip-path 720ms cubic-bezier(.16,.82,.18,1),
    visibility 0s linear 720ms;
  will-change: mask-size;
}
.project-page.is-visible {
  visibility: visible;
  pointer-events: auto;
  transition:
    clip-path 720ms cubic-bezier(.16,.82,.18,1),
    visibility 0s;
}
.project-page.is-open {
  clip-path: inset(0 0 0 0);
}
.project-return {
  position: fixed;
  top: calc(var(--o) + 52 * var(--u));
  left: calc(var(--o) + 24 * var(--u));
  z-index: 2;
  display: inline-flex;
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  color: #000;
  cursor: pointer;
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  transition: opacity 180ms ease;
}
.project-return:hover,
.project-return:focus-visible {
  opacity: .62;
}
.project-page-inner {
  min-height: 100vh;
  padding: calc(var(--o) + 72 * var(--u)) 24px calc(120 * var(--u));
  display: block;
  opacity: 0;
  filter: blur(calc(10 * var(--u)));
  transform: translateY(calc(96 * var(--u)));
  transition:
    opacity 380ms ease 180ms,
    filter 520ms cubic-bezier(.16,.82,.18,1) 180ms,
    transform 520ms cubic-bezier(.16,.82,.18,1) 180ms;
}
.project-page.is-open .project-page-inner {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* ---------- Hero: title right, cover full-width, meta right ----- */
.project-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  row-gap: calc(48 * var(--u));
}
.project-hero .project-title {
  grid-column: 1 / -1;
  margin: 0;
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: clamp(48px, calc(80 * var(--u)), 80px);
  line-height: .96;
  font-weight: 700;
  letter-spacing: -0.03em;
  text-align: left;
  text-wrap: balance;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: none;
}
.project-cover {
  grid-column: 1 / -1;
  margin: 0;
}
.project-cover-img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #f2f2f2;
}
.project-hero-meta {
  grid-column: 2;
}
.project-description {
  width: min(100%, calc(560 * var(--u)));
  max-width: 62ch;
  margin: 0;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  text-wrap: pretty;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: none;
}
.project-info-bar {
  margin: calc(48 * var(--u)) 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: calc(8 * var(--u)) calc(40 * var(--u));
}
.project-info-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.project-info-label-row {
  display: flex;
  align-items: center;
  margin-bottom: calc(8 * var(--u));
}
.project-info-label {
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-weight: 400;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  letter-spacing: 0;
  text-transform: none;
  color: rgba(0, 0, 0, 0.55);
}
.project-info-value {
  margin: 0;
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  color: #000;
}

/* ---------- Section blocks: text right, images full-width ------- */
.project-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  row-gap: calc(48 * var(--u));
  margin-top: calc(120 * var(--u));
}
.project-block-text {
  grid-column: 2;
}
.project-block-title {
  margin: 0 0 calc(24 * var(--u));
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: clamp(24px, calc(32 * var(--u)), 32px);
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-align: left;
  text-wrap: balance;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: none;
}
.project-block-body {
  width: min(100%, calc(560 * var(--u)));
  max-width: 62ch;
  margin: 0;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  text-wrap: pretty;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: none;
}
.project-block-paragraph {
  margin: 0 0 calc(16 * var(--u));
}
.project-block-paragraph:last-child,
.project-block-list:last-child {
  margin-bottom: 0;
}
.project-block-list {
  list-style: none;
  margin: 0 0 calc(16 * var(--u));
  padding: 0;
}
.project-block-list li {
  position: relative;
  padding-left: calc(18 * var(--u));
  margin: 0 0 calc(8 * var(--u));
}
.project-block-list li:last-child {
  margin-bottom: 0;
}
.project-block-list li::before {
  content: "-";
  position: absolute;
  left: 0;
  top: 0;
}
.project-block-media {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(16 * var(--u));
}
.project-block-media[data-count="2"] { grid-template-columns: 1fr 1fr; }
.project-block-media[data-count="3"] { grid-template-columns: 1fr 1fr 1fr; }
.project-block-media[data-count="4"] { grid-template-columns: 1fr 1fr 1fr 1fr; }
.project-block-media figure {
  margin: 0;
}
.project-block-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  background: #f2f2f2;
}
.project-block-media[data-count="1"] .project-block-img { aspect-ratio: 21 / 9; }
.project-block-media[data-count="2"] .project-block-img { aspect-ratio: 4 / 3; }
.project-block-media[data-count="3"] .project-block-img { aspect-ratio: 1 / 1; }
.project-block-media[data-count="4"] .project-block-img { aspect-ratio: 3 / 4; }

@media (max-width: 1024px) {
  .project-page-inner {
    padding: 80px 16px 80px;
  }
  .project-hero {
    grid-template-columns: 1fr;
    row-gap: 24px;
  }
  .project-hero .project-title {
    grid-column: 1;
    font-size: 48px;
    line-height: 1;
  }
  .project-cover { grid-column: 1; }
  .project-cover-img {
    aspect-ratio: auto;
    height: 70vw;
    min-height: 240px;
    max-height: 480px;
  }
  .project-hero-meta { grid-column: 1; }
  .project-description { width: 100%; font-size: 15px; line-height: 20px; }
  .project-info-bar {
    margin-top: 32px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }
  .project-block {
    grid-template-columns: 1fr;
    margin-top: 56px;
    row-gap: 20px;
  }
  .project-block-text { grid-column: 1; }
  .project-block-title { font-size: 24px; line-height: 1.1; }
  .project-block-body { width: 100%; max-width: none; font-size: 15px; line-height: 20px; }

  .project-block-media {
    grid-column: 1;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 16px;
    gap: 12px;
    /* bleed scroll area to viewport edges */
    margin: 0 -16px;
    padding: 0 16px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .project-block-media::-webkit-scrollbar { display: none; }
  .project-block-media[data-count="1"],
  .project-block-media[data-count="2"],
  .project-block-media[data-count="3"],
  .project-block-media[data-count="4"] {
    grid-template-columns: none;
  }
  .project-block-media figure {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }
  .project-block-media[data-count="1"] figure { flex-basis: 100%; }
  .project-block-media[data-count="2"] figure,
  .project-block-media[data-count="3"] figure,
  .project-block-media[data-count="4"] figure { flex-basis: 78%; }
  .project-block-img {
    aspect-ratio: auto;
    height: 70vw;
    min-height: 240px;
    max-height: 480px;
  }
}

/* ===== Mobile (< 720px) general layout =========== */
@media (max-width: 1024px) {
  body { overflow-x: hidden; }
  body::after {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 64px;
    background: #fff;
    z-index: 210;
    pointer-events: none;
    transition: background-color 520ms cubic-bezier(.16,.82,.18,1);
  }
  body.about-open::after {
    background: #000;
  }

  .canvas {
    width: 100%;
    height: auto;
    padding: 64px 16px 24px;
    display: flex;
    flex-direction: column;
    gap: 28px;
  }

  /* unanchor flowing content but keep top chrome fixed */
  .hero, .card, .footer { position: static; }

  .logo {
    position: fixed;
    left: 16px;
    top: 16px;
    font-size: 20px;
    line-height: 20px;
    letter-spacing: -0.4px;
  }
  .nav {
    position: fixed;
    left: 50%;
    top: 16px;
    transform: translateX(-50%);
    display: flex;
    gap: 20px;
  }
  .logo,
  .nav a,
  .contact-top {
    color: #000;
    transition: color 520ms cubic-bezier(.16,.82,.18,1);
  }
  body.about-open .logo,
  body.about-open .nav a,
  body.about-open .contact-top {
    color: #fff;
  }
  .nav a {
    font-size: 15px;
    line-height: 20px;
    transition:
      color 520ms cubic-bezier(.16,.82,.18,1),
      opacity 180ms ease;
  }
  .contact-top {
    position: fixed;
    right: 16px;
    top: 16px;
  }

  .hero { order: 1; width: 100%; }
  .hero-text {
    width: 100%;
    max-width: 560px;
    font-size: 16px;
    line-height: 22px;
  }
  .hero-text br { display: none; }
  .hero-contact {
    position: static;
    margin-top: 20px;
  }

  /* keep star in place (don't follow viewport), sized down for mobile */
  .hero-star {
    position: absolute !important;
    top: 360px !important;
    left: 50% !important;
    margin: 0 !important;
    transform: translate(-50%, -50%);
    width: 180px !important;
    height: 180px !important;
  }
  /* project cards: vertical stack */
  .works {
    order: 5;
    display: flex !important;
    flex-direction: column;
    gap: 32px;
    margin-top: 320px;
  }
  .card { width: 100% !important; left: 0 !important; top: 0 !important; }
  .card-img { width: 100% !important; height: auto !important; aspect-ratio: 4/3; }
  .card-4 .card-img { aspect-ratio: 1/1; }

  .footer { order: 7; width: 100%; margin-top: 24px; }
  .footer-rule { margin-bottom: 24px; }
  .footer-meta {
    position: static;
    margin-top: 16px;
    font-size: 13px;
    line-height: 18px;
    flex-wrap: wrap;
    gap: 8px;
  }

  /* projects bar on mobile sits comfortably */
  .projects-bar {
    left: 12px; right: 12px; bottom: 12px;
    height: 44px;
    padding: 0 16px;
    font-size: 14px;
  }

  .drawer {
    inset: auto 12px auto auto;
    top: 52px;
    width: min(280px, calc(100vw - 24px));
    min-width: 0;
    border-radius: 6px;
    padding: 16px;
    gap: 24px;
  }
  .drawer-main {
    position: relative;
  }
  .drawer-links a {
    font-size: 40px;
    line-height: 44px;
  }
  .drawer-foot {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }
  .drawer-talk {
    font-size: 15px;
    line-height: 20px;
  }
  .drawer-email {
    font-size: 15px;
    line-height: 20px;
  }
  .drawer-socials {
    display: none;
  }
}

@media (max-width: 820px) {
  body::after { height: 96px; }
  .canvas { padding-top: 96px; }
  .nav {
    left: 16px;
    right: 16px;
    top: 48px;
    transform: none;
    justify-content: flex-start;
    gap: clamp(14px, 5vw, 20px);
    width: auto;
    max-width: calc(100vw - 32px);
    overflow: visible;
    white-space: nowrap;
  }
  .contact-top {
    top: 16px;
    right: 16px;
  }
  .project-page-inner { padding-top: 112px; }
}

@media (max-width: 600px) {
  body::after { height: 96px; }
  .canvas { padding-top: 96px; }
  .nav {
    left: 16px;
    right: auto;
    top: 48px;
    transform: none;
    justify-content: flex-start;
    gap: 18px;
  }
  .contact-top { top: 16px; right: 16px; }
  .project-page-inner { padding-top: 112px; }

  /* bigger card images on phones */
  .card-img { aspect-ratio: 1 / 1 !important; }
  .card-4 .card-img { aspect-ratio: 1 / 1 !important; }

  /* tidier project meta */
  .project-info-bar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px 24px;
    margin-top: 32px;
  }
}

/* ===== About page overlay ===================================== */
.about-page {
  position: fixed;
  inset: 0;
  width: 100dvw;
  height: 100dvh;
  z-index: 170;
  background: #000;
  color: #fff;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior-x: none;
  touch-action: pan-y;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-mask-image: url("assets/star.svg?v=20260531-star-tip");
          mask-image: url("assets/star.svg?v=20260531-star-tip");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-size: 0% 0%;
          mask-size: 0% 0%;
  visibility: hidden;
  pointer-events: none;
  transition:
    -webkit-mask-size 820ms cubic-bezier(.16,.82,.18,1),
    mask-size 820ms cubic-bezier(.16,.82,.18,1),
    visibility 0s linear 900ms;
  will-change: mask-size;
}
.about-page::-webkit-scrollbar { display: none; }
.about-page.is-open {
  -webkit-mask-size: 12000px 12000px;
  mask-size: 12000px 12000px;
  visibility: visible;
  pointer-events: auto;
  transition:
    -webkit-mask-size 820ms cubic-bezier(.16,.82,.18,1),
    mask-size 820ms cubic-bezier(.16,.82,.18,1),
    visibility 0s;
}
.about-page-inner {
  position: relative;
  min-height: 100vh;
  padding: calc(var(--o) + 92 * var(--u)) 24px calc(96 * var(--u));
  opacity: 0;
  transition: opacity 480ms ease 200ms;
}
.about-page.is-open .about-page-inner {
  opacity: 1;
}

.about-hero {
  position: relative;
  margin-left: 50%;
  width: calc(324 * var(--u));
}
.about-hero-title {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  color: #fff;
}
.about-hero-text {
  margin: 0 0 calc(20 * var(--u));
  font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
  font-size: calc(15 * var(--u));
  line-height: calc(20 * var(--u));
  font-weight: 400;
  letter-spacing: 0;
  width: calc(324 * var(--u));
  color: rgba(255,255,255,0.92);
}
.about-hero-text:last-child { margin-bottom: 0; }

.about-photo {
  position: relative;
  width: calc(324 * var(--u));
  aspect-ratio: 4 / 5;
  margin: calc(28 * var(--u)) 0 0 50%;
  overflow: hidden;
}
.about-photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ----- Star burst when About is open ----- */
body.about-open .hero-star {
  z-index: 175;
}
body.about-open .hero-star-shape {
  animation: none;
  transform: scale(100);
  filter: invert(1);
  transition: transform 820ms cubic-bezier(.16,.82,.18,1), filter 820ms ease;
}

@media (max-width: 1024px) {
  body.about-open .hero-star {
    z-index: 5;
  }
  body.about-open .hero-star-shape {
    transform: scale(1);
    filter: none;
  }
}

/* ----- Inversions on About: header chrome turns white ----- */
body.about-open .contact-top { mix-blend-mode: normal; }

body.about-closing .contact-top { mix-blend-mode: normal; }

@media (max-width: 1024px) {
  .about-page-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 64px 16px 56px;
    gap: 48px;
  }
  .about-hero {
    position: static;
    width: 100%;
    max-width: 560px;
    margin-left: 0;
  }
  .about-hero-title { font-size: 40px; line-height: 1; margin-bottom: 24px; }
  .about-hero-text { font-size: 16px; line-height: 22px; }
  .about-hero-text {
    width: 100%;
    max-width: 560px;
    margin-bottom: 20px;
  }
  .about-photo {
    position: static;
    width: 100%;
    max-width: 560px;
    aspect-ratio: 4 / 5;
    margin: 0;
  }
}

@media (max-width: 820px) {
  .about-page-inner {
    padding-top: 96px;
  }
}

/* Reset sibling-dim after a nav link is clicked (until pointer leaves nav) */
.nav.is-hover-locked:hover a,
.nav.is-hover-locked:hover a:hover { opacity: 1; }

@media (hover: none), (pointer: coarse) {
  .nav:hover a,
  .nav:focus-within a,
  .nav a:hover,
  .nav a:focus-visible,
  .nav.is-hover-locked:hover a,
  .nav.is-hover-locked:hover a:hover {
    opacity: 1;
  }
}

body.about-open .drawer {
  background: #1a1a1a;
}

@media (max-width: 1024px) {
  .about-page {
    -webkit-mask-image: none;
    mask-image: none;
    -webkit-mask-size: auto;
    mask-size: auto;
    opacity: 0;
    visibility: hidden;
    transition: opacity 520ms cubic-bezier(.16,.82,.18,1), visibility 0s linear 520ms;
  }
  .about-page.is-open {
    opacity: 1;
    visibility: visible;
    transition: opacity 520ms cubic-bezier(.16,.82,.18,1), visibility 0s linear 0s;
  }
}
