/* ============================================================================
 * RiftWords landing · style-pages.css
 * Sibling to style.css · sections 10-16 (screenshots, languages, press, footer,
 * doc pages, reduced-motion, print). Split out so each file stays under the
 * 500-line project limit. Same tokens, no duplication.
 * ============================================================================ */

/* ---------------------------------------------------------------------------
 * 10 · Screenshots band (landing-brief §9.6)
 * --------------------------------------------------------------------------- */
.screenshots { padding-top: var(--space-7); padding-bottom: var(--space-7); }
.screenshots__rail {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 48rem) { .screenshots__rail { grid-template-columns: 1fr 1fr; } }
@media (min-width: 64rem) { .screenshots__rail { grid-template-columns: repeat(3, 1fr); } }

.screenshots figure { margin: 0; }
.screenshots .phone-frame { max-width: 280px; margin: 0 auto; }
.screenshots figcaption {
  margin-top: var(--space-3);
  text-align: center;
  font-size: var(--text-body-sm);
  color: var(--color-ink-muted);
}

/* ---------------------------------------------------------------------------
 * 11 · Languages (landing-brief §9.7)
 * --------------------------------------------------------------------------- */
.languages {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border-soft);
  border-bottom: 1px solid var(--color-border-soft);
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
}
.languages h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-h2);
  line-height: 1.2;
  letter-spacing: -0.01em;
  max-width: 22ch;
  margin-bottom: var(--space-6);
}
.languages__columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
@media (min-width: 48rem) {
  .languages__columns { grid-template-columns: 1fr 1fr 1fr; gap: var(--space-5); }
}
.lang-col h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-size: var(--text-body);
  margin: 0 0 var(--space-4);
  color: var(--color-ink-muted);
}
.lang-list { display: flex; flex-direction: column; gap: var(--space-2); }
.lang-list li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 1rem;
}
.lang-list--coming li { color: var(--color-ink-dim); font-weight: 500; }
.lang-list--roadmap li { color: var(--color-ink-muted); font-weight: 500; }

/* Flag icon (SVG image) · 28×21px (4:3 ratio matches lipis/flag-icons source).
   Slight border + radius softens the edge against the dark surface. */
.lang-flag {
  width: 28px;
  height: 21px;
  flex: 0 0 28px;
  border-radius: 3px;
  border: 1px solid var(--color-border-soft);
  object-fit: cover;
  display: block;
}

/* Cyrillic + Greek don't have glyphs in the bundled Barlow Condensed subset.
   Force a system-fallback chain with good non-Latin bold coverage, and tighten
   letter-spacing to compensate for non-condensed fallback widening. Long-term
   fix: ship Barlow Condensed with Cyrillic + Greek subsets. */
.lang-list li:lang(ru),
.lang-list li:lang(uk),
.lang-list li:lang(el),
.lang-list li:lang(ko),
.lang-list li:lang(ja) {
  font-family: "Helvetica Neue", "Arial Black", "Segoe UI", "Noto Sans CJK KR", "Noto Sans CJK JP", "Hiragino Sans", system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: 0.02em;
  font-size: 0.95em;
}
/* Korean + Japanese specifically: prefer OS CJK fonts (macOS / Windows have these by default). */
.lang-list li:lang(ko) {
  font-family: "Apple SD Gothic Neo", "Malgun Gothic", "Noto Sans KR", "Helvetica Neue", system-ui, sans-serif;
}
.lang-list li:lang(ja) {
  font-family: "Hiragino Sans", "Yu Gothic", "Meiryo", "Noto Sans JP", "Helvetica Neue", system-ui, sans-serif;
}
.languages__note {
  color: var(--color-ink-dim);
  max-width: 60ch;
  margin: 0;
}

/* ---------------------------------------------------------------------------
 * 12 · Press / contact (landing-brief §9.8)
 * --------------------------------------------------------------------------- */
.press { padding-top: var(--space-8); padding-bottom: var(--space-7); }
.press__grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 48rem) {
  .press__grid { grid-template-columns: 1.2fr 1fr; }
}

.quote-panel {
  background: var(--color-surface-soft);
  color: var(--color-ink-on-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-6);
}
.quote-panel blockquote {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.4;
  letter-spacing: -0.01em;
}
.quote-panel cite {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: var(--text-body-sm);
  font-style: normal;
  color: var(--color-ink-on-soft);
  opacity: 0.7;
}

.contact-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.contact-card h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-h3);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin: 0 0 var(--space-4);
}
.contact-card .eyebrow { color: var(--color-accent-teal); }
.contact-list { display: flex; flex-direction: column; gap: var(--space-3); margin: 0 0 var(--space-5); }
.contact-list dt {
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-size: var(--text-body-sm);
  color: var(--color-ink-muted);
}
.contact-list dd { margin: 0 0 var(--space-2); color: var(--color-ink-dim); }

.copy-button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-pill);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--text-mono);
  letter-spacing: 0.06em;
  transition: border-color var(--dur-hover) var(--ease-out), color var(--dur-hover) var(--ease-out);
}
.copy-button:hover { border-color: var(--color-border-strong); }
.copy-button.is-copied { color: var(--color-success); border-color: var(--color-success); }
.copy-button svg { width: 14px; height: 14px; }

.social-row {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.social-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-soft);
  color: var(--color-ink-dim);
  transition: border-color var(--dur-hover) var(--ease-out), color var(--dur-hover) var(--ease-out);
}
.social-row a:hover { color: var(--color-ink); border-color: var(--color-border-strong); text-decoration: none; }
.social-row svg { width: 20px; height: 20px; }

/* ---------------------------------------------------------------------------
 * 13 · Footer (landing-brief §9.9)
 * --------------------------------------------------------------------------- */
.site-footer {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border-soft);
  padding: var(--space-7) 0 var(--space-6);
  margin-top: var(--space-7);
}
.site-footer .shell { display: grid; gap: var(--space-5); grid-template-columns: 1fr; align-items: start; }
@media (min-width: 48rem) {
  .site-footer .shell { grid-template-columns: 1fr 1fr 1fr; align-items: center; }
}
.footer__brand { display: flex; flex-direction: column; gap: var(--space-2); }
.footer__brand .studio-mark { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--color-ink); }
.footer__brand .studio-mark__logo { color: var(--color-primary); overflow: visible; }
.footer__brand .studio-mark__wordmark { height: 22px; width: auto; display: block; }
.footer__brand small { color: var(--color-ink-muted); font-size: var(--text-body-sm); }
.footer__legal { display: flex; gap: var(--space-5); flex-wrap: wrap; justify-content: flex-start; }
@media (min-width: 48rem) { .footer__legal { justify-content: center; } }
.footer__legal a { color: var(--color-ink-dim); font-weight: 500; font-size: var(--text-body-sm); }
.footer__build {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--text-mono);
  letter-spacing: 0.06em;
  color: var(--color-ink-muted);
  text-transform: uppercase;
  margin: 0;
}
@media (min-width: 48rem) { .footer__build { text-align: right; } }
.footer__locale {
  grid-column: 1 / -1;
  text-align: center;
  font-size: var(--text-mono);
  color: var(--color-ink-muted);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-soft);
}

/* ---------------------------------------------------------------------------
 * 14 · Article pages (privacy, security-policy)
 * --------------------------------------------------------------------------- */
.doc { padding-top: var(--space-8); padding-bottom: var(--space-8); }
.doc article { max-width: 44rem; margin: 0 auto; }
.doc h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 2.5rem);
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin-bottom: var(--space-4);
}
.doc h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-h2);
  letter-spacing: -0.01em;
  margin-top: var(--space-7);
  margin-bottom: var(--space-4);
}
.doc h3 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-h3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
  color: var(--color-ink);
}
.doc p, .doc li { color: var(--color-ink-dim); }
.doc strong { color: var(--color-ink); font-weight: 500; }
.doc ul { list-style: disc; padding-left: var(--space-5); margin: 0 0 var(--space-5); }
.doc ul ul { list-style: circle; margin-top: var(--space-2); }
.doc li { margin-bottom: var(--space-2); max-width: 65ch; }
.doc code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--color-surface);
  border: 1px solid var(--color-border-soft);
  border-radius: 4px;
  padding: 1px 6px;
  color: var(--color-ink);
}
.doc header time, .doc header strong { color: var(--color-ink); }
.doc > article > header { margin-bottom: var(--space-6); }
.doc > article > footer {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-soft);
  font-size: var(--text-body-sm);
  color: var(--color-ink-muted);
}

/* ---------------------------------------------------------------------------
 * 15 · Reduced motion (brand-guide §6.4, landing-brief §7.3)
 * --------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: opacity 0.01ms; }
  .daily__pill::before { animation: none; opacity: 1; }
}

/* ---------------------------------------------------------------------------
 * 16 · Print
 * --------------------------------------------------------------------------- */
@media print {
  body { background: #fff; color: #000; }
  .site-header, .site-footer, .skip-link, .cta-row, .social-row { display: none; }
  .doc { padding: 0; }
  a { color: #000; text-decoration: underline; }
}
