/* ==========================================================================
   Honduras Heritage Blog — stylesheet
   Built on the Honduras Heritage / Lunchpiration design system tokens
   (colors.css, typography.css, spacing.css, effects.css, fonts.css).
   ========================================================================== */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--text-on-dark);
  background: linear-gradient(180deg, var(--gray-900) 0%, #161f33 50%, var(--gray-900) 100%);
  position: relative;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: opacity var(--duration-fast) var(--ease-standard); }

/* ---- Live background: soft drifting aurora glows behind everything ---- */
.bg-aurora {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.bg-aurora::before,
.bg-aurora::after {
  content: "";
  position: absolute;
  width: 70vw;
  height: 70vw;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.35;
}
.bg-aurora::before {
  top: -20%;
  left: -10%;
  background: radial-gradient(circle, var(--blue-500) 0%, rgba(0,115,207,0) 70%);
  animation: driftA 26s ease-in-out infinite alternate;
}
.bg-aurora::after {
  bottom: -25%;
  right: -15%;
  background: radial-gradient(circle, var(--fuchsia-500) 0%, rgba(110,198,255,0) 70%);
  animation: driftB 30s ease-in-out infinite alternate;
}
.bg-aurora .aurora-mid {
  position: absolute;
  top: 35%;
  left: 55%;
  width: 55vw;
  height: 55vw;
  border-radius: 50%;
  background: radial-gradient(circle, var(--teal-600) 0%, rgba(13,148,136,0) 70%);
  filter: blur(100px);
  opacity: 0.22;
  animation: driftC 34s ease-in-out infinite alternate;
}

@keyframes driftA { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(6%, 8%) scale(1.15); } }
@keyframes driftB { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(-8%, -6%) scale(1.1); } }
@keyframes driftC { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(-5%, 5%) scale(1.2); } }

@media (prefers-reduced-motion: reduce) {
  .bg-aurora::before, .bg-aurora::after, .bg-aurora .aurora-mid { animation: none; }
}

.page { position: relative; z-index: 1; perspective: 1400px; }

/* ---- Header / nav ---- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid transparent;
  transition: background var(--duration-md) var(--ease-standard), border-color var(--duration-md) var(--ease-standard);
}
.site-header.is-scrolled {
  background: rgba(17, 24, 39, 0.78);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-on-dark);
}
.nav {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-4) var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav__logo {
  font: 800 1.15rem var(--font-sans);
  letter-spacing: var(--tracking-tight);
  background: var(--gradient-headline);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
   display:flex;
  flex-direction: row;
  align-items: center;
}
.nav__logo .nav__flag {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 26px;
  margin-left: var(--space-3);
  border-radius: 3px;
  overflow: hidden;
  background: var(--gray-800);
}
.nav__logo .nav__flag canvas {
  display: block;
  width: 100%;
  height: 100%;
}
.nav__links {
  display: flex;
  gap: var(--space-8);
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav__links a {
  font: var(--label-nav);
  color: var(--text-on-dark-muted);
}
.nav__links a:hover { color: var(--text-on-dark); opacity: 1; }
.nav__burger {
  display: none;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-btn);
  background: var(--gray-800);
  border: none;
  color: #fff;
  font: 600 1.1rem var(--font-sans);
  cursor: pointer;
}
.nav__mobile {
  display: none;
  flex-direction: column;
  gap: var(--space-5);
  padding: var(--space-4) var(--gutter) var(--space-6);
  border-top: 1px solid var(--border-on-dark);
  background: rgba(17, 24, 39, 0.96);
}
.nav__mobile a { font: var(--label-nav); color: var(--text-on-dark-muted); }
.nav__mobile.is-open { display: flex; }

@media (max-width: 860px) {
  .nav__links { display: none; }
  .nav__burger { display: inline-flex; align-items: center; justify-content: center; }
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 26px;
  font: var(--label-btn);
  border-radius: var(--radius-btn);
  border: none;
  cursor: pointer;
  transition: filter var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-standard);
}
.btn:active { transform: scale(0.98); }
.btn:hover { filter: brightness(1.12); }
.btn--gradient { background: var(--gradient-brand); color: #fff; }
.btn--subtle { background: var(--gray-800); color: #fff; }

/* ---- Hero: full-width image with overlaid text ---- */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.hero__bg {
position: absolute;
    inset: 0;
    z-index: 1;
    height: 100vh;
    background-attachment: fixed;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: heroZoom 24s ease-in-out infinite alternate;
}
@keyframes heroZoom {
  0% { transform: scale(1); }
  100% { transform: scale(1.08); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__bg img { animation: none; }
}
.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  /* background:
    linear-gradient(0deg, rgba(17,24,39,0.95) 0%, rgba(17,24,39,0.55) 45%, rgba(17,24,39,0.25) 100%),
    var(--gradient-hero-glow); */
}
.hero__canvas {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0.8;
}
.hero__canvas canvas { display: block; width: 100%; height: 100%; }
.hero__content {
  position: relative;
  z-index: 3;
  max-width: var(--content-max);
  margin: 20px auto 30px auto;
  padding: var(--space-24) var(--gutter) var(--space-20);
  width: 100%;
  border-radius: 2rem;
  background: rgba(255, 255, 255, 0.5);
}
.hero__eyebrow {
  font: var(--label-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-500);
  margin: 0 0 var(--space-3);
}
.hero__title {
  font: var(--display-hero);
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-5);
  max-width: 14ch;
  background: var(--gradient-headline);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__subtitle {
  font: var(--body-md);
  color: var(--gray-100);
  max-width: 560px;
  margin: 0 0 var(--space-8);
}
.hero__ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ---- Sections ---- */
.section {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-24) var(--gutter);
}
.section--tinted {
  max-width: none;
  background: rgba(255, 255, 255, 0.03);
  padding: var(--space-24) 0;
}
.section--tinted > .section__inner {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.eyebrow {
  font: var(--label-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-500);
  margin: 0 0 var(--space-3);
}
.section-heading { max-width: 640px; margin: 0 0 var(--space-10); }
.section-heading__title {
  font: var(--display-section);
  letter-spacing: var(--tracking-tight);
  color: var(--text-on-dark);
  margin: 0 0 var(--space-3);
}
.section-heading__blurb { font: var(--body-md); color: var(--text-on-dark-muted); margin: 0; }

/* ---- Overview stats ---- */
.overview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}
.overview-copy { font: var(--body-md); color: var(--text-on-dark-muted); display: flex; flex-direction: column; gap: var(--space-5); }
.overview-copy strong { color: var(--text-on-dark); }

.stat-card {
  background: var(--surface-card-dark);
  border: 1px solid var(--border-on-dark);
  border-radius: var(--radius-card-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.stat + .stat { border-top: 1px solid var(--border-on-dark); padding-top: var(--space-6); }
.stat__value { font: 800 2.5rem var(--font-sans); letter-spacing: -0.02em; color: var(--text-on-dark); }
.stat__label { font: var(--body-sm); color: var(--text-on-dark-muted); }

@media (max-width: 860px) {
  .overview-grid { grid-template-columns: 1fr; gap: var(--space-10); }
}

/* ---- Flag ---- */
.flag-card {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-10);
  align-items: center;
  background: var(--surface-card-dark);
  border: 1px solid var(--border-on-dark);
  border-radius: var(--radius-card-lg);
  padding: var(--space-8);
  margin-bottom: var(--space-14);
}
.flag-swatch { border-radius: var(--radius-card); overflow: hidden; border: 1px solid var(--border-on-dark); }
.flag-swatch__stripe { height: 40px; background: var(--blue-500); }
.flag-swatch__stars { height: 40px; background: #fff; display: flex; align-items: center; justify-content: center; gap: 6px; }
.flag-swatch__stars span { color: var(--blue-500); font-size: 14px; line-height: 1; }
.flag-notes { display: flex; flex-direction: column; gap: var(--space-4); font: var(--body-sm); color: var(--text-on-dark-muted); }
.flag-notes strong { color: var(--text-on-dark); }

@media (max-width: 640px) {
  .flag-card { grid-template-columns: 1fr; }
}

/* ---- Article-style cards ---- */
.card-grid { display: grid; gap: var(--space-6); }

/*
  Bento mosaics modeled on a 3x3 grid of mixed 1x1 / 2x1 / 1x2 tiles (like the
  reference "Grid" swatch: small square, wide rectangle, wide rectangle, tall
  rectangle, two more squares). Each section below tiles the same 3x3 grid a
  different way so every mosaic reads as its own shape, and every tile is a
  real card — nothing is decorative filler.
*/

/* Symbols — small tile, wide tile, wide tile, tall tile, two small tiles
   (the exact arrangement from the reference swatch) */
.card-grid--symbols {
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
}
.card-grid--symbols > *:nth-child(1) { grid-column-start: 1; grid-row-start: 1; }
.card-grid--symbols > *:nth-child(2) {
  grid-column: span 2 / span 2;
  grid-column-start: 2;
  grid-row-start: 1;
}
.card-grid--symbols > *:nth-child(3) {
  grid-column: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 2;
}
.card-grid--symbols > *:nth-child(4) {
  grid-row: span 2 / span 2;
  grid-column-start: 3;
  grid-row-start: 2;
}
.card-grid--symbols > *:nth-child(5) { grid-column-start: 1; grid-row-start: 3; }
.card-grid--symbols > *:nth-child(6) { grid-column-start: 2; grid-row-start: 3; }
.card-grid--symbols > *:nth-child(4) .card__media img { height: 100%; min-height: 220px; }

/* Traditions — tall tile on the left, two small tiles, wide tile, wide tile, small tile */
.card-grid--traditions {
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
}
.card-grid--traditions > *:nth-child(1) {
  grid-row: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 1;
}
.card-grid--traditions > *:nth-child(2) { grid-column-start: 2; grid-row-start: 1; }
.card-grid--traditions > *:nth-child(3) { grid-column-start: 3; grid-row-start: 1; }
.card-grid--traditions > *:nth-child(4) {
  grid-column: span 2 / span 2;
  grid-column-start: 2;
  grid-row-start: 2;
}
.card-grid--traditions > *:nth-child(5) {
  grid-column: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 3;
}
.card-grid--traditions > *:nth-child(6) { grid-column-start: 3; grid-row-start: 3; }
.card-grid--traditions > *:nth-child(1) .card__media img { height: 100%; min-height: 220px; }

/* Legends — wide tile, tall tile, two small tiles, wide tile, small tile */
.card-grid--legends {
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
}
.card-grid--legends > *:nth-child(1) {
  grid-column: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 1;
}
.card-grid--legends > *:nth-child(2) {
  grid-row: span 2 / span 2;
  grid-column-start: 3;
  grid-row-start: 1;
}
.card-grid--legends > *:nth-child(3) { grid-column-start: 1; grid-row-start: 2; }
.card-grid--legends > *:nth-child(4) { grid-column-start: 2; grid-row-start: 2; }
.card-grid--legends > *:nth-child(5) {
  grid-column: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 3;
}
.card-grid--legends > *:nth-child(6) { grid-column-start: 3; grid-row-start: 3; }
.card-grid--legends > *:nth-child(2) .card__media img { height: 100%; min-height: 220px; }

/* Travel — mirror of the Symbols mosaic (tall tile on the left this time) */
.travel-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
}
.travel-grid > *:nth-child(1) { grid-column-start: 3; grid-row-start: 1; }
.travel-grid > *:nth-child(2) {
  grid-column: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 1;
}
.travel-grid > *:nth-child(3) {
  grid-column: span 2 / span 2;
  grid-column-start: 2;
  grid-row-start: 2;
}
.travel-grid > *:nth-child(4) {
  grid-row: span 2 / span 2;
  grid-column-start: 1;
  grid-row-start: 2;
}
.travel-grid > *:nth-child(5) { grid-column-start: 3; grid-row-start: 3; }
.travel-grid > *:nth-child(6) { grid-column-start: 2; grid-row-start: 3; }
.travel-grid > *:nth-child(4) .card__media img { height: 100%; min-height: 220px; }

.card {
  border-radius: var(--radius-card-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  color: var(--text-on-card);
  transition: transform var(--duration-md) var(--ease-standard), box-shadow var(--duration-md) var(--ease-standard);
  height: 100%;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.card--teal   { background: var(--gradient-card-teal); }
.card--orange { background: var(--gradient-card-orange); }
.card--yellow { background: var(--gradient-card-yellow); }
.card--purple { background: var(--gradient-card-purple); }
.card--pink   { background: var(--gradient-card-pink); }

.card__media img { width: 100%; height: 140px; object-fit: cover; border-radius: var(--radius-thumb); }
.card__tag {
  display: inline-flex;
  align-self: flex-start;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-pill);
  background: var(--surface-pill);
  font: var(--label-tag);
}
.card--teal .card__tag   { color: var(--teal-600); }
.card--orange .card__tag { color: var(--orange-600); }
.card--yellow .card__tag { color: var(--yellow-600); }
.card--purple .card__tag { color: var(--purple-600); }
.card--pink .card__tag   { color: var(--pink-600); }

.card__title { font: var(--display-card); letter-spacing: var(--tracking-tight); margin: 0; }
.card__body { font: var(--body-sm); color: var(--text-on-card-muted); margin: 0; }

@media (max-width: 980px) {
  .card-grid--symbols,
  .card-grid--traditions,
  .card-grid--legends,
  .travel-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: none;
  }
  .card-grid--symbols > *,
  .card-grid--traditions > *,
  .card-grid--legends > *,
  .travel-grid > * {
    grid-column: auto !important;
    grid-row: auto !important;
  }
  .card-grid--symbols > *:nth-child(4) .card__media img,
  .card-grid--traditions > *:nth-child(1) .card__media img,
  .card-grid--legends > *:nth-child(2) .card__media img,
  .travel-grid > *:nth-child(4) .card__media img {
    height: 160px;
    min-height: 0;
  }
}
@media (max-width: 640px) {
  .card-grid--symbols,
  .card-grid--traditions,
  .card-grid--legends,
  .travel-grid {
    grid-template-columns: 1fr;
  }
}

/* ---- Government / religion ---- */
.gov-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); margin-bottom: var(--space-20); }
.gov-card { border-radius: var(--radius-card-lg); padding: var(--space-8); height: 100%; }
.gov-card__label { font: var(--label-tag); margin: 0 0 var(--space-3); }
.gov-card__title { font: var(--display-card); letter-spacing: var(--tracking-tight); color: var(--text-on-card); margin: 0 0 var(--space-3); }
.gov-card__body { font: var(--body-sm); color: var(--text-on-card-muted); margin: 0; }
.gov-card--purple { background: var(--gradient-card-purple); }
.gov-card--teal { background: var(--gradient-card-teal); }
.gov-card--purple .gov-card__label { color: var(--purple-600); }
.gov-card--teal .gov-card__label { color: var(--teal-600); }

@media (max-width: 780px) {
  .gov-grid { grid-template-columns: 1fr; }
}

/* ---- Laws list ---- */
.laws-list { display: flex; flex-direction: column; }
.law-row {
  display: flex;
  gap: var(--space-6);
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--border-on-dark);
  align-items: baseline;
}
.laws-list .law-row:first-child { border-top: 1px solid var(--border-on-dark); }
.law-index { font: 800 1.5rem var(--font-sans); color: var(--blue-500); min-width: 44px; }
.law-title { font: 700 1.15rem var(--font-sans); color: var(--text-on-dark); margin: 0 0 var(--space-2); }
.law-body { font: var(--body-sm); color: var(--text-on-dark-muted); max-width: 640px; margin: 0; }

/* ---- Travel ---- */
/* .travel-grid mosaic is defined above alongside the other card-grid patterns */

/* ---- Footer ---- */
.site-footer { border-top: 1px solid var(--border-on-dark); padding: var(--space-16) var(--gutter) var(--space-10); }
.footer-grid {
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: var(--space-12);
}
.footer-brand { font: 800 1.1rem var(--font-sans); letter-spacing: var(--tracking-tight); background: var(--gradient-headline); -webkit-background-clip: text; background-clip: text; color: transparent; margin: 0 0 var(--space-3); }
.footer-blurb { font: var(--body-sm); color: var(--text-on-dark-muted); max-width: 320px; margin: 0; }
.footer-col__title { font: var(--label-nav); color: var(--text-on-dark); margin: 0 0 var(--space-1); }
.footer-links { display: flex; flex-direction: column; gap: var(--space-3); }
.footer-links a { font: var(--body-sm); color: var(--text-on-dark-muted); }
.footer-links a:hover { color: var(--text-on-dark); }
.footer-bottom {
  max-width: var(--content-max);
  margin: var(--space-10) auto 0;
  padding-top: var(--space-6);
  border-top: 1px solid var(--border-on-dark);
  font: var(--body-xs);
  color: var(--gray-500);
}

@media (max-width: 700px) {
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-8); }
}

/* ---- Scroll reveal ---- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1), transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

.card-grid .reveal:nth-child(2) { transition-delay: 0.08s; }
.card-grid .reveal:nth-child(3) { transition-delay: 0.16s; }
.card-grid .reveal:nth-child(4) { transition-delay: 0.24s; }
.card-grid .reveal:nth-child(5) { transition-delay: 0.32s; }
.card-grid .reveal:nth-child(6) { transition-delay: 0.4s; }
.laws-list .reveal:nth-child(2) { transition-delay: 0.06s; }
.laws-list .reveal:nth-child(3) { transition-delay: 0.12s; }
.laws-list .reveal:nth-child(4) { transition-delay: 0.18s; }
.laws-list .reveal:nth-child(5) { transition-delay: 0.24s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---- Read more link ---- */
.read-more {
  background: none;
  border: none;
  padding: 0;
  font: var(--label-link);
  color: var(--text-link);
  cursor: pointer;
}
.read-more:hover { text-decoration: underline; }

/* ---- Modal ---- */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  background: rgba(17, 24, 39, 0.7);
  backdrop-filter: blur(6px);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-md) var(--ease-standard);
}
.modal-overlay.is-open { opacity: 1; visibility: visible; }

.modal {
  position: relative;
  width: 100%;
  max-width: 560px;
  max-height: 85vh;
  overflow-y: auto;
  background: var(--gray-800);
  border: 1px solid var(--border-on-dark);
  border-radius: var(--radius-card-lg);
  padding: var(--space-8);
  transform: translateY(24px) scale(0.98);
  opacity: 0;
  transition: transform var(--duration-md) var(--ease-standard), opacity var(--duration-md) var(--ease-standard);
}
.modal-overlay.is-open .modal { transform: translateY(0) scale(1); opacity: 1; }

.modal__close {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  width: 36px;
  height: 36px;
  border-radius: var(--radius-btn);
  background: var(--gray-700);
  border: none;
  color: #fff;
  cursor: pointer;
  font-size: 1rem;
}
.modal__close:hover { filter: brightness(1.2); }

.modal__media { margin: 0 0 var(--space-5); }
.modal__media img { width: 100%; height: 220px; object-fit: cover; border-radius: var(--radius-thumb); }

.modal__tag {
  display: inline-flex;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-pill);
  background: var(--surface-pill);
  color: var(--blue-600);
  font: var(--label-tag);
  margin-bottom: var(--space-4);
}

.modal__title { font: var(--display-banner); color: var(--text-on-dark); margin: 0 0 var(--space-4); }
.modal__body { font: var(--body-md); color: var(--text-on-dark-muted); display: flex; flex-direction: column; gap: var(--space-4); }
.modal__body p { margin: 0; }

body.modal-open { overflow: hidden; }

/* ---- Page loader ---- */
.page-loader {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  background: var(--gray-900);
  transition: opacity 0.5s var(--ease-standard), visibility 0.5s var(--ease-standard);
}
.page-loader__mark {
  font: 800 1.4rem var(--font-sans);
  letter-spacing: var(--tracking-tight);
  background: var(--gradient-headline);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: loaderPulse 1.6s ease-in-out infinite;
}
.page-loader__track {
  width: 180px;
  height: 4px;
  border-radius: var(--radius-pill);
  background: var(--gray-800);
  overflow: hidden;
}
.page-loader__bar {
  width: 40%;
  height: 100%;
  border-radius: var(--radius-pill);
  background: var(--gradient-brand);
  animation: loaderSlide 1.1s ease-in-out infinite;
}
@keyframes loaderSlide {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(350%); }
}
@keyframes loaderPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}
.page-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .page-loader__mark, .page-loader__bar { animation: none; }
}

/* ---- 404 page ---- */
.not-found {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-24) var(--gutter);
}
.not-found__code {
  font: var(--display-hero);
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-4);
  background: var(--gradient-headline);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.not-found__title {
  font: var(--display-section);
  color: var(--text-on-dark);
  margin: 0 0 var(--space-4);
}
.not-found__body {
  font: var(--body-md);
  color: var(--text-on-dark-muted);
  max-width: 480px;
  margin: 0 0 var(--space-8);
}