body {
  font-family: var(--font-ja);
  color: var(--ink);
  background: linear-gradient(180deg, #f2f1ee 0%, var(--bg) 45%, #faf9f7 100%);
  font-size: var(--text-body);
  line-height: var(--leading-body);
  letter-spacing: var(--tracking-body);
  overflow-x: hidden;
}

/* Subtle noise texture */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.022;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Always-visible floating orbs — spans full page */
.bg-orbs {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.bg-orbs__o {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  will-change: transform;
}

.bg-orbs__o--1 {
  width: 520px;
  height: 520px;
  top: -100px;
  right: 0;
  background: rgba(95, 116, 255, 0.13);
  animation: orb-drift-1 40s ease-in-out infinite;
}

.bg-orbs__o--2 {
  width: 560px;
  height: 560px;
  top: -80px;
  left: -60px;
  background: rgba(14, 97, 103, 0.11);
  animation: orb-drift-2 50s ease-in-out infinite;
}

.bg-orbs__o--3 {
  width: 440px;
  height: 440px;
  bottom: -100px;
  left: 30%;
  background: rgba(46, 109, 118, 0.09);
  animation: orb-drift-3 35s ease-in-out infinite;
}

@keyframes orb-drift-1 {
  0%   { transform: translate(0, 0) scale(1);     opacity: 1; }
  25%  { transform: translate(-60px, 50px) scale(1.08); opacity: 0.6; }
  50%  { transform: translate(-30px, 100px) scale(0.95); opacity: 0.9; }
  75%  { transform: translate(40px, 60px) scale(1.05); opacity: 0.5; }
  100% { transform: translate(0, 0) scale(1);     opacity: 1; }
}

@keyframes orb-drift-2 {
  0%   { transform: translate(0, 0) scale(1);     opacity: 1; }
  25%  { transform: translate(50px, 70px) scale(1.1); opacity: 0.55; }
  50%  { transform: translate(80px, 30px) scale(0.92); opacity: 0.85; }
  75%  { transform: translate(20px, 90px) scale(1.06); opacity: 0.5; }
  100% { transform: translate(0, 0) scale(1);     opacity: 1; }
}

@keyframes orb-drift-3 {
  0%   { transform: translate(0, 0) scale(1);     opacity: 1; }
  25%  { transform: translate(-40px, -50px) scale(1.07); opacity: 0.6; }
  50%  { transform: translate(30px, -80px) scale(0.94); opacity: 0.85; }
  75%  { transform: translate(-20px, -30px) scale(1.04); opacity: 0.45; }
  100% { transform: translate(0, 0) scale(1);     opacity: 1; }
}

::selection {
  background: var(--accent-light);
  color: var(--ink);
}

.container {
  width: min(var(--max-w), calc(100% - var(--space-8)));
  margin-inline: auto;
}

.container--narrow {
  width: min(var(--max-w-narrow), calc(100% - var(--space-8)));
  margin-inline: auto;
}

.label {
  font-family: var(--font-label);
  font-size: var(--text-label);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faint);
  line-height: var(--leading-label);
}

.label--accent {
  color: var(--accent);
}

h1, h2, h3 {
  font-family: var(--font-ja);
  font-weight: 860;
  color: var(--ink);
}

h2 {
  font-size: var(--text-h2);
  line-height: var(--leading-heading);
  letter-spacing: var(--tracking-heading);
}

h3 {
  font-size: var(--text-h3);
  line-height: var(--leading-heading);
  letter-spacing: var(--tracking-heading);
  font-weight: 760;
}
