/* ============================================================
   ALBUFERA — LATENCY BRAND SYSTEM
   main.css · Blue-Boost S.L. © 2026
   ============================================================ */

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root {
  /* Primary palette */
  --grape:      #4E00EB;
  --indigo:     #330099;
  --violet:     #9661FF;
  --lavender:   #D6C2FF;
  --mauve:      #EEE5FF;

  /* Neutrals */
  --midnight:   #111318;
  --lead:       #465063;
  --steel:      #687692;
  --silver:     #CFD4DD;
  --cloud:      #F0F2F4;
  --air:        #FFFFFF;

  /* Marketing palette */
  --parchment:  #F7F5F0;
  --bone:       #EFEDE7;
  --flax:       #E8D9B5;
  --sand:       #E2DFD5;
  --obsidian:   #1A181E;
  --amber:      #C88A3E;
  --copper:     #915F3D;
  --deep-royal: #250066;
  --amethyst:   #824DFF;

  /* Semantic */
  --candy:      #B32114;
  --rose:       #E9483A;
  --ballet:     #FCE5E3;
  --basil:      #0C6E45;
  --neon:       #16CA7F;
  --daiquiri:   #B6F7DC;
  --ocean:      #2A5EB6;
  --skyline:    #448AFF;
  --frost:      #D6E5FF;
  --gold:       #DBB700;
  --lemon:      #FFD505;
  --cream:      #FFF4BD;

  /* Typography */
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-body:    'Schibsted Grotesk', 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    'JetBrains Mono', 'Courier New', monospace;

  /* Spacing scale */
  --space-xs:   4px;
  --space-sm:   8px;
  --space-md:   16px;
  --space-lg:   24px;
  --space-xl:   40px;
  --space-2xl:  64px;
  --space-3xl:  96px;
  --space-4xl:  128px;

  /* Layout */
  --max-width:  1200px;
  --nav-height: 64px;

  /* Transitions */
  --ease:       cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast:   150ms;
  --dur-mid:    280ms;
  --dur-slow:   500ms;
}

/* ── RESET ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--parchment);
  color: var(--obsidian);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--obsidian);
}
h4, h5, h6 {
  font-family: var(--font-body);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: var(--obsidian);
}
h1 { font-size: clamp(2.5rem, 6vw, 5rem); }
h2 { font-size: clamp(2rem, 4vw, 3.5rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2.5rem); }
h4 { font-size: 1.375rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }

p { color: var(--lead); line-height: 1.65; max-width: 68ch; }
p + p { margin-top: var(--space-md); }

code, pre {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  font-weight: 500;
}
code {
  background: var(--bone);
  color: var(--obsidian);
  padding: 2px 6px;
  border-radius: 3px;
}

.overline {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}
@media (max-width: 768px) {
  .container { padding: 0 var(--space-md); }
}

.section {
  padding: var(--space-3xl) 0;
  border-top: 1px solid var(--sand);
}
.section:first-of-type { border-top: none; }

.section--dark {
  background: var(--deep-royal);
  border-top: none;
}
.section--bone {
  background: var(--bone);
  border-top: 1px solid var(--sand);
}
.section--grape {
  background: var(--grape);
  border-top: none;
}

.section-header {
  margin-bottom: var(--space-2xl);
}
.section-header .overline { margin-bottom: var(--space-md); }
.section-header h2 { margin-bottom: var(--space-lg); }
.section-header p { font-size: 1.125rem; line-height: 1.6; }

/* Two-column grid */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
}
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
}
.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.grid-auto {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-xl);
}
@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4, .grid-auto { grid-template-columns: 1fr; }
}

/* ── NAVBAR ─────────────────────────────────────────────────── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--nav-height);
  background: var(--parchment);
  border-bottom: 1px solid var(--sand);
  transition: box-shadow var(--dur-mid) var(--ease),
              background var(--dur-mid) var(--ease);
}
.navbar.scrolled {
  box-shadow: 0 1px 24px rgba(17,19,24,0.08);
  background: rgba(247,245,240,0.95);
  backdrop-filter: blur(12px);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}
.nav-logo img {
  height: 20px;
  width: auto;
  filter: brightness(0);
}
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
}
.nav-links > li {
  position: relative;
}
.nav-links > li > a {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--lead);
  letter-spacing: -0.01em;
  padding: var(--space-xs) 0;
  transition: color var(--dur-fast);
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-links > li > a:hover,
.nav-links > li > a.active { color: var(--obsidian); }
.nav-links > li > a.active::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0; right: 0;
  height: 2px;
  background: var(--grape);
  border-radius: 1px;
}
.nav-chevron {
  width: 12px; height: 12px;
  transition: transform var(--dur-fast);
}
.has-dropdown:hover .nav-chevron { transform: rotate(180deg); }

/* Dropdown */
.dropdown {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--air);
  border: 1px solid var(--silver);
  border-radius: 8px;
  padding: var(--space-sm) 0;
  min-width: 220px;
  box-shadow: 0 8px 32px rgba(17,19,24,0.12);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(-8px);
  transition: opacity var(--dur-mid) var(--ease),
              transform var(--dur-mid) var(--ease);
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown {
  opacity: 1;
  pointer-events: all;
  transform: translateX(-50%) translateY(0);
}
.dropdown a {
  display: flex;
  flex-direction: column;
  padding: 10px var(--space-lg);
  font-size: 0.875rem;
  color: var(--lead);
  transition: background var(--dur-fast), color var(--dur-fast);
}
.dropdown a span {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 2px;
}
.dropdown a:hover {
  background: var(--cloud);
  color: var(--obsidian);
}

/* Mobile nav toggle */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--space-sm);
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--obsidian);
  border-radius: 2px;
  transition: transform var(--dur-mid), opacity var(--dur-mid);
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay */
.nav-mobile {
  display: none;
  position: fixed;
  inset: var(--nav-height) 0 0 0;
  background: var(--parchment);
  z-index: 99;
  overflow-y: auto;
  padding: var(--space-xl);
}
.nav-mobile.open { display: block; }
.nav-mobile ul { display: flex; flex-direction: column; gap: var(--space-xs); }
.nav-mobile a {
  display: block;
  padding: var(--space-md) 0;
  font-size: 1.25rem;
  color: var(--lead);
  border-bottom: 1px solid var(--sand);
}
.nav-mobile .mob-section {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-top: var(--space-lg);
  margin-bottom: var(--space-xs);
}

@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .nav-inner { padding: 0 var(--space-md); }
}

/* ── PAGE HERO ──────────────────────────────────────────────── */
.page-hero {
  background: var(--deep-royal);
  color: var(--air);
  padding: var(--space-4xl) 0 var(--space-3xl);
  min-height: 420px;
  display: flex;
  align-items: flex-end;
}
.page-hero .overline { color: var(--amber); margin-bottom: var(--space-md); }
.page-hero h1 { color: var(--air); margin-bottom: var(--space-lg); }
.page-hero p {
  color: rgba(255,255,255,0.7);
  font-size: 1.125rem;
  max-width: 60ch;
}

/* Home hero */
.home-hero {
  background: var(--deep-royal);
  color: var(--air);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--space-2xl) 0 0;
  overflow: hidden;
}
.home-hero__content {
  padding: var(--space-4xl) 0 var(--space-2xl);
  flex: 1;
}
.home-hero__logo {
  height: 28px;
  width: auto;
  margin-bottom: var(--space-3xl);
  opacity: 0.9;
}
.home-hero__eyebrow {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: var(--space-md);
}
.home-hero__title {
  font-family: var(--font-display);
  font-size: clamp(4rem, 10vw, 8rem);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.0;
  color: var(--air);
  margin-bottom: var(--space-lg);
}
.home-hero__sub {
  font-size: 1.125rem;
  color: var(--amber);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-md);
}
.home-hero__desc {
  font-size: 1rem;
  color: rgba(255,255,255,0.6);
  max-width: 56ch;
  line-height: 1.6;
}
.home-hero__nav {
  display: flex;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.home-hero__nav-item {
  flex: 1;
  padding: var(--space-lg) var(--space-xl);
  border-right: 1px solid rgba(255,255,255,0.1);
  transition: background var(--dur-mid);
}
.home-hero__nav-item:last-child { border-right: none; }
.home-hero__nav-item:hover { background: rgba(255,255,255,0.04); }
.home-hero__nav-item .num {
  display: block;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 4px;
}
.home-hero__nav-item .label {
  display: block;
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.7);
}

/* ── SECTION CARDS (overview page) ─────────────────────────── */
.system-card {
  background: var(--air);
  border: 1px solid var(--sand);
  border-radius: 12px;
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: transform var(--dur-mid) var(--ease),
              box-shadow var(--dur-mid) var(--ease),
              border-color var(--dur-mid);
  text-decoration: none;
  color: inherit;
}
.system-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(17,19,24,0.10);
  border-color: var(--silver);
}
.system-card__tag {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
}
.system-card__title {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--obsidian);
  line-height: 1.15;
}
.system-card__desc {
  font-size: 0.9375rem;
  color: var(--lead);
  line-height: 1.55;
  max-width: none;
}
.system-card__arrow {
  margin-top: auto;
  padding-top: var(--space-lg);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--grape);
  display: flex;
  align-items: center;
  gap: 6px;
  transition: gap var(--dur-fast);
}
.system-card:hover .system-card__arrow { gap: 10px; }

/* ── CONTENT COMPONENTS ─────────────────────────────────────── */

/* Pillar card (Voice pillars) */
.pillar-card {
  background: var(--bone);
  border-radius: 12px;
  padding: var(--space-xl);
  border-left: 3px solid var(--grape);
}
.pillar-card__num {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--space-sm);
}
.pillar-card__title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 400;
  color: var(--obsidian);
  margin-bottom: var(--space-md);
}
.pillar-card p { font-size: 0.9375rem; }
.pillar-card__example {
  margin-top: var(--space-lg);
  border-top: 1px solid var(--sand);
  padding-top: var(--space-lg);
}
.pillar-card__example .voice-in {
  background: var(--air);
  border-left: 2px solid var(--basil);
  padding: var(--space-sm) var(--space-md);
  border-radius: 0 6px 6px 0;
  font-size: 0.875rem;
  font-style: italic;
  color: var(--lead);
  margin-bottom: var(--space-sm);
}
.pillar-card__example .voice-out {
  background: var(--air);
  border-left: 2px solid var(--rose);
  padding: var(--space-sm) var(--space-md);
  border-radius: 0 6px 6px 0;
  font-size: 0.875rem;
  font-style: italic;
  color: var(--steel);
  text-decoration: line-through;
  text-decoration-color: var(--rose);
}
.voice-label {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.voice-label.in { color: var(--basil); }
.voice-label.out { color: var(--rose); }

/* Tone context card */
.tone-card {
  background: var(--air);
  border: 1px solid var(--sand);
  border-radius: 10px;
  padding: var(--space-xl);
}
.tone-card__context {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--grape);
  margin-bottom: var(--space-sm);
}
.tone-card h4 { font-size: 1.125rem; margin-bottom: var(--space-md); }
.tone-card p { font-size: 0.9375rem; }
.do-dont { margin-top: var(--space-lg); display: flex; gap: var(--space-md); }
.do-dont__col { flex: 1; }
.do-dont__label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
}
.do-dont__col.do .do-dont__label { color: var(--basil); }
.do-dont__col.dont .do-dont__label { color: var(--candy); }
.do-dont__col ul { display: flex; flex-direction: column; gap: 6px; }
.do-dont__col li {
  font-size: 0.8125rem;
  color: var(--lead);
  padding-left: var(--space-md);
  position: relative;
  line-height: 1.45;
}
.do-dont__col.do li::before {
  content: '✓';
  position: absolute; left: 0;
  color: var(--basil); font-size: 0.75rem;
}
.do-dont__col.dont li::before {
  content: '✗';
  position: absolute; left: 0;
  color: var(--candy); font-size: 0.75rem;
}

/* Rule card (writing rules, mechanics) */
.rule-card {
  background: var(--bone);
  border-radius: 10px;
  padding: var(--space-xl);
}
.rule-card h4 { margin-bottom: var(--space-sm); }
.rule-card p { font-size: 0.9375rem; }

/* Human voice rule */
.hv-rule {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-xl);
  padding: var(--space-xl) 0;
  border-top: 1px solid var(--sand);
}
.hv-rule:first-child { border-top: none; }
.hv-rule__num {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 400;
  color: var(--sand);
  line-height: 1;
  padding-top: 4px;
}
.hv-rule__content h4 { margin-bottom: var(--space-sm); }
.hv-rule__content p { font-size: 0.9375rem; margin-bottom: var(--space-md); }
.example-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.example-block pre {
  background: var(--air);
  border-radius: 8px;
  padding: var(--space-md);
  font-size: 0.8125rem;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  border: 1px solid var(--sand);
  color: var(--lead);
}
.example-block pre.correct { border-color: var(--neon); }
.example-block pre.wrong { border-color: var(--rose); opacity: 0.7; }
.example-block .ex-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-xs);
}
.example-block .ex-label.correct { color: var(--basil); }
.example-block .ex-label.wrong { color: var(--candy); }
@media (max-width: 768px) {
  .hv-rule { grid-template-columns: 1fr; gap: var(--space-md); }
  .hv-rule__num { font-size: 2rem; }
  .example-block { grid-template-columns: 1fr; }
}

/* Callout / quote block */
.callout {
  background: var(--deep-royal);
  color: var(--air);
  border-radius: 12px;
  padding: var(--space-xl) var(--space-2xl);
}
.callout blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  line-height: 1.4;
  color: var(--air);
}
.callout cite {
  display: block;
  margin-top: var(--space-md);
  font-size: 0.875rem;
  color: var(--violet);
  font-style: normal;
}

/* Forbidden/vocabulary pill */
.vocab-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.vocab-pill {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 6px;
  background: var(--bone);
  color: var(--lead);
  border: 1px solid var(--sand);
}
.vocab-pill.forbidden {
  background: var(--ballet);
  color: var(--candy);
  border-color: var(--rose);
  text-decoration: line-through;
  text-decoration-color: var(--rose);
}
.vocab-pill.approved {
  background: var(--daiquiri);
  color: var(--basil);
  border-color: var(--neon);
}

/* ── COLOUR SYSTEM ──────────────────────────────────────────── */
.swatch-row {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-xl);
}
.swatch {
  flex: 1;
  min-width: 0;
  border-radius: 8px;
  overflow: hidden;
  transition: transform var(--dur-mid) var(--ease);
}
.swatch:hover { transform: translateY(-4px); z-index: 1; }
.swatch__block {
  height: 120px;
}
.swatch__info {
  padding: var(--space-md);
  background: var(--air);
  border: 1px solid var(--sand);
  border-top: none;
  border-radius: 0 0 8px 8px;
}
.swatch__name {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--obsidian);
  display: block;
  margin-bottom: 2px;
}
.swatch__hex {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--steel);
}
.swatch__desc {
  font-size: 0.6875rem;
  color: var(--steel);
  margin-top: 4px;
  line-height: 1.4;
}
@media (max-width: 768px) {
  .swatch-row { flex-wrap: wrap; }
  .swatch { flex: 0 0 calc(50% - 1px); }
  .swatch__block { height: 80px; }
}

/* Semantic colour groups */
.semantic-group {
  margin-bottom: var(--space-xl);
}
.semantic-group h5 {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--space-sm);
}
.semantic-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
}
@media (max-width: 768px) {
  .semantic-row { grid-template-columns: repeat(2, 1fr); }
}

/* Gradient preview */
.gradient-card {
  border-radius: 12px;
  overflow: hidden;
}
.gradient-card__preview {
  height: 160px;
}
.gradient-card__info {
  background: var(--bone);
  padding: var(--space-lg);
  border: 1px solid var(--sand);
  border-top: none;
  border-radius: 0 0 12px 12px;
}
.gradient-card__name { font-weight: 600; margin-bottom: var(--space-xs); }
.gradient-card__desc { font-size: 0.875rem; color: var(--lead); }

/* Misuse card */
.misuse-card {
  background: var(--air);
  border: 1px solid var(--sand);
  border-radius: 10px;
  overflow: hidden;
}
.misuse-card__header {
  padding: var(--space-md) var(--space-xl);
  background: var(--ballet);
  border-bottom: 1px solid var(--sand);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.misuse-card__header .num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--candy);
  color: var(--air);
  font-size: 0.75rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.misuse-card__header h5 { font-size: 0.9375rem; }
.misuse-card__body {
  padding: var(--space-xl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
}
.misuse-card__body > div { font-size: 0.875rem; }
.misuse-card__body .dont-label, .misuse-card__body .do-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-xs);
}
.misuse-card__body .dont-label { color: var(--candy); }
.misuse-card__body .do-label { color: var(--basil); }
.misuse-card__body p { color: var(--lead); line-height: 1.55; max-width: none; }
@media (max-width: 768px) {
  .misuse-card__body { grid-template-columns: 1fr; }
}

/* ── TYPOGRAPHY SPECIMENS ───────────────────────────────────── */
.type-specimen {
  background: var(--bone);
  border-radius: 12px;
  padding: var(--space-2xl);
  border: 1px solid var(--sand);
}
.type-specimen__meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--sand);
}
.type-specimen__name {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
}
.type-specimen__detail {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--steel);
  text-align: right;
}
.type-specimen__sample {
  margin-bottom: var(--space-lg);
}

.type-scale-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-xl);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--sand);
}
.type-scale-row:last-child { border-bottom: none; }
.type-scale-row__token {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--steel);
  width: 120px;
  flex-shrink: 0;
}
.type-scale-row__detail {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--violet);
  width: 140px;
  flex-shrink: 0;
}

/* Audience card */
.audience-card {
  background: var(--bone);
  border-radius: 12px;
  padding: var(--space-xl) var(--space-2xl);
}
.audience-card h3 { margin-bottom: var(--space-md); }
.audience-card .sub {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: var(--space-xs);
}
.audience-card .block { margin-bottom: var(--space-xl); }
.audience-card .block:last-child { margin-bottom: 0; }
.audience-card p { max-width: none; }

/* Key message card */
.message-card {
  background: var(--air);
  border: 1px solid var(--sand);
  border-radius: 10px;
  padding: var(--space-xl);
}
.message-card__audience {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--grape);
  margin-bottom: var(--space-sm);
}
.message-card h5 { margin-bottom: var(--space-md); font-size: 0.9375rem; }
.message-card p { font-size: 0.875rem; max-width: none; }

/* Boilerplate block */
.boilerplate {
  background: var(--deep-royal);
  color: var(--air);
  border-radius: 10px;
  padding: var(--space-xl);
  margin-bottom: var(--space-md);
}
.boilerplate__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: var(--space-md);
}
.boilerplate p {
  font-size: 0.9375rem;
  color: rgba(255,255,255,0.8);
  max-width: none;
  line-height: 1.65;
}

/* Checklist */
.checklist {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.checklist li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  font-size: 0.9375rem;
  color: var(--lead);
  padding: var(--space-md) var(--space-lg);
  background: var(--air);
  border: 1px solid var(--sand);
  border-radius: 8px;
}
.checklist li::before {
  content: '';
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 2px solid var(--grape);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Tagline display */
.tagline-primary {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.5rem, 5vw, 4rem);
  letter-spacing: -0.02em;
  color: var(--obsidian);
  line-height: 1.1;
  margin-bottom: var(--space-xl);
}

/* Code block with token JSON */
.code-block {
  background: var(--midnight);
  border-radius: 12px;
  overflow: hidden;
}
.code-block__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md) var(--space-xl);
  background: rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.code-block__lang {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--violet);
}
.code-block pre {
  padding: var(--space-xl);
  font-size: 0.8125rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.85);
  overflow-x: auto;
  background: transparent;
  white-space: pre;
}
.code-block code { background: none; color: inherit; padding: 0; }

/* Usage ratio bar */
.ratio-bar {
  display: flex;
  height: 48px;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: var(--space-xl);
}
.ratio-bar__seg {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--air);
  transition: flex var(--dur-slow) var(--ease);
}

/* ── CONTENT TABLE ──────────────────────────────────────────── */
.content-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.content-table th {
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  background: var(--bone);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--steel);
  border-bottom: 1px solid var(--sand);
}
.content-table td {
  padding: var(--space-md);
  border-bottom: 1px solid var(--sand);
  color: var(--lead);
  vertical-align: top;
  line-height: 1.5;
}
.content-table tr:last-child td { border-bottom: none; }
.content-table tr:hover td { background: var(--cloud); }
.content-table td:first-child { font-family: var(--font-mono); color: var(--obsidian); }

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer {
  background: var(--deep-royal);
  padding: var(--space-xl) 0;
}
.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  gap: var(--space-xl);
}
.footer-logo img { height: 20px; opacity: 0.9; }
.footer-meta {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.footer-meta span {
  font-size: 0.6875rem;
  color: rgba(255,255,255,0.4);
}
.footer-meta .system { color: var(--violet); font-weight: 500; }
@media (max-width: 768px) {
  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 var(--space-md);
    gap: var(--space-md);
  }
  .footer-meta { text-align: left; }
}

/* ── SCROLL REVEAL ANIMATIONS ───────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--dur-slow) var(--ease),
              transform var(--dur-slow) var(--ease);
}
.reveal.in-view {
  opacity: 1;
  transform: translateY(0);
}
.reveal-delay-1 { transition-delay: 80ms; }
.reveal-delay-2 { transition-delay: 160ms; }
.reveal-delay-3 { transition-delay: 240ms; }
.reveal-delay-4 { transition-delay: 320ms; }

/* ── UTILITY ─────────────────────────────────────────────────── */
.text-amber  { color: var(--amber); }
.text-grape  { color: var(--grape); }
.text-air    { color: var(--air); }
.text-steel  { color: var(--steel); }
.text-lead   { color: var(--lead); }
.bg-bone     { background: var(--bone); }
.bg-deep     { background: var(--deep-royal); }
.mono        { font-family: var(--font-mono); }
.italic      { font-style: italic; }
.mt-xl  { margin-top: var(--space-xl); }
.mt-2xl { margin-top: var(--space-2xl); }
.mb-xl  { margin-bottom: var(--space-xl); }
.mb-2xl { margin-bottom: var(--space-2xl); }
hr.divider {
  border: none;
  border-top: 1px solid var(--sand);
  margin: var(--space-2xl) 0;
}
hr.divider-dark {
  border: none;
  border-top: 1px solid rgba(255,255,255,0.1);
  margin: var(--space-xl) 0;
}
