/* ─────────────────────────────────────────────────────────────
   Page 07 — Typography
   ───────────────────────────────────────────────────────────── */

/* Two-family specimen */
.type-family {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 900px) { .type-family { grid-template-columns: 1fr; } }
.family-card {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: 36px 32px 36px;
  background: rgba(255,255,255,0.02);
  position: relative;
  overflow: hidden;
}
.family-card .meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 18px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.family-card .meta .role { color: var(--blue-300); }
.family-card .glyph-large {
  font-family: var(--font-sans);
  font-size: clamp(96px, 12vw, 184px);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-weight: 600;
  color: var(--fg-default);
  margin: 0 0 18px;
}
.family-card.mono .glyph-large {
  font-family: var(--font-mono);
  font-weight: 400;
  letter-spacing: 0;
}
.family-card .alphabet {
  font-size: 17px;
  line-height: 1.45;
  color: var(--fg-secondary);
  letter-spacing: -0.005em;
  margin: 0 0 18px;
  border-bottom: 1px solid var(--border-subtle);
  padding-bottom: 16px;
}
.family-card.mono .alphabet { font-family: var(--font-mono); font-size: 14.5px; }
.family-card h4 {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 6px;
}
.family-card p {
  font-size: 14px;
  color: var(--fg-secondary);
  line-height: 1.6;
  margin: 0;
}

/* Type scale — vertical specimen ladder */
.scale-ladder {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.scale-ladder .step {
  display: grid;
  grid-template-columns: 110px 1fr 180px;
  align-items: center;
  padding: 22px 24px;
  border-bottom: 1px solid var(--border-subtle);
  gap: 24px;
}
.scale-ladder .step:last-child { border-bottom: 0; }
@media (max-width: 820px) {
  .scale-ladder .step { grid-template-columns: 90px 1fr; }
  .scale-ladder .step .props { display: none; }
}
.scale-ladder .step .token {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.scale-ladder .step .token b {
  color: var(--blue-300);
  font-weight: 500;
  display: block;
  margin-bottom: 4px;
}
.scale-ladder .step .specimen {
  color: var(--fg-default);
  text-wrap: balance;
}
.scale-ladder .step .props {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
  text-align: right;
  line-height: 1.55;
}
.scale-ladder .step .props b {
  color: var(--fg-secondary);
  font-weight: 400;
}

/* Weight row */
.weight-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
@media (max-width: 900px) { .weight-row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .weight-row { grid-template-columns: repeat(2, 1fr); } }
.weight-card {
  padding: 24px 20px 22px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,0.02);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.weight-card .glyph {
  font-size: 56px;
  line-height: 0.95;
  letter-spacing: -0.025em;
  color: var(--fg-default);
}
.weight-card .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--fg-muted);
  text-transform: uppercase;
}
.weight-card .meta b {
  color: var(--blue-300);
  font-weight: 500;
}

/* Pairing — sans + mono in a real card */
.pairing-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 900px) { .pairing-grid { grid-template-columns: 1fr; } }
.pair-card {
  border-radius: var(--radius-xl);
  border: 1px solid;
  padding: 32px 30px 36px;
  position: relative;
  overflow: hidden;
}
.pair-card.daylight {
  background: #FFFFFF;
  color: #000;
  border-color: rgba(0,0,0,0.08);
}
.pair-card.nightfall {
  background:
    radial-gradient(ellipse 80% 100% at 100% 0%, rgba(47,55,255,0.16), transparent 60%),
    #050818;
  color: #FFFFFF;
  border-color: rgba(255,255,255,0.10);
}
.pair-card .ts {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 14px;
}
.pair-card.daylight .ts { color: #767781; }
.pair-card.nightfall .ts { color: rgba(255,255,255,0.55); }
.pair-card .ts b { font-weight: 500; }
.pair-card.daylight .ts b { color: var(--blue-700); }
.pair-card.nightfall .ts b { color: var(--blue-300); }
.pair-card .ed {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.pair-card.daylight .ed { color: var(--blue-700); }
.pair-card.nightfall .ed { color: var(--blue-300); }
.pair-card .lead {
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.025em;
  line-height: 1.08;
  font-weight: 600;
  margin: 0 0 18px;
  text-wrap: balance;
}
.pair-card .body {
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 20px;
}
.pair-card.daylight .body { color: #434349; }
.pair-card.nightfall .body { color: rgba(255,255,255,0.78); }
.pair-card .annotation {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  border-left: 1px solid;
  padding-left: 12px;
}
.pair-card.daylight .annotation { color: #767781; border-left-color: rgba(0,0,0,0.16); }
.pair-card.nightfall .annotation { color: rgba(255,255,255,0.6); border-left-color: rgba(255,255,255,0.16); }

/* Type don'ts */
.type-donts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 820px) { .type-donts { grid-template-columns: 1fr; } }
.type-dont {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: rgba(255,255,255,0.02);
}
.type-dont .demo {
  height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 22px;
  position: relative;
  border-bottom: 1px solid var(--border-subtle);
  text-align: center;
  font-size: 26px;
  letter-spacing: -0.018em;
  font-weight: 600;
  color: var(--fg-default);
}
.type-dont .demo::after {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  top: 50%;
  height: 2px;
  background: var(--orange-500);
  transform: rotate(-8deg);
  opacity: 0.85;
}
.type-dont .info {
  padding: 14px 18px 18px;
}
.type-dont .info .x {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--orange-300);
  margin-bottom: 6px;
}
.type-dont .info h5 {
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 4px;
  letter-spacing: -0.005em;
}
.type-dont .info p {
  font-size: 12.5px;
  color: var(--fg-muted);
  line-height: 1.5;
  margin: 0;
}
