:root {
  --bg: #edf2ea;
  --mist: rgba(204, 219, 214, 0.65);
  --paper: rgba(255, 252, 244, 0.82);
  --line: rgba(93, 116, 103, 0.2);
  --ink: #141414;
  --muted: #688278;
  --pill: #fff46c;
  --pill-border: rgba(186, 174, 53, 0.45);
  --pill-shadow: 0 10px 18px rgba(68, 65, 24, 0.24);
  --pill-disabled: rgba(255, 245, 143, 0.56);
  --panel-shadow: 0 22px 50px rgba(72, 84, 76, 0.12);
  --radius-xl: 40px;
  --radius-lg: 999px;
  --radius-sm: 14px;
  --font-display: "Fraunces", "Iowan Old Style", "Palatino Linotype", serif;
  --font-body: "Manrope", "Avenir Next", "Helvetica Neue", sans-serif;
}

@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=Manrope:wght@400;500;600;700&display=swap");

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background:
    radial-gradient(circle at 15% 12%, rgba(248, 220, 162, 0.45), transparent 24%),
    radial-gradient(circle at 82% 14%, rgba(195, 219, 211, 0.55), transparent 24%),
    linear-gradient(180deg, #edf2ea 0%, #d9e4de 100%);
  min-height: 100vh;
}

.shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 44px 24px 72px;
}

.hero {
  text-align: center;
  margin-bottom: 34px;
}

.eyebrow {
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}

.brand-mark {
  font-family: var(--font-body);
  font-size: clamp(62px, 12vw, 128px);
  line-height: 0.92;
  letter-spacing: 0.02em;
  margin-bottom: 12px;
}

h1, h2 {
  margin: 0;
  font-family: var(--font-display);
  line-height: 1.05;
}

h1 {
  font-size: clamp(30px, 4vw, 50px);
  max-width: 14ch;
  margin: 0 auto;
}

h2 {
  font-size: 34px;
}

.lede,
.capability-note p {
  color: var(--muted);
  line-height: 1.65;
}

.lede {
  max-width: 60ch;
  margin: 16px auto 0;
}

.module-panel,
.capability-note {
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow: var(--panel-shadow);
  background: linear-gradient(145deg, rgba(255, 251, 245, 0.82), rgba(236, 244, 239, 0.68));
  backdrop-filter: blur(12px);
}

.module-panel {
  padding: 28px 24px 26px;
}

.panel-label {
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 22px;
}

.panel-label.secondary {
  margin-top: 22px;
}

.module-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px 16px;
}

.core-grid {
  margin-bottom: 6px;
}

.module-button {
  min-height: 82px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: inherit;
  padding: 16px 22px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--pill-border);
  background: var(--pill);
  box-shadow: var(--pill-shadow);
  text-align: center;
}

.module-button.available:hover {
  transform: translateY(-2px) scale(1.01);
}

.module-button.pending {
  background: var(--pill-disabled);
  color: rgba(20, 20, 20, 0.82);
  box-shadow: 0 8px 14px rgba(78, 73, 28, 0.14);
}

.module-button.tribe {
  outline: 2px solid rgba(48, 128, 92, 0.28);
  outline-offset: 2px;
}

.module-name {
  font-size: 18px;
  font-weight: 700;
}

.module-meta {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.capability-note {
  margin-top: 24px;
  padding: 28px 30px;
}

@media (max-width: 720px) {
  .shell {
    padding: 28px 16px 40px;
  }

  .module-grid {
    grid-template-columns: 1fr;
  }
}
