/* MAHNIA — component + layout styles. Tokens live in tokens.css. */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--type-body-md);
  line-height: 1.55;
  color: var(--color-ink);
  background: var(--color-canvas);
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ─── Layout primitives ─── */
.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
  width: 100%;
}

.band {
  padding-block: clamp(48px, 8vw, 96px);
}
.band--ink   { background: var(--color-ink);   color: var(--color-on-dark); }
.band--red   { background: var(--color-primary); color: var(--color-on-primary); }
.band--light { background: var(--color-canvas); color: var(--color-ink); }
.band--soft  { background: var(--color-canvas-soft); color: var(--color-ink); }

/* ─── Typography roles ─── */
.eyebrow {
  font-size: var(--type-eyebrow);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 var(--space-lg);
}
.display-hero {
  font-family: var(--font-display);
  font-size: var(--type-hero);
  font-weight: 800;
  line-height: 0.92;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}
.display-lg {
  font-size: var(--type-display-lg);
  font-weight: 300;
  line-height: 1.08;
  margin: 0;
}
.display-md {
  font-size: var(--type-display-md);
  font-weight: 300;
  line-height: 1.1;
  margin: 0;
}
.display-sm {
  font-size: var(--type-display-sm);
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
}
.lead {
  font-size: var(--type-body-lg);
  font-weight: 300;
  line-height: 1.5;
  max-width: 52ch;
}
.muted { color: var(--color-body); }

/* ─── Buttons (pills) ─── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--type-body-md);
  font-weight: 600;
  line-height: 1;
  padding: var(--space-md) var(--space-2xl);
  border-radius: var(--radius-pill-lg);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .12s ease, opacity .12s ease, background-color .12s ease, color .12s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary {
  background: var(--color-primary);
  color: var(--color-on-primary);
  border-color: var(--color-primary);
}
.btn--primary:hover { opacity: .92; }
.btn--outline-red {
  background: var(--color-canvas);
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn--outline-light {
  background: transparent;
  color: var(--color-on-dark);
  border-color: var(--color-on-dark);
}
.btn--outline-light:hover { background: var(--color-on-dark); color: var(--color-ink); }

/* ─── Badge chips ─── */
.chip {
  display: inline-block;
  background: var(--color-canvas-soft);
  color: var(--color-ink);
  font-size: var(--type-caption);
  font-weight: 700;
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-pill-md);
}
.band--ink .chip { background: rgba(255,255,255,.12); color: var(--color-on-dark); }

/* ─── Nav ─── */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-ink);
  color: var(--color-on-dark);
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2xl);
  padding-block: var(--space-md);
}
.nav__brand { display: flex; align-items: center; gap: var(--space-md); }
.nav__logo { height: 44px; width: auto; border-radius: var(--radius-xs); }
.nav__wordmark { font-weight: 800; letter-spacing: 0.06em; font-size: var(--type-body-md); }
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--space-2xl);
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav__link {
  font-size: var(--type-body-sm);
  color: var(--color-on-dark);
  opacity: .85;
  transition: opacity .12s ease;
}
.nav__link:hover { opacity: 1; }
.nav__item--dropdown { position: relative; }
.nav__item--dropdown > .nav__link { display: inline-flex; align-items: center; gap: var(--space-xs); }
.nav__caret { transition: transform .15s ease; }
.nav__item--dropdown:hover .nav__caret,
.nav__item--dropdown:focus-within .nav__caret { transform: rotate(180deg); }
.nav__dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  margin: 0;
  padding: var(--space-sm) 0;
  list-style: none;
  background: var(--color-ink);
  border-top: 2px solid var(--color-primary);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity .14s ease, transform .14s ease, visibility .14s;
  z-index: 60;
}
.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown:focus-within .nav__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav__dropdown .nav__link { display: block; padding: var(--space-sm) var(--space-lg); white-space: nowrap; }
.nav__toggle {
  display: none;
  background: none;
  border: 0;
  color: var(--color-on-dark);
  cursor: pointer;
  padding: var(--space-sm);
}
.nav__toggle svg { display: block; }

/* ─── Hero ─── */
.hero {
  position: relative;
  background: var(--color-ink);
  color: var(--color-on-dark);
  overflow: hidden;
  min-height: clamp(440px, 72vh, 760px);
  display: flex;
  align-items: flex-end;
}
.hero__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .42;
}
.hero__inner {
  position: relative;
  z-index: 1;
  padding-block: clamp(48px, 8vw, 96px);
}
.hero__headline { max-width: 16ch; }
.hero__copy { margin-top: var(--space-2xl); color: rgba(255,255,255,.86); }
.hero__actions { margin-top: var(--space-3xl); display: flex; flex-wrap: wrap; gap: var(--space-md); }

/* ─── Section heading block ─── */
.section-head { max-width: 60ch; margin-bottom: clamp(32px, 5vw, 56px); }

/* ─── Card grid ─── */
.grid { display: grid; gap: var(--space-2xl); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

.card {
  background: var(--color-canvas);
  color: var(--color-ink);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  border: 1px solid var(--color-canvas-soft);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  height: 100%;
}
.card__media {
  border-radius: var(--radius-card);
  aspect-ratio: 16 / 9;
  object-fit: cover;
  width: 100%;
}
.card__title { font-size: var(--type-display-xs); font-weight: 700; line-height: 1.2; margin: 0; }
.card__meta { font-size: var(--type-caption); color: var(--color-body); }
.card__index {
  font-size: var(--type-display-sm);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}

/* Issue card — flat, ink-on-canvas, red index */
.issue {
  background: var(--color-canvas-soft);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  height: 100%;
}
.issue__title { font-size: var(--type-display-xs); font-weight: 700; margin: var(--space-sm) 0 0; }
.issue__desc { font-size: var(--type-body-sm); color: var(--color-body); margin: 0; }

/* ─── Mission focal (red band) ─── */
.mission__quote {
  font-size: var(--type-display-lg);
  font-weight: 300;
  line-height: 1.15;
  max-width: 22ch;
  margin: 0;
}
.mission__cite { margin-top: var(--space-2xl); font-weight: 700; font-size: var(--type-body-sm); letter-spacing: .04em; text-transform: uppercase; }

/* ─── Footer ─── */
.footer { background: var(--color-ink); color: var(--color-on-dark); }
.footer__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--space-3xl);
  padding-block: clamp(48px, 6vw, 72px);
}
.footer__col h3 {
  font-size: var(--type-caption-upper);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
  color: var(--color-mute);
  margin: 0 0 var(--space-lg);
}
.footer__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-sm); }
.footer__col a { color: rgba(255,255,255,.82); font-size: var(--type-body-sm); }
.footer__col a:hover { color: var(--color-on-dark); }
.footer__brand { display: flex; align-items: center; gap: var(--space-md); margin-bottom: var(--space-lg); }
.footer__brand img { height: 56px; width: auto; }
.footer__contact { display: grid; gap: var(--space-xs); font-size: var(--type-body-sm); color: rgba(255,255,255,.82); }
.footer__bottom {
  border-top: 1px solid rgba(255,255,255,.16);
  padding-block: var(--space-xl);
  font-size: var(--type-caption);
  color: var(--color-mute);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-md);
}
.social { display: flex; gap: var(--space-md); margin-top: var(--space-lg); }
.social a {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: var(--radius-full);
}
.social a:hover { background: var(--color-primary); border-color: var(--color-primary); }

/* ─── Inner page header ─── */
.page-hero {
  position: relative;
  background: var(--color-ink);
  color: var(--color-on-dark);
  overflow: hidden;
}
.page-hero__media {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: .3;
}
.page-hero__inner { position: relative; z-index: 1; padding-block: clamp(56px, 9vw, 120px); }
.page-hero h1 {
  font-family: var(--font-display);
  font-size: var(--type-display-xl);
  font-weight: 800;
  text-transform: uppercase;
  line-height: 0.95;
  letter-spacing: -0.01em;
  margin: 0;
  max-width: 18ch;
}
.page-hero p { margin-top: var(--space-2xl); }

/* ─── Prose ─── */
.prose { max-width: 68ch; }
.prose p { margin: 0 0 var(--space-lg); font-size: var(--type-body-lg); font-weight: 300; color: var(--color-ink); }
.prose p.muted { color: var(--color-body); }

/* ─── Values / feature list ─── */
.values { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-2xl); }
.value { border-top: 3px solid var(--color-primary); padding-top: var(--space-md); }
.value h3 { margin: 0 0 var(--space-xs); font-size: var(--type-display-xs); font-weight: 700; }
.value p { margin: 0; font-size: var(--type-body-sm); color: var(--color-body); }

/* ─── Stat row ─── */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2xl); }
.stat__num { font-size: var(--type-display-md); font-weight: 800; color: var(--color-primary); line-height: 1; }
.stat__label { margin-top: var(--space-sm); font-size: var(--type-body-sm); color: var(--color-body); }

/* ─── People (committee) ─── */
.people { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 clamp(40px, 6vw, 88px); }
.person {
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-lg);
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--color-canvas-soft);
}
.person__name { font-weight: 700; font-size: var(--type-body-lg); }
.person__org { color: var(--color-body); font-size: var(--type-body-sm); }
.person__role {
  font-size: var(--type-caption-upper); text-transform: uppercase; letter-spacing: .06em;
  font-weight: 700; color: var(--color-primary); white-space: nowrap;
}

/* ─── Member grid ─── */
.members-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
.member {
  background: var(--color-canvas-soft);
  border-radius: var(--radius-sm);
  padding: var(--space-md) var(--space-lg);
  font-size: var(--type-body-sm);
  font-weight: 600;
  display: flex; align-items: center; gap: var(--space-md);
}
.member__dot { width: 6px; height: 6px; border-radius: var(--radius-full); background: var(--color-primary); flex: none; }

/* ─── Pricing tiers ─── */
.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2xl); }
.tier {
  background: var(--color-canvas-soft);
  border: 1px solid var(--color-mute);
  border-radius: var(--radius-card);
  padding: var(--space-2xl);
  display: flex; flex-direction: column; gap: var(--space-md); height: 100%;
}
.tier--featured { background: var(--color-ink); color: var(--color-on-dark); border-color: var(--color-ink); }
.tier--featured .tier__note, .tier--featured .muted { color: rgba(255,255,255,.7); }
.tier__name { font-size: var(--type-display-xs); font-weight: 700; }
.tier__price { font-size: var(--type-display-md); font-weight: 800; line-height: 1; }
.tier__price span { font-size: var(--type-body-sm); font-weight: 400; color: var(--color-body); }
.tier--featured .tier__price span { color: rgba(255,255,255,.7); }
.tier__note { font-size: var(--type-body-sm); color: var(--color-body); }
.tier .btn { margin-top: auto; justify-content: center; }

/* ─── Forms ─── */
.form { display: grid; gap: var(--space-lg); max-width: 560px; }
.field { display: grid; gap: var(--space-xs); }
.field label { font-size: var(--type-caption); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.field input, .field textarea {
  font: inherit;
  padding: var(--space-md) var(--space-lg);
  border: 1px solid var(--color-ink);
  border-radius: var(--radius-sm);
  background: var(--color-canvas);
  color: var(--color-ink);
}
.field textarea { min-height: 140px; resize: vertical; }

/* ─── FAQs ─── */
.faqs { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(40px, 6vw, 72px) clamp(40px, 6vw, 96px); }
.faq__q {
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-lg);
  margin: 0 0 var(--space-lg);
  color: var(--color-primary);
  font-size: var(--type-body-lg);
  font-weight: 700;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.faq__icon { flex: none; color: var(--color-primary); margin-top: 2px; }
.faq__a { margin: 0; color: var(--color-body); font-size: var(--type-body-md); max-width: 46ch; }

/* ─── Email template ─── */
.email-template {
  background: var(--color-canvas);
  border: 1px solid var(--color-ink);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.email-template__head {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-ink);
  color: var(--color-on-dark);
}
.email-template__head .eyebrow { margin: 0; }
.email-template__body {
  margin: 0;
  padding: var(--space-xl);
  font-family: "SFMono-Regular", ui-monospace, "Cascadia Code", Menlo, Consolas, monospace;
  font-size: var(--type-body-sm);
  line-height: 1.9;
  color: var(--color-ink);
  white-space: pre-wrap;
}
.email-template__meta { color: var(--color-body); }
.btn--ghost-light {
  background: transparent; color: var(--color-on-dark);
  border-color: rgba(255,255,255,.4);
  padding: var(--space-sm) var(--space-lg); font-size: var(--type-body-sm);
}
.btn--ghost-light:hover { background: var(--color-on-dark); color: var(--color-ink); }

/* ─── Contact split ─── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 80px); }
.contact-detail { margin-bottom: var(--space-xl); }
.contact-detail h3 { font-size: var(--type-caption-upper); text-transform: uppercase; letter-spacing: .06em; color: var(--color-body); margin: 0 0 var(--space-xs); }
.contact-detail p, .contact-detail a { margin: 0; font-size: var(--type-body-md); }

/* ─── Two-up feature ─── */
.feature-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 72px); align-items: center; }
.feature-split img { border-radius: var(--radius-card); aspect-ratio: 4/3; object-fit: cover; width: 100%; }

/* ─── Responsive ─── */
@media (max-width: 1023px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .values { grid-template-columns: repeat(2, 1fr); }
  .tiers { grid-template-columns: 1fr; max-width: 460px; }
}
@media (max-width: 768px) {
  .grid--3 { grid-template-columns: repeat(2, 1fr); }
  .members-grid { grid-template-columns: repeat(2, 1fr); }
  .people { grid-template-columns: 1fr; }
  .split, .feature-split { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr; gap: var(--space-lg); }
  .faqs { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .nav__links {
    display: none;
    position: absolute;
    inset: 100% 0 auto;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    background: var(--color-ink);
    padding: var(--space-lg) var(--gutter) var(--space-2xl);
    border-top: 1px solid rgba(255,255,255,.12);
  }
  .nav__links--open { display: flex; }
  .nav__links .nav__link { padding-block: var(--space-md); width: 100%; }
  .nav__links .btn { margin-top: var(--space-md); }
  .nav__toggle { display: inline-flex; }
  .nav__caret { display: none; }
  .nav__dropdown {
    position: static; opacity: 1; visibility: visible; transform: none;
    background: transparent; border-top: 0; min-width: 0;
    padding: 0 0 var(--space-sm) var(--space-lg);
  }
  .nav__dropdown .nav__link { padding-block: var(--space-sm); }
  .grid--2, .grid--3 { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .values, .members-grid { grid-template-columns: 1fr; }
}
