/* Components */

/* ---------- Container ---------- */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* ---------- Top bar ---------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  backdrop-filter: saturate(120%);
}

.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding: var(--space-4) var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
}

.brand {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-xl);
  letter-spacing: -0.04em;
  text-transform: uppercase;
  line-height: 1;
  color: var(--ink);
}

.brand__mark { font-size: var(--text-2xl); }

.brand__tag {
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  font-weight: 500;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  align-self: center;
  padding-bottom: 2px;
}

.nav {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.nav__list {
  display: flex;
  gap: var(--space-6);
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav__link {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  padding: 6px 0;
  transition: color var(--transition);
}

.nav__link:hover, .nav__link[aria-current="page"] {
  color: var(--ink);
}

.nav__link[aria-current="page"]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--ink);
}

.controls {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.lang-toggle {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  gap: 6px;
  color: var(--muted);
  text-transform: uppercase;
}

.lang-toggle__btn {
  padding: 4px 6px;
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
}

.lang-toggle__btn[aria-pressed="true"] {
  color: var(--ink);
  background: var(--bg-elev);
}

.lang-toggle__sep {
  color: var(--faint);
  align-self: center;
}

.theme-toggle {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: inline-grid;
  place-items: center;
  transition: border-color var(--transition), background var(--transition);
}

.theme-toggle:hover { border-color: var(--ink); }

.theme-toggle svg { width: 14px; height: 14px; }

.nav-mobile-toggle {
  display: none;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
}

.nav-mobile-toggle svg { width: 18px; height: 18px; }

/* ---------- Status strip ---------- */
.status-strip {
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 10px var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.status-strip__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  display: inline-block;
  margin-left: auto;
  animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 0.4; transform: scale(0.9); }
  50% { opacity: 1; transform: scale(1.15); }
}

.status-strip__sep {
  color: var(--faint);
  margin: 0 4px;
}

/* ---------- Annotation pills ---------- */
.pill {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 10px;
  border: 1px solid var(--line);
  border-radius: var(--pill-radius);
  color: var(--muted);
  background: var(--bg);
  white-space: nowrap;
}

.pill--accent {
  color: var(--accent);
  border-color: var(--accent);
}

.pill--solid {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

/* ---------- Marquee ticker ---------- */
.marquee {
  background: var(--bg);
  color: var(--muted);
  overflow: hidden;
  border-block: 1px solid var(--line);
  padding: var(--space-4) 0;
  position: relative;
  opacity: 0.85;
}

.marquee--display {
  background: var(--bg-inv);
  color: var(--ink-on-inv);
  border-color: var(--bg-inv);
  padding: var(--space-6) 0;
  opacity: 1;
}

.marquee__track {
  display: flex;
  gap: var(--space-12);
  width: max-content;
  animation: marquee 90s linear infinite;
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: var(--text-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1;
}

.marquee--display .marquee__track {
  animation-duration: 120s;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 6vw, 4.5rem);
  letter-spacing: -0.03em;
}

.marquee__track--slow { animation-duration: 160s; }
.marquee__track--reverse { animation-direction: reverse; }

.marquee__item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-12);
}

.marquee__dot {
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.35;
  vertical-align: middle;
}

@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ---------- Footer ---------- */
.footer {
  border-top: 1px solid var(--line);
  padding: var(--space-16) var(--gutter) var(--space-8);
  max-width: var(--max-w);
  margin: 0 auto;
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-16);
}

.footer__head {
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--space-4);
}

.footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}

.footer__list a {
  font-size: var(--text-sm);
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color var(--transition);
}

.footer__list a:hover { border-bottom-color: var(--ink); }

.footer__big {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(4rem, 12vw, 10rem);
  letter-spacing: -0.04em;
  line-height: 0.85;
  text-transform: uppercase;
  margin: var(--space-12) 0;
  overflow: hidden;
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  padding-top: var(--space-6);
  border-top: 1px solid var(--line);
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* ---------- Reveal on scroll ---------- */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 800ms cubic-bezier(0.2, 0.6, 0.2, 1),
              transform 800ms cubic-bezier(0.2, 0.6, 0.2, 1);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ---------- Inline mono labels ---------- */
.label {
  font-family: var(--font-mono);
  font-size: var(--text-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.bracket-label::before { content: '[ '; }
.bracket-label::after { content: ' ]'; }

/* ---------- Section base ---------- */
.section {
  padding: var(--space-24) var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
}

.section--tight { padding-block: var(--space-16); }
.section--loose { padding-block: var(--space-32); }

.section__head {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
  align-items: end;
}

@media (max-width: 800px) {
  .section__head {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

/* ---------- Underlined link ---------- */
.link {
  position: relative;
  display: inline-block;
  padding-bottom: 1px;
  border-bottom: 1px solid currentColor;
  transition: color var(--transition);
}

.link--accent:hover { color: var(--accent); border-bottom-color: var(--accent); }

/* ---------- Mobile responsive ---------- */
@media (max-width: 900px) {
  .nav__list { display: none; }
  .nav-mobile-toggle { display: inline-flex; }
  .topbar.nav-open .nav__list {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg);
    border-bottom: 1px solid var(--line);
    flex-direction: column;
    padding: var(--space-6) var(--gutter);
    gap: var(--space-4);
  }
}

@media (max-width: 800px) {
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
  .footer__big { font-size: clamp(3rem, 18vw, 6rem); }
}

@media (max-width: 480px) {
  .footer__grid { grid-template-columns: 1fr; }
  .status-strip__dot { margin-left: 0; }
}
