/* =============================================
   Cortex Collective — Base Stylesheet
   v3 · styles.css
   ============================================= */

/* ── Design Tokens ── */
:root {
  --ink:             #0c0a09;
  --ink-2:           #1a1714;
  --bone:            #ece8e1;
  --bone-2:          #f5f2ed;
  --paper:           #f0ece5;
  --gold:            #c9a25a;
  --gold-2:          #8a6a2a;
  --purple:          #5b2bd6;
  --purple-deep:     #2a0d6b;
  --purple-chrome-1: #c9a9ff;
  --silver:          #c8c2b6;
  --silver-2:        #6a6358;
  --hot:             #d62213;
  --line:            rgba(236, 232, 225, 0.12);
}

/* ── Nav Overlay ── */
.nav-overlay {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--ink);
  display: flex; flex-direction: column; justify-content: center;
  padding: 48px 52px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 0.35s ease, transform 0.35s cubic-bezier(.4,0,.2,1);
}
.nav-overlay.open {
  opacity: 1; transform: translateY(0); pointer-events: all;
}
.nav-overlay-close {
  position: absolute; top: 28px; right: 36px;
  background: none; border: none; cursor: none;
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--bone);
  opacity: 0.6; transition: opacity 0.2s;
}
.nav-overlay-close:hover { opacity: 1; }
.nav-overlay-links {
  display: flex; flex-direction: column; gap: 4px;
}
.nav-overlay-link {
  display: flex; align-items: baseline; gap: 24px;
  font-family: "Anton", sans-serif;
  font-size: clamp(52px, 10vw, 120px);
  line-height: 1; color: var(--bone); text-decoration: none;
  letter-spacing: -0.02em;
  border-top: 1px solid rgba(236,232,225,0.1);
  padding: 12px 0;
  transition: color 0.15s ease, padding-left 0.2s ease;
}
.nav-overlay-link:last-child { border-bottom: 1px solid rgba(236,232,225,0.1); }
.nav-overlay-link::before {
  content: attr(data-num);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: 0.2em;
  color: rgba(236,232,225,0.4);
  flex-shrink: 0; padding-bottom: 4px;
}
.nav-overlay-link:hover { color: var(--hot); padding-left: 12px; }
.nav-overlay-link:hover::before { color: var(--hot); }
.nav-overlay-meta {
  position: absolute; bottom: 32px; left: 52px; right: 52px;
  display: flex; justify-content: space-between;
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(236,232,225,0.35);
}

/* ── Loader v4 – Logo Flip ── */
.loader-stage {
  position: fixed; inset: 0; z-index: 9999;
  overflow: hidden; isolation: isolate;
  background: #0a0908;
  font-family: "Courier New", ui-monospace, monospace;
  color: #f3efe7;
  transition: opacity 0.5s ease, transform 0.7s cubic-bezier(.7,0,.3,1);
}
.loader-stage.gone { opacity: 0; transform: translateY(-100%); pointer-events: none; }

/* flipbook */
.loader-flipbook { position: absolute; inset: 0; z-index: 1; }
.loader-flipbook .frame {
  position: absolute; inset: 0;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  opacity: 0; transform: scale(1.06);
  filter: contrast(1.05) saturate(1.05);
  will-change: opacity, transform, filter;
}
.loader-flipbook .frame.live { opacity: 1; }
.loader-flipbook .frame.flash  { filter: contrast(2) saturate(0) brightness(1.4); mix-blend-mode: lighten; }
.loader-flipbook .frame.invert { filter: invert(1) hue-rotate(180deg) contrast(1.1); }
.loader-flipbook .frame.shift-l { transform: scale(1.06) translateX(-2%); }
.loader-flipbook .frame.shift-r { transform: scale(1.06) translateX(2%); }
.loader-flipbook .frame.zoom    { transform: scale(1.18); }
.loader-flipbook::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    radial-gradient(ellipse at center, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.6) 70%, rgba(0,0,0,0.85) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.55));
}

/* FX layers */
.loader-vignette {
  position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.55) 100%);
}
.loader-scanbar {
  position: absolute; left: 0; right: 0; height: 80px; z-index: 6; pointer-events: none;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.04) 30%, rgba(255,255,255,0.10) 50%, rgba(255,255,255,0.04) 70%, transparent);
  mix-blend-mode: screen;
  animation: loader-scanbar-roll 7s linear infinite;
}
@keyframes loader-scanbar-roll { from { top: -10%; } to { top: 110%; } }
.loader-scanlines {
  position: absolute; inset: 0; z-index: 6; pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.22) 0px, rgba(0,0,0,0.22) 1px, transparent 1px, transparent 3px);
  mix-blend-mode: multiply;
}
.loader-grain {
  position: absolute; inset: -10%; z-index: 7; pointer-events: none;
  opacity: 0.42; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  animation: loader-grain-shift 0.18s steps(6) infinite;
}
@keyframes loader-grain-shift {
  0%   { transform: translate(0,0); }
  20%  { transform: translate(-3%,2%); }
  40%  { transform: translate(2%,-2%); }
  60%  { transform: translate(-1%,3%); }
  80%  { transform: translate(3%,1%); }
  100% { transform: translate(0,0); }
}
.loader-tear {
  position: absolute; left: 0; right: 0; height: 0; z-index: 8; pointer-events: none;
  background: #ff2a1a; mix-blend-mode: difference; opacity: 0;
}
.loader-tear.fire { animation: loader-tear-fire 0.18s ease-out; }
@keyframes loader-tear-fire { 0% { opacity:0; height:0; } 20% { opacity:1; height:6px; } 100% { opacity:0; height:14px; } }

/* HUD chrome */
.loader-corner {
  position: absolute; z-index: 12; width: 22px; height: 22px;
  border: 1px solid rgba(243,239,231,0.55); pointer-events: none;
}
.loader-corner.tl { top:14px;    left:14px;  border-right:none; border-bottom:none; }
.loader-corner.tr { top:14px;    right:14px; border-left:none;  border-bottom:none; }
.loader-corner.bl { bottom:14px; left:14px;  border-right:none; border-top:none; }
.loader-corner.br { bottom:14px; right:14px; border-left:none;  border-top:none; }
.loader-crosshair {
  position: absolute; inset: 0; z-index: 11; pointer-events: none; color: rgba(243,239,231,0.22);
}
.loader-crosshair::before, .loader-crosshair::after {
  content: ""; position: absolute; background: currentColor;
}
.loader-crosshair::before { left:50%; top:50%; width:1px; height:38px; margin:-19px 0 0 -0.5px; }
.loader-crosshair::after  { left:50%; top:50%; width:38px; height:1px; margin:-0.5px 0 0 -19px; }

.loader-ribbon {
  position: absolute; top:22px; left:50%; transform:translateX(-50%);
  z-index: 12; display:flex; gap:10px; align-items:center;
  font-size:11px; letter-spacing:0.34em; text-transform:uppercase; color:rgba(243,239,231,0.55);
}
.loader-pip {
  display:inline-block; width:6px; height:6px; background:#ff2a1a;
  border-radius:50%; box-shadow:0 0 10px #ff2a1a;
  animation: loader-pip-pulse 1.1s ease-in-out infinite;
}
@keyframes loader-pip-pulse { 0%,100% { opacity:0.3; transform:scale(0.85); } 50% { opacity:1; transform:scale(1.15); } }

.loader-hud {
  position: absolute; z-index: 12; font-size:11px; letter-spacing:0.32em;
  text-transform:uppercase; color:#f3efe7; pointer-events:none; line-height:1.6;
}
.loader-hud.tl { top:22px;    left:26px; }
.loader-hud.tr { top:22px;    right:26px; text-align:right; }
.loader-hud.bl { bottom:110px; left:26px; }
.loader-hud.br { bottom:110px; right:26px; text-align:right; }
.loader-dim   { color: rgba(243,239,231,0.55); }
.loader-faint { color: rgba(243,239,231,0.22); }
.loader-hot   { color: #ff2a1a; }

/* center logo */
.loader-center-block {
  position: absolute; inset: 0; z-index: 10;
  display: grid; place-items: center; pointer-events: none;
}
.loader-logo-wrap {
  position: relative; width: min(82vw, 760px);
  filter: drop-shadow(0 8px 30px rgba(0,0,0,0.85)) drop-shadow(0 0 1px rgba(0,0,0,0.9));
  animation: loader-logo-breath 4.6s ease-in-out infinite;
  transform-origin: 50% 50%;
}
.loader-logo-wrap img { width:100%; height:auto; display:block; }
.loader-logo-skin { position:absolute; inset:0; opacity:0; transition:opacity 0.04s linear; }
.loader-logo-skin:first-child { position:relative; }
.loader-logo-skin.live { opacity:1; }
@keyframes loader-logo-breath { 0%,100% { transform:scale(1); } 50% { transform:scale(1.012); } }
.loader-logo-wrap.glitch { animation: loader-logo-glitch 0.22s steps(4,end); }
@keyframes loader-logo-glitch {
  0%   { transform: translate(0,0); }
  25%  { transform: translate(-3px,1px) skewX(-1deg); }
  50%  { transform: translate(2px,-1px); filter: drop-shadow(2px 0 0 #ff2a1a) drop-shadow(-2px 0 0 #00f0ff); }
  75%  { transform: translate(-1px,2px); }
  100% { transform: translate(0,0); }
}

/* caption */
.loader-caption {
  position: absolute; bottom:110px; left:50%; transform:translateX(-50%);
  z-index: 12; font-size:11px; letter-spacing:0.34em; text-transform:uppercase; color:#d8d2c4;
  background:rgba(0,0,0,0.55); padding:6px 14px; border:1px solid rgba(243,239,231,0.22);
  backdrop-filter:blur(2px); white-space:nowrap; text-align:center; min-width:220px;
}
.loader-cap-num { color:#ff2a1a; margin-right:10px; }

/* progress strip */
.loader-strip {
  position: absolute; left:26px; right:26px; bottom:26px; z-index:12;
  display:flex; flex-direction:column; gap:10px; color:#f3efe7;
}
.loader-strip-row {
  display:flex; justify-content:space-between; align-items:baseline;
  font-size:11px; letter-spacing:0.3em; text-transform:uppercase;
}
.loader-pct { font-variant-numeric:tabular-nums; color:#d8d2c4; }
.loader-blink { animation: loader-blink 0.85s steps(2,end) infinite; }
@keyframes loader-blink { 0%,49% { opacity:1; } 50%,100% { opacity:0; } }
.loader-bar {
  --segs: 60;
  width:100%; height:14px; display:grid;
  grid-template-columns: repeat(var(--segs), 1fr); gap:2px;
}
.loader-bar i { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.10); transition:background 0.12s linear, box-shadow 0.12s linear, border-color 0.12s linear; }
.loader-bar i.on   { background:#d8d2c4; border-color:#d8d2c4; }
.loader-bar i.head { background:#ff2a1a; border-color:#ff2a1a; box-shadow:0 0 10px #ff2a1a, 0 0 2px #ff2a1a; }
.loader-meta {
  display:flex; justify-content:space-between; font-size:10px;
  letter-spacing:0.32em; text-transform:uppercase; color:rgba(243,239,231,0.55);
}

@media (max-width: 600px) {
  .loader-hud { font-size:9px; letter-spacing:0.24em; }
  .loader-hud.bl, .loader-hud.br { display:none; }
  .loader-ribbon { font-size:9px; letter-spacing:0.24em; }
  .loader-caption { font-size:9px; bottom:130px; }
}

/* ── Reset ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--ink);
  color: var(--bone);
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  cursor: none;
  overflow-x: hidden;
}

*, *::before, *::after {
  cursor: none;
}

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

button {
  background: none;
  border: none;
  color: inherit;
  font: inherit;
  cursor: none;
}

img {
  display: block;
  max-width: 100%;
}

/* ── Grain overlay ── */
.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9000;
  opacity: 0.18;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>");
  mix-blend-mode: overlay;
}

/* ── Custom Cursor ── */
.cursor-ring {
  position: fixed;
  top: 0; left: 0;
  width: 40px; height: 40px;
  border: 1.5px solid rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9997;
  transform: translate(-50%, -50%);
  transition: width 0.25s cubic-bezier(.2,.8,.2,1),
              height 0.25s cubic-bezier(.2,.8,.2,1),
              border-color 0.25s,
              background 0.25s;
  mix-blend-mode: difference;
}

.cursor-ring.is-link {
  width: 64px;
  height: 64px;
}

.cursor-dot {
  position: fixed;
  top: 0; left: 0;
  width: 6px; height: 6px;
  background: #fff;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
}

/* ── Nav Link ── */
.nav-link {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  cursor: none;
  transition: opacity 0.2s;
}

.nav-link:hover {
  opacity: 0.7;
}

/* ── Hero ── */
.hero {
  position: relative;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
}

.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(0.52) contrast(1.1) saturate(0.9);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 28px 40px;
}

.hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(236, 232, 225, 0.75);
}

.corner-l,
.corner-r {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.corner-r {
  align-items: flex-end;
}

.center-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(236, 232, 225, 0.75);
}

.scroll-hint {
  opacity: 0.5;
  font-size: 10px;
  letter-spacing: 0.18em;
}

.lang {
  opacity: 0.55;
}

.hero-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  width: 100%;
  padding: 0 40px;
}

.hero-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}

.hero-logo-stack {
  position: relative;
  width: clamp(260px, 44vw, 660px);
}

.hero-logo-stack img {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: auto;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.hero-logo-stack img:first-child {
  position: relative;
}

.hero-logo-stack img.active {
  opacity: 1;
}

.hero-bookline {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.hero-bookline a {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--bone);
  border-bottom: 1px solid rgba(255, 255, 255, 0.38);
  padding-bottom: 3px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.5);
  transition: border-color 0.2s, color 0.2s;
}

.hero-bookline a:hover {
  border-bottom-color: var(--bone);
}

.hero-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(236, 232, 225, 0.65);
}

.b-l {
  opacity: 0.75;
}

.b-r {
  display: flex;
  align-items: center;
  gap: 10px;
}

.live-dot {
  width: 7px; height: 7px;
  background: #ff2d1a;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

/* ── Section base ── */
.section {
  position: relative;
}

/* ── Marquee ── */
.marquee {
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 16px 0;
  background: var(--ink);
  color: var(--bone);
  user-select: none;
}

.marquee-track {
  display: inline-flex;
  gap: 0;
  animation: marqueeScroll 36s linear infinite;
}

.marquee-track span {
  display: inline-block;
  white-space: nowrap;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding-right: 2px;
}

.marquee .star {
  display: inline-block;
  color: var(--gold);
  transition: transform 0.4s ease, color 0.4s ease;
}

/* ── Cuts ── */
.cuts {
  background: var(--ink);
  color: var(--bone);
}

.cuts-mini {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  padding: 18px 40px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.09);
}

.cuts-list {
  position: relative;
}

.cut-row {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 22px 40px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  cursor: none;
  text-decoration: none;
  color: var(--bone);
  position: relative;
  transition: background 0.25s;
}

.cut-row .idx {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  min-width: 32px;
  opacity: 0.55;
}

.cut-row .name {
  font-family: "Anton", sans-serif;
  font-size: clamp(26px, 3.2vw, 52px);
  line-height: 0.96;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  flex: 1;
  color: var(--bone);
}

.cut-row .desc {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.55;
  min-width: 180px;
}

.cut-row .price {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  min-width: 80px;
  text-align: right;
  opacity: 0.6;
}

.cut-row .arrow {
  font-size: 18px;
  margin-left: 4px;
  opacity: 0.55;
}

/* ── Cut Preview ── */
.cut-preview {
  position: fixed;
  pointer-events: none;
  z-index: 998;
  width: 280px;
  height: 380px;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.22s ease;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: var(--ink);
}

.cut-preview.visible {
  opacity: 1;
}

.cut-preview img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(1.05);
  transition: transform 0.4s ease;
}

.cut-preview .preview-corner {
  display: none;
}

.cut-preview .preview-label {
  position: absolute;
  left: 14px;
  bottom: 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: rgba(0, 0, 0, 0.6);
  padding: 6px 10px;
  border-left: 2px solid var(--gold);
  z-index: 2;
}

/* ── Display (shared utility) ── */
.display {
  font-family: "Anton", sans-serif;
  text-transform: uppercase;
  line-height: 0.92;
  letter-spacing: -0.012em;
}

/* ── Footer ── */
.footer {
  background: var(--ink);
  color: var(--bone);
  padding: 80px 40px 40px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 48px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 52px;
  margin-top: 0;
}

.footer-grid h4 {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: 18px;
}

.footer-grid p,
.footer-grid a {
  display: block;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  line-height: 1.65;
  color: rgba(236, 232, 225, 0.7);
}

.footer-grid a:hover {
  color: var(--bone);
}

.footer-bot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 48px;
  padding-top: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}

/* ── About collection (referenced in inline overrides) ── */
.about-collection {
  padding: 120px 40px;
  position: relative;
  overflow: hidden;
}

.about-collection::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.about-mini {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.5;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 80px;
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}

.about-tag {
  font-family: "Anton", sans-serif;
  font-size: clamp(40px, 5vw, 76px);
  line-height: 0.96;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  max-width: 20ch;
}

.about-lead {
  font-family: "Inter", sans-serif;
  font-size: 20px;
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 20px;
}

.about-body {
  font-family: "Inter", sans-serif;
  font-size: 17px;
  line-height: 1.65;
  max-width: 60ch;
  color: rgba(236, 232, 225, 0.72);
}

.about-stats {
  display: flex;
  gap: 48px;
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}

.about-stats .n {
  font-family: "Anton", sans-serif;
  font-size: 48px;
  display: block;
}

.about-stats .l {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.6;
}

/* ── Section divider ── */
.section-divider {
  height: 1px;
  background: rgba(255,255,255,0.1);
  position: relative;
  overflow: hidden;
}

/* ── Animations ── */
@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

@keyframes kenburns {
  0%   { transform: scale(1) translate(0, 0); }
  100% { transform: scale(1.08) translate(1%, -1%); }
}

@keyframes marqueeScroll {
  to { transform: translateX(-25%); }
}

/* ── Responsive ── */
@media (max-width: 920px) {
  .hero-overlay { padding: 20px 24px; }
  .cuts-mini { flex-direction: column; gap: 4px; padding: 14px 24px; }
  .cuts-mini span:not(:first-child) { display: none; }
  .cut-row { padding: 18px 24px; gap: 14px; }
  .cut-row .desc { display: none; }
  .cut-row .price { min-width: auto; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .hero-logo-stack { width: clamp(220px, 72vw, 400px); }
}

@media (max-width: 600px) {
  .hero-top .corner-l span:last-child,
  .hero-top .center-menu .scroll-hint { display: none; }
  .footer-grid { grid-template-columns: 1fr; }
  .cut-row .name { font-size: clamp(22px, 5.5vw, 36px); }
}

@media (pointer: coarse) {
  .footer-grid a,
  .footer-grid .nav-link,
  .nav-link,
  .nav-overlay-link {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }
  .footer-grid a { display: flex; }

  /* hover preview doesn't work on touch — mouseleave never fires so it gets stuck */
  .cut-preview { display: none !important; }
}
