/*
Theme Name: Astronauta Store
Theme URI: https://astronautastore.com
Author: Astronauta Store
Author URI: https://astronautastore.com
Description: Editorial space-journal theme for Astronauta Store — a multi-channel e-commerce brand. Dark, minimalist, sophisticated. Custom-built, no page builder required.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astronauta-store
Tags: one-page, dark-theme, minimal, custom-colors, custom-menu
*/

/* ═══════════════════════════════════════════════════════════════
   ASTRONAUTA STORE — Observatory / Editorial Space Journal
   ═══════════════════════════════════════════════════════════════ */

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  --bg:         #0b0a0e;
  --bg-rise:    #14131a;
  --bg-sink:    #050409;

  --ink:        #ebe6dc;
  --ink-dim:    #8a857a;
  --ink-faint:  #4a4640;
  --ink-ghost:  #2a2824;

  --rule:       #1e1c24;
  --rule-hi:    #2f2d37;

  --warm:       #c8a064;
  --warm-deep:  #8c6c3e;
  --warm-glow:  #e4c18c;

  --cool:       #7a8b9e;

  --font-display: "Fraunces", ui-serif, Georgia, "Times New Roman", serif;
  --font-body:    "Instrument Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", "Cascadia Mono", Menlo, monospace;

  --container:  1440px;
  --pad-x:      clamp(22px, 5vw, 88px);

  --fraunces-display: "opsz" 120, "SOFT" 60, "WONK" 1;
  --fraunces-text:    "opsz" 14, "SOFT" 30, "WONK" 0;
}

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

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: 0.005em;
  overflow-x: clip;
  background-image:
    radial-gradient(ellipse at 20% 0%,  rgba(200, 160, 100, 0.05) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(122, 139, 158, 0.04) 0%, transparent 50%),
    linear-gradient(180deg, #0b0a0e 0%, #070608 100%);
  background-attachment: fixed;
}

img { display: block; max-width: 100%; height: auto; }
ul, ol { list-style: none; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
::selection { background: var(--warm); color: var(--bg); }

/* Hide WP admin bar gap at top on front */
html[lang] { scroll-padding-top: 80px; }

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

/* ── Starfield ───────────────────────── */
.starfield { position: fixed; inset: 0; pointer-events: none; z-index: 0; }
.starfield span {
  position: absolute; left: var(--x); top: var(--y);
  width: var(--s); height: var(--s);
  background: var(--ink); border-radius: 50%;
  opacity: var(--o); filter: blur(0.3px);
  animation: twinkle 8s ease-in-out infinite;
}
.starfield span:nth-child(3n)  { animation-delay: 1.8s; animation-duration: 11s; }
.starfield span:nth-child(5n)  { animation-delay: 3.2s; animation-duration: 13s; }
.starfield span:nth-child(7n)  { animation-delay: 0.6s; animation-duration: 9s; }
@keyframes twinkle {
  0%, 100% { opacity: var(--o); }
  50%      { opacity: calc(var(--o) * 0.3); }
}

/* ═══════════════════════════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════════════════════════ */
.topbar {
  position: sticky; top: 0; z-index: 100;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(24px, 6vw, 72px);
  padding: 18px var(--pad-x);
  background: rgba(11, 10, 14, 0.72);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--rule);
}

.topbar__mark {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-display);
  font-variation-settings: "opsz" 24, "SOFT" 50, "WONK" 1;
  letter-spacing: -0.015em;
}
/* When WP custom logo is set, `the_custom_logo()` renders its own
   <a class="custom-logo-link"><img class="custom-logo"></a> inside
   .topbar__mark--logo. The <img> has HTML width/height attributes pulled
   from the media file (e.g. 807x489), so the !important overrides are
   required to keep the rendered size inside the topbar rhythm. */
.topbar__mark--logo,
.topbar__mark--logo .custom-logo-link {
  display: block;
  line-height: 0;
}
.topbar__mark--logo .custom-logo {
  display: block !important;
  height: 44px !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain;
}
.mark__primary {
  font-size: 1.35rem; font-weight: 600; font-style: italic;
  color: var(--ink);
}
.mark__secondary {
  font-size: 0.72rem; font-family: var(--font-mono); font-weight: 400;
  color: var(--ink-dim); letter-spacing: 0.3em;
  text-transform: uppercase; font-style: normal;
}

.topbar__nav {
  display: flex; justify-content: center;
  gap: clamp(20px, 4vw, 56px);
  font-family: var(--font-mono); font-size: 0.72rem; font-weight: 400;
  text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-dim);
}
.topbar__nav a {
  position: relative; padding: 6px 0; transition: color 0.4s ease;
}
.topbar__nav a::after {
  content: ""; position: absolute; left: 50%; bottom: 2px;
  width: 0; height: 1px; background: var(--warm);
  transform: translateX(-50%);
  transition: width 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.topbar__nav a:hover { color: var(--ink); }
.topbar__nav a:hover::after { width: 100%; }

.topbar__meta {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 0.68rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim);
}
.pulse {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--warm);
  box-shadow: 0 0 0 0 rgba(200, 160, 100, 0.6);
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(200, 160, 100, 0.6); }
  70%  { box-shadow: 0 0 0 8px rgba(200, 160, 100, 0); }
  100% { box-shadow: 0 0 0 0 rgba(200, 160, 100, 0); }
}

@media (max-width: 780px) {
  .topbar { grid-template-columns: auto auto; }
  .topbar__meta { display: none; }
  .topbar__nav { gap: 20px; }
}

/* ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  padding: clamp(80px, 14vh, 160px) var(--pad-x) clamp(60px, 10vh, 120px);
  max-width: var(--container); margin-inline: auto;
  min-height: calc(100vh - 64px);
  display: flex; flex-direction: column; justify-content: space-between;
}
.hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(280px, 1fr);
  gap: clamp(48px, 8vw, 120px);
  align-items: start;
}
@media (max-width: 960px) {
  .hero__grid { grid-template-columns: 1fr; gap: 72px; }
}

.stamp {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 400;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: var(--warm); margin-bottom: clamp(40px, 7vh, 72px);
  animation: fade-up 1.1s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.stamp__rule { display: inline-block; width: 32px; height: 1px; background: var(--warm-deep); }
.stamp__date { color: var(--ink-dim); }

.hero__headline {
  font-family: var(--font-display);
  font-variation-settings: var(--fraunces-display);
  font-weight: 300;
  font-size: clamp(2.6rem, 7.5vw, 6.8rem);
  line-height: 0.98; letter-spacing: -0.03em;
  color: var(--ink); margin-bottom: clamp(28px, 4vh, 48px);
}
.hero__headline .line {
  display: block; opacity: 0; transform: translateY(26px);
  animation: fade-up 1.1s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}
.hero__headline .line--1 { animation-delay: 0.15s; }
.hero__headline .line--2 { animation-delay: 0.35s; }
.hero__headline .line--3 { animation-delay: 0.55s; }
.hero__headline em {
  font-style: italic; font-weight: 400; color: var(--warm-glow);
  font-variation-settings: "opsz" 120, "SOFT" 100, "WONK" 1;
}

.hero__lede {
  font-family: var(--font-body); font-size: clamp(1rem, 1.2vw, 1.15rem);
  line-height: 1.6; color: var(--ink-dim); max-width: 44ch;
  opacity: 0;
  animation: fade-up 1.2s 0.75s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

.hero__column--aside {
  display: flex; flex-direction: column; gap: 40px;
  opacity: 0;
  animation: fade-up 1.2s 0.9s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}
@media (max-width: 960px) {
  .hero__column--aside { order: -1; flex-direction: row; align-items: center; gap: 32px; }
}

.visor {
  position: relative; width: clamp(180px, 22vw, 260px); aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 35% 30%, rgba(200, 160, 100, 0.18) 0%, transparent 45%),
    radial-gradient(circle at center, #0c0b14 0%, #030205 78%);
  box-shadow:
    inset 0 0 40px rgba(0, 0, 0, 0.9),
    inset 0 0 0 1px rgba(200, 160, 100, 0.15),
    0 0 0 1px var(--rule-hi),
    0 0 0 7px rgba(44, 42, 50, 0.3),
    0 30px 60px -20px rgba(0, 0, 0, 0.9);
  overflow: hidden; transform: rotate(-3deg);
  transition: transform 1.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.visor:hover { transform: rotate(3deg) scale(1.03); }
.visor::before {
  content: ""; position: absolute; top: 8%; left: 10%;
  width: 36%; height: 26%;
  background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.12) 0%, transparent 70%);
  filter: blur(4px); transform: rotate(-20deg);
}
.visor::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  background: conic-gradient(from 120deg at 50% 50%,
    transparent 0deg, transparent 200deg,
    rgba(200, 160, 100, 0.2) 270deg, transparent 330deg);
  mix-blend-mode: screen;
}
.visor__star {
  position: absolute; left: var(--vx); top: var(--vy);
  width: var(--vs); height: var(--vs);
  background: var(--ink); border-radius: 50%; filter: blur(0.3px);
  animation: twinkle 6s ease-in-out infinite;
}
.visor__star:nth-of-type(even) { animation-delay: 2.2s; }
.visor__star:nth-of-type(3n) { animation-delay: 4s; }

.coords {
  font-family: var(--font-mono); font-size: 0.72rem; font-weight: 300;
  line-height: 1.4; color: var(--ink); letter-spacing: 0.04em;
  display: grid; grid-template-columns: auto 1fr; gap: 10px 24px;
  padding-top: 24px; border-top: 1px solid var(--rule);
}
.coords dt {
  color: var(--ink-dim); text-transform: uppercase;
  letter-spacing: 0.2em; font-size: 0.64rem;
}
.coords dd { color: var(--ink); }
@media (max-width: 960px) {
  .coords { flex: 1; padding-top: 0; border-top: 0; padding-left: 24px; border-left: 1px solid var(--rule); }
}

.hero__footer {
  margin-top: clamp(60px, 10vh, 120px);
  display: flex; align-items: center; gap: 20px;
  font-family: var(--font-mono); font-size: 0.68rem;
  text-transform: uppercase; letter-spacing: 0.3em;
  color: var(--ink-faint); opacity: 0;
  animation: fade-up 1.5s 1.2s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}
.hero__footer__rule { flex: 1; max-width: 120px; height: 1px; background: var(--rule-hi); }

@keyframes fade-up {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════════
   SECTION HEADS
   ═══════════════════════════════════════════════════════════════ */
.section-head {
  max-width: var(--container); margin: 0 auto;
  padding: 0 var(--pad-x); margin-bottom: clamp(48px, 7vw, 96px);
}
.section-head--right { text-align: right; }
.section-head--right .section-head__sub { margin-left: auto; }

.section-head__tag {
  display: block; font-family: var(--font-mono); font-size: 0.68rem; font-weight: 400;
  color: var(--warm); text-transform: uppercase; letter-spacing: 0.3em;
  margin-bottom: 22px;
}
.section-head__title {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 96, "SOFT" 40, "WONK" 0;
  font-weight: 300; font-size: clamp(2.2rem, 5.5vw, 4.8rem);
  line-height: 1.0; letter-spacing: -0.025em;
  color: var(--ink); margin-bottom: 18px;
}
.section-head__title em {
  font-style: italic; color: var(--warm-glow);
  font-variation-settings: "opsz" 96, "SOFT" 100, "WONK" 1;
}
.section-head__sub {
  font-size: 1rem; color: var(--ink-dim); max-width: 48ch; line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════
   § 01 · MANIFEST
   ═══════════════════════════════════════════════════════════════ */
.manifest { padding: clamp(80px, 12vh, 140px) 0 clamp(60px, 10vh, 120px); position: relative; }

.transmissions {
  max-width: var(--container); margin: 0 auto;
  padding: 0 var(--pad-x); border-top: 1px solid var(--rule);
}
.entry { border-bottom: 1px solid var(--rule); position: relative; }
.entry__link {
  display: grid; grid-template-columns: auto 1fr;
  gap: clamp(24px, 4vw, 56px);
  padding: clamp(32px, 5vw, 56px) 0;
  transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.entry__no {
  font-family: var(--font-mono); font-size: clamp(0.9rem, 1.1vw, 1.1rem);
  font-weight: 300; color: var(--ink-faint);
  letter-spacing: 0.04em; padding-top: 0.3em; min-width: 2ch;
  transition: color 0.5s ease;
}
.entry__body { min-width: 0; }
.entry__top {
  display: flex; align-items: center; gap: 16px; margin-bottom: 16px;
  font-family: var(--font-mono); font-size: 0.68rem;
  letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-dim);
}
.entry__name {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 120, "SOFT" 50, "WONK" 0;
  font-weight: 300; font-size: clamp(2.6rem, 6vw, 5.2rem);
  line-height: 0.95; letter-spacing: -0.03em; color: var(--ink);
  margin-bottom: 12px;
  transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), color 0.5s ease;
}
.tld {
  font-size: 0.3em; vertical-align: baseline; font-family: var(--font-mono);
  font-weight: 300; color: var(--ink-dim); letter-spacing: 0.05em;
  font-variation-settings: normal; padding-left: 4px;
  position: relative; top: -1.3em;
}
.entry__kicker {
  font-size: clamp(0.95rem, 1.1vw, 1.1rem); line-height: 1.55;
  color: var(--ink-dim); max-width: 60ch; margin-bottom: 20px;
  font-family: var(--font-body); font-style: italic; font-weight: 400;
}
.entry__data {
  display: flex; flex-wrap: wrap; gap: 12px 36px;
  font-family: var(--font-mono); font-size: 0.7rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-dim); padding-top: 16px; border-top: 1px dashed var(--rule);
}
.entry__cta {
  margin-left: auto; color: var(--warm); font-weight: 500;
  letter-spacing: 0.2em; transition: letter-spacing 0.4s ease;
}
.cta-arrow {
  display: inline-block; transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.entry__link:hover .entry__no    { color: var(--warm); }
.entry__link:hover .entry__name  { transform: translateX(14px); color: var(--warm-glow); }
.entry__link:hover .entry__cta   { letter-spacing: 0.3em; }
.entry__link:hover .cta-arrow    { transform: translate(4px, -4px); }
.entry:has(.entry__link:hover)   {
  background: linear-gradient(90deg, rgba(200, 160, 100, 0.04) 0%, transparent 70%);
}

/* ═══════════════════════════════════════════════════════════════
   § 02 · ATELIERS
   ═══════════════════════════════════════════════════════════════ */
.ateliers { padding: clamp(80px, 12vh, 140px) 0 clamp(60px, 10vh, 120px); position: relative; }
.brands { max-width: var(--container); margin: 0 auto; padding: 0 var(--pad-x); }
.brand {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: baseline; gap: clamp(16px, 3vw, 40px);
  padding: clamp(36px, 5vw, 64px) 0; border-bottom: 1px solid var(--rule);
  position: relative; overflow: hidden;
}
.brand:first-child { border-top: 1px solid var(--rule); }
.brand__index {
  font-family: var(--font-mono); font-size: 0.72rem;
  color: var(--ink-faint); letter-spacing: 0.1em; font-weight: 300;
  align-self: start; padding-top: 0.85em;
}
.brand__name {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 144, "SOFT" 70, "WONK" 1;
  font-weight: 300; font-style: italic;
  font-size: clamp(2.4rem, 7vw, 6rem);
  line-height: 0.95; letter-spacing: -0.035em; color: var(--ink);
  transition: letter-spacing 0.8s cubic-bezier(0.2, 0.8, 0.2, 1), color 0.6s ease;
  white-space: nowrap;
}
.brand__tags {
  font-family: var(--font-mono); font-size: 0.72rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim); text-align: right; align-self: center;
}
.brand:hover .brand__name { color: var(--warm-glow); letter-spacing: -0.02em; }
.brand::after {
  content: ""; position: absolute; left: 0; bottom: -1px;
  width: 0; height: 1px; background: var(--warm);
  transition: width 1s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.brand:hover::after { width: 100%; }
@media (max-width: 720px) {
  .brand { grid-template-columns: auto 1fr; }
  .brand__tags { grid-column: 1 / -1; text-align: left; padding-top: 12px; }
}
.ateliers__note {
  max-width: var(--container); margin: 48px auto 0;
  padding: 0 var(--pad-x); font-family: var(--font-mono);
  font-size: 0.72rem; color: var(--ink-faint);
  letter-spacing: 0.15em; text-transform: uppercase; text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   § 03 · DISPATCH
   ═══════════════════════════════════════════════════════════════ */
.dispatch { padding: clamp(80px, 12vh, 140px) 0 clamp(100px, 14vh, 180px); position: relative; }
.dispatch__body { max-width: 760px; margin: 0 auto; padding: 0 var(--pad-x); }
.dispatch__body p {
  font-size: clamp(1.05rem, 1.3vw, 1.25rem); line-height: 1.7;
  color: var(--ink); margin-bottom: 1.4em; font-family: var(--font-body);
}
.dispatch__body p.lead {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 36, "SOFT" 40, "WONK" 0;
  font-weight: 300; font-size: clamp(1.3rem, 2vw, 1.7rem);
  line-height: 1.4; letter-spacing: -0.015em;
  color: var(--ink); margin-bottom: 1.8em;
}
.dispatch__sig {
  display: flex; flex-wrap: wrap; align-items: center; gap: 14px;
  margin-top: 3em; padding-top: 1.8em; border-top: 1px solid var(--rule);
  font-family: var(--font-mono); font-size: 0.72rem;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-dim);
}
.dispatch__sig__sep { color: var(--ink-faint); }

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer {
  padding: clamp(48px, 8vw, 80px) var(--pad-x);
  border-top: 1px solid var(--rule); background: var(--bg-sink);
}
.footer__grid {
  max-width: var(--container); margin: 0 auto;
  display: grid; grid-template-columns: 1.3fr 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
}
@media (max-width: 780px) {
  .footer__grid { grid-template-columns: 1fr; gap: 40px; }
}
.footer__mark {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 40, "SOFT" 60, "WONK" 1;
  font-weight: 400; font-style: italic;
  font-size: clamp(1.6rem, 2.2vw, 2rem);
  letter-spacing: -0.02em; color: var(--ink); margin-bottom: 10px;
}
.footer__tagline {
  font-family: var(--font-mono); font-size: 0.72rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim);
}
.footer__label {
  font-family: var(--font-mono); font-size: 0.68rem;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--warm); margin-bottom: 18px;
}
.footer__col--channels ul {
  display: flex; flex-direction: column; gap: 10px;
  font-family: var(--font-body); font-size: 0.95rem; color: var(--ink);
}
.footer__col--channels a {
  display: inline-flex; align-items: center; gap: 8px; padding: 4px 0;
  transition: color 0.3s ease, transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.footer__col--channels a .ext {
  color: var(--ink-faint);
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), color 0.3s ease;
}
.footer__col--channels a:hover { color: var(--warm-glow); transform: translateX(4px); }
.footer__col--channels a:hover .ext { transform: translate(2px, -2px); color: var(--warm); }
.footer__col--meta {
  font-family: var(--font-mono); font-size: 0.74rem; line-height: 1.8;
  color: var(--ink-dim); letter-spacing: 0.04em;
}
.footer__copy {
  margin-top: 28px; font-size: 0.66rem; color: var(--ink-faint);
  letter-spacing: 0.12em; text-transform: uppercase; line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════
   Generic WP pages (page.php / 404.php)
   ═══════════════════════════════════════════════════════════════ */
.wp-page {
  max-width: 820px; margin: 0 auto;
  padding: clamp(80px, 12vh, 140px) var(--pad-x) clamp(100px, 14vh, 180px);
}
.wp-page__tag {
  display: block; font-family: var(--font-mono); font-size: 0.68rem;
  color: var(--warm); text-transform: uppercase; letter-spacing: 0.3em;
  margin-bottom: 22px;
}
.wp-page__title {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 120, "SOFT" 50, "WONK" 1;
  font-weight: 300; font-size: clamp(2.4rem, 6vw, 4.6rem);
  line-height: 1.0; letter-spacing: -0.03em; color: var(--ink);
  margin-bottom: 40px;
}
.wp-page__title em { font-style: italic; color: var(--warm-glow); }
.wp-page__content { font-size: 1.08rem; line-height: 1.7; color: var(--ink); }
.wp-page__content p, .wp-page__content ul, .wp-page__content ol,
.wp-page__content blockquote, .wp-page__content pre { margin-bottom: 1.3em; }
.wp-page__content a { color: var(--warm); border-bottom: 1px solid var(--warm-deep); }
.wp-page__content a:hover { color: var(--warm-glow); }
.wp-page__content h2 {
  font-family: var(--font-display); font-weight: 300;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem); line-height: 1.15;
  letter-spacing: -0.02em; margin-top: 2em; margin-bottom: 0.6em;
}
.wp-page__content h3 {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.3rem, 1.9vw, 1.6rem); margin-top: 1.6em; margin-bottom: 0.4em;
}
.wp-page__content blockquote {
  padding-left: 1.4em; border-left: 2px solid var(--warm);
  font-style: italic; color: var(--ink-dim);
}

.wp-404__actions { margin-top: 32px; }
.wp-404__actions a {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border: 1px solid var(--rule-hi);
  font-family: var(--font-mono); font-size: 0.74rem;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink);
  transition: border-color 0.3s ease, color 0.3s ease, transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.wp-404__actions a:hover { color: var(--warm-glow); border-color: var(--warm); transform: translateX(4px); }

/* ═══════════════════════════════════════════════════════════════
   Reduced motion
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .hero__headline .line, .hero__lede, .hero__column--aside, .hero__footer {
    opacity: 1; transform: none;
  }
}

/* Logged-in WP admin bar offset */
body.admin-bar .topbar { top: 32px; }
@media (max-width: 782px) {
  body.admin-bar .topbar { top: 46px; }
}
