/* ============================================================
   Components — header, buttons, cards, footer, nav
   ============================================================ */

/* --- Header --- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-2) var(--ease), background var(--dur-2) var(--ease), backdrop-filter var(--dur-2) var(--ease);
}
.site-header.is-scrolled {
  background: rgba(255,255,255,0.78);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom-color: var(--line);
}
.header-inner { display: flex; align-items: center; gap: var(--s-6); min-height: 76px; }

/* Logo (full name lockup, no acronym) */
.logo { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; color: var(--ink); }
.logo:hover { color: var(--ink); }
.logo-mark { width: 32px; height: 32px; flex: none; }
.logo-word { display: flex; flex-direction: column; line-height: 1.08; }
.logo-word .lw-1 { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-4); }
.logo-word .lw-2 { font-size: 1.02rem; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); }
@media (max-width: 520px) { .logo-word .lw-2 { font-size: 0.92rem; } .logo-word .lw-1 { font-size: 0.55rem; } }

/* Desktop nav */
.nav-desktop { display: flex; align-items: center; gap: var(--s-3); margin-left: auto; }
.nav-list { display: flex; align-items: center; gap: 4px; }
.nav-link {
  display: inline-block; padding: 8px 12px; color: var(--ink-2); font-weight: 500;
  font-size: 0.95rem; border-radius: var(--r-sm); text-decoration: none;
  transition: color var(--dur-1) var(--ease);
}
.nav-link:hover { color: var(--ink); }
.nav-link[aria-current="page"] { color: var(--ink); font-weight: 600; }
.nav-menu, .nav-list { margin-right: var(--s-2); }

.nav-menu { position: relative; }
.nav-menu-btn {
  display: inline-flex; align-items: center; gap: 5px; padding: 9px 14px;
  background: none; border: 0; color: var(--ink-2); font-weight: 500; font-size: 0.95rem;
  border-radius: var(--r-sm);
}
.nav-menu-btn:hover { background: var(--bg-soft); color: var(--ink); }
.nav-menu-btn .chev { width: 14px; height: 14px; transition: transform var(--dur-1) var(--ease); }
.nav-menu-btn[aria-expanded="true"] .chev { transform: rotate(180deg); }
.nav-menu-panel {
  position: absolute; top: calc(100% + 10px); left: 0; min-width: 340px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg); padding: var(--s-3); display: none;
}
.nav-menu-panel.is-open { display: block; }
.nav-menu-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-4); padding: 6px 12px 8px; }
.nav-menu-item { display: flex; gap: 13px; align-items: flex-start; padding: 11px 12px; border-radius: var(--r); text-decoration: none; color: var(--ink-3); transition: background var(--dur-1) var(--ease); }
.nav-menu-item:hover { background: var(--bg-soft); color: var(--ink-3); }
.nav-menu-item .mi-dot { width: 9px; height: 9px; border-radius: 50%; margin-top: 7px; flex: none; background: var(--accent); }
.nav-menu-item .mi-title { font-weight: 600; color: var(--ink); display: block; font-size: 0.95rem; }
.nav-menu-item .mi-desc { font-size: 0.82rem; color: var(--ink-4); }
.mi-build  .mi-dot { background: var(--sky-ink); }
.mi-train  .mi-dot { background: var(--peach-ink); }
.mi-govern .mi-dot { background: var(--lav-ink); }
.mi-inform .mi-dot { background: var(--rose-ink); }

/* Hamburger */
.nav-toggle {
  display: none; width: 44px; height: 44px; margin-left: auto;
  align-items: center; justify-content: center; background: none;
  border: 1px solid var(--line-2); border-radius: var(--r-sm); color: var(--ink);
}
.nav-toggle svg { width: 22px; height: 22px; }

@media (max-width: 940px) {
  .nav-desktop { display: none; }
  .nav-toggle { display: inline-flex; }
}

/* Mobile overlay */
.nav-overlay { position: fixed; inset: 0; z-index: 200; background: var(--bg); display: none; flex-direction: column; padding: var(--s-5); overflow-y: auto; }
.nav-overlay.is-open { display: flex; }
.nav-overlay-head { display: flex; align-items: center; justify-content: space-between; min-height: 72px; margin-bottom: var(--s-4); }
.nav-overlay-list { display: flex; flex-direction: column; }
.nav-overlay-list a {
  display: block; padding: var(--s-4) var(--s-1); font-size: 1.5rem; font-weight: 600;
  color: var(--ink); border-bottom: 1px solid var(--line); text-decoration: none;
  opacity: 0; transform: translateY(8px);
}
.nav-overlay.is-open .nav-overlay-list a { animation: navIn var(--dur-2) var(--ease) forwards; }
.nav-overlay-list a:nth-child(1){animation-delay:30ms}.nav-overlay-list a:nth-child(2){animation-delay:60ms}
.nav-overlay-list a:nth-child(3){animation-delay:90ms}.nav-overlay-list a:nth-child(4){animation-delay:120ms}
.nav-overlay-list a:nth-child(5){animation-delay:150ms}.nav-overlay-list a:nth-child(6){animation-delay:180ms}
.nav-overlay-list a:nth-child(7){animation-delay:210ms}.nav-overlay-list a:nth-child(8){animation-delay:240ms}
.nav-overlay-list a:nth-child(9){animation-delay:270ms}.nav-overlay-list a:nth-child(10){animation-delay:300ms}
.nav-overlay-cta { margin-top: var(--s-6); }
@keyframes navIn { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .nav-overlay-list a { opacity: 1; transform: none; animation: none; } }

/* --- Buttons --- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 46px; padding: 11px 20px; border-radius: var(--r-sm);
  font-weight: 600; font-size: 0.975rem; border: 1.5px solid transparent;
  text-decoration: none; white-space: nowrap;
  transition: background var(--dur-1) var(--ease), color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease), transform var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn .arrow { transition: transform var(--dur-1) var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

.btn-primary { background: var(--btn); color: #fff; border-color: var(--btn); }
.btn-primary:hover { background: var(--btn-hover); border-color: var(--btn-hover); color: #fff; box-shadow: var(--shadow); }
.btn-secondary { background: var(--surface); color: var(--ink); border-color: var(--line-2); }
.btn-secondary:hover { border-color: var(--ink-4); color: var(--ink); background: var(--surface); }
.btn-ghost { background: none; color: var(--ink); padding-inline: 6px; min-height: 40px; }
.btn-ghost:hover { color: var(--accent-ink); }
.btn-lg { min-height: 54px; padding: 15px 26px; font-size: 1.05rem; }

.bg-dark .btn-primary { background: #fff; color: var(--ink); border-color: #fff; }
.bg-dark .btn-primary:hover { background: var(--on-dark); border-color: var(--on-dark); }
.bg-dark .btn-secondary { background: transparent; color: #fff; border-color: rgba(255,255,255,0.28); }
.bg-dark .btn-secondary:hover { border-color: #fff; }
.bg-dark .btn-ghost { color: #fff; }

.btn-row { display: flex; flex-wrap: wrap; gap: var(--s-3); }

/* --- Chip / pill --- */
.chip {
  display: inline-flex; align-items: center; gap: 7px; font-size: var(--fs-cap); font-weight: 600;
  padding: 6px 12px; border-radius: var(--r-pill); background: var(--accent-page-soft); color: var(--accent-page-ink);
}
.chip-line { background: var(--surface); border: 1px solid var(--line-2); color: var(--ink-3); }
.chip-dashed { background: none; border: 1.5px dashed var(--line-2); color: var(--ink-4); }

/* --- Pill cluster (trust strip) --- */
.pillrow { display: flex; flex-wrap: wrap; gap: var(--s-3); }

/* --- Cards --- */
.card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: var(--s-6); box-shadow: var(--shadow-sm);
  transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
}
.card-hover:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--line-2); }

.grid { display: grid; gap: var(--s-5); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 940px){ .grid-3,.grid-4 { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 600px){ .grid-2,.grid-3,.grid-4 { grid-template-columns: 1fr;} }

/* Feature tile with pastel icon */
.feature { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--s-6); transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease); }
.feature:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.feature .f-icon { width: 48px; height: 48px; padding: 12px; border-radius: 14px; background: var(--accent-page-soft); color: var(--accent-page-ink); margin-bottom: var(--s-5); }
.feature h3 { font-size: 1.1rem; margin-bottom: var(--s-3); }
.feature p { font-size: var(--fs-sm); color: var(--ink-3); }

/* Discipline card (pastel themed) */
.disc-card {
  position: relative; display: flex; flex-direction: column; gap: var(--s-3);
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: var(--s-6); text-decoration: none; color: var(--ink-3); overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.disc-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); color: var(--ink-3); }
.disc-card .dc-icon { width: 52px; height: 52px; padding: 13px; border-radius: 15px; background: var(--dc-soft); color: var(--dc-ink); }
.disc-card h3 { color: var(--ink); }
.disc-card .dc-verb { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--dc-ink); }
.disc-card p { font-size: var(--fs-sm); color: var(--ink-3); }
.disc-card .dc-link { margin-top: auto; font-weight: 600; color: var(--ink); display: inline-flex; align-items: center; gap: 6px; padding-top: var(--s-2); }
.disc-card[data-d="build"]  { --dc-soft: var(--sky);   --dc-ink: var(--sky-ink); }
.disc-card[data-d="train"]  { --dc-soft: var(--peach); --dc-ink: var(--peach-ink); }
.disc-card[data-d="govern"] { --dc-soft: var(--lav);   --dc-ink: var(--lav-ink); }
.disc-card[data-d="inform"] { --dc-soft: var(--rose);  --dc-ink: var(--rose-ink); }
.disc-card[data-d="grow"]   { --dc-soft: var(--mint);  --dc-ink: var(--mint-ink); }

/* Stat */
.stat { padding: var(--s-2) 0; }
.stat-num { font-size: clamp(2.4rem, 4vw, 3.4rem); font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -0.04em; }
.bg-dark .stat-num { color: #fff; }
.stat-label { font-size: var(--fs-sm); color: var(--ink-3); margin-top: var(--s-3); max-width: 30ch; }
.bg-dark .stat-label { color: var(--on-dark-2); }
.stat-caption { font-size: var(--fs-cap); color: var(--ink-4); margin-top: 4px; }

/* Pull quote */
.pullquote { font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1.25; color: var(--ink); font-weight: 600; letter-spacing: -0.03em; max-width: 22ch; }
.bg-dark .pullquote { color: #fff; }
.quote-attr { margin-top: var(--s-5); font-size: var(--fs-sm); color: var(--ink-4); font-weight: 500; }

/* Section head */
.section-head { max-width: 64ch; margin-bottom: var(--s-8); }
.section-head.center { margin-inline: auto; }

/* Reveal */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity var(--dur-3) var(--ease), transform var(--dur-3) var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* --- Footer (light, Mercury-style) --- */
.site-footer { background: var(--bg-soft); border-top: 1px solid var(--line); padding-block: var(--s-9) var(--s-6); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: var(--s-7); }
@media (max-width: 880px){ .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--s-6);} }
@media (max-width: 520px){ .footer-grid { grid-template-columns: 1fr;} }
.footer-brand .logo { margin-bottom: var(--s-4); }
.footer-mission { color: var(--ink-3); max-width: 34ch; font-size: var(--fs-sm); }
.footer-col h4 { color: var(--ink); font-size: var(--fs-cap); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: var(--s-4); font-weight: 700; }
.footer-links { display: flex; flex-direction: column; gap: var(--s-3); }
.footer-links a { color: var(--ink-3); font-size: var(--fs-sm); }
.footer-links a:hover { color: var(--ink); }
.footer-contact { font-size: var(--fs-sm); line-height: 1.9; color: var(--ink-3); font-style: normal; }
.footer-contact a { color: var(--ink-3); }
.footer-contact a:hover { color: var(--ink); }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--s-3); margin-top: var(--s-8); padding-top: var(--s-5); border-top: 1px solid var(--line); font-size: var(--fs-cap); color: var(--ink-4); }
.footer-badge { display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line-2); border-radius: var(--r-pill); padding: 4px 12px; }
.footer-legal { display: inline-flex; align-items: center; gap: 8px; }
.footer-legal a { color: var(--ink-4); }
.footer-legal a:hover { color: var(--ink); }
