@charset "UTF-8";
/* global.css — Restored & consolidated
   Trust‑Valuing Civilization
   Single authoritative tokens, header mapping for .header and .hero__nav,
   no debug rules, no duplicates.
*/

/* -------------------------
   Reset / Base
   ------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, main, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

/* -------------------------
   Design tokens (single source)
   ------------------------- */
:root {
  --color-dusk-1: #071827;
  --color-dusk-2: #0F2B3F;
  --color-warm-white: #FBF9F7;
  --color-warm-charcoal: #2A2A2A;
  --color-sage-1: #CFE6D9;
  --color-sage-2: #9FBDAA;
  --color-lavender-2: #C9BFE6;
  --color-rose-2: #E0BFC6;
  --color-sand-1: #F6F1EE;
  --color-aqua-accent: #4FB3C6;
  --color-gold: #E7C98A;
  --color-text: #22282B;
  --color-muted: #6E7576;

  --page-gutter: 48px;
  --space-xxl: 160px;
  --space-xl: 80px;
  --space-lg: 40px;
  --space-md: 24px;
  --space-sm: 16px;

  --container-max: 1100px;
  --container-narrow: 720px;

  --radius-sm: 10px;
  --radius-md: 14px;
  --shadow-soft: 0 10px 30px rgba(10,20,30,0.06);
  --shadow-elevate: 0 20px 50px rgba(10,20,30,0.09);

  --type-heading: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --type-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --h1: 3.25rem;
  --h2: 2.25rem;
  --h3: 1.75rem;
  --h4: 1.25rem;
  --body: 1rem;

  --transition-fast: 180ms;
  --transition-medium: 320ms;
  --focus-ring: rgba(231,201,138,0.25);
}

/* -------------------------
   Global base styles
   ------------------------- */
html, body { height: 100%; }
body {
  font-family: var(--type-body);
  font-size: var(--body);
  color: var(--color-text);
  background: var(--color-warm-white);
  line-height: 1.6;
  min-height: 100vh;
  -webkit-tap-highlight-color: transparent;
}

/* Links */
a { color: var(--color-dusk-2); text-decoration: none; border-bottom: 1px solid rgba(17,38,58,0.06); transition: color var(--transition-fast) ease, border-color var(--transition-fast) ease; }
a:hover, a:focus { color: var(--color-gold); border-color: rgba(231,201,138,0.35); }

/* Headings */
h1, .h1 { font-family: var(--type-heading); font-size: var(--h1); line-height: 1.06; font-weight: 700; color: var(--color-dusk-2); }
h2, .h2 { font-family: var(--type-heading); font-size: var(--h2); line-height: 1.12; font-weight: 700; color: var(--color-dusk-2); }
h3, .h3 { font-family: var(--type-heading); font-size: var(--h3); line-height: 1.18; font-weight: 700; color: var(--color-dusk-2); }

/* Paragraphs */
p { margin-bottom: var(--space-md); color: var(--color-muted); font-size: 1rem; }

/* Images */
img { max-width: 100%; height: auto; display: block; border-radius: 6px; }

/* -------------------------
   Header / Navigation (mapped to .header and .hero__nav)
   ------------------------- */
/* Shared header container style (applies to .header and hero nav) */
.header,
.hero__nav {
  position: sticky;
  top: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 12px var(--page-gutter);
  background: linear-gradient(180deg, rgba(255,255,255,0.66), rgba(255,255,255,0.50));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(15,43,63,0.06);
  box-shadow: 0 6px 18px rgba(10,20,30,0.03);
}

/* Transparent variant for hero overlay */
.header--transparent,
.hero.header--transparent,
.hero__nav.header--transparent {
  background: transparent !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Brand / logo */
.brand,
.nav__logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--color-dusk-2);
}
.brand__logo,
.nav__logo {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--color-sage-2), var(--color-lavender-2));
  box-shadow: var(--shadow-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-warm-white);
  font-weight: 700;
  flex-shrink: 0;
}

/* Primary nav */
.nav,
.nav__links { display: flex; align-items: center; gap: 18px; }
.nav__list { display: flex; gap: 14px; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav__list a,
.nav__link {
  color: var(--color-dusk-2);
  padding: 8px 10px;
  border-radius: 8px;
  font-weight: 600;
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}
.nav__list a:hover,
.nav__link:hover,
.nav__list a:focus,
.nav__link:focus {
  background: rgba(79,179,198,0.06);
  color: var(--color-dusk-1);
  transform: translateY(-1px);
  outline: none;
}

/* Active / CTA */
.nav__link--active,
.nav__list a.active,
.btn--primary {
  background: linear-gradient(90deg, var(--color-aqua-accent), var(--color-gold));
  color: var(--color-warm-white);
  box-shadow: var(--shadow-elevate);
}

/* Header actions */
.header__actions,
.hero__actions { display:flex; gap:12px; align-items:center; }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 10px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.btn--secondary { background: var(--color-sand-1); color: var(--color-warm-charcoal); border: 1px solid rgba(10,20,30,0.04); }

/* Mobile toggle and menu */
.nav-toggle { display: none; background: transparent; border: none; color: var(--color-dusk-2); font-size: 1.4rem; cursor: pointer; padding: 8px; }
.mobile-menu { display: none; position: absolute; right: var(--page-gutter); top: calc(100% + 8px); background: var(--color-warm-white); border-radius: 12px; box-shadow: var(--shadow-elevate); padding: 12px; min-width: 220px; border: 1px solid rgba(10,20,30,0.06); }
.mobile-menu .nav__list { flex-direction: column; gap: 8px; }
.mobile-menu.active { display: block; }

/* -------------------------
   Hero primitive (page-specific visuals in home.css)
   ------------------------- */
.hero { color: var(--color-warm-white); text-align: center; padding: calc(var(--space-xxl) * 0.9) var(--page-gutter); background-position: center; background-size: cover; }
.hero__inner { max-width: var(--container-narrow); margin: 0 auto; }

/* -------------------------
   Layout primitives
   ------------------------- */
.container { max-width: var(--container-narrow); margin-left: auto; margin-right: auto; padding-left: var(--page-gutter); padding-right: var(--page-gutter); }
.container--wide { max-width: var(--container-max); margin-left: auto; margin-right: auto; padding-left: var(--page-gutter); padding-right: var(--page-gutter); }
.section { padding-top: var(--space-xxl); padding-bottom: var(--space-xxl); }

/* Grid helpers */
.grid { display: grid; gap: var(--space-lg); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

/* -------------------------
   Surfaces, cards, components
   ------------------------- */
.surface { background: var(--color-warm-white); border-radius: var(--radius-md); box-shadow: var(--shadow-soft); padding: var(--space-lg); transition: transform var(--transition-medium), box-shadow var(--transition-medium); }
.surface--elevated { box-shadow: var(--shadow-elevate); transform: translateY(0); }
.card { border-radius: var(--radius-sm); overflow: hidden; background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(255,255,255,0.96)); border: 1px solid rgba(10,20,30,0.04); transition: transform var(--transition-medium), box-shadow var(--transition-medium); }
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-elevate); }

/* -------------------------
   Forms & accessibility
   ------------------------- */
input, textarea, select { width: 100%; font-family: var(--type-body); font-size: 1rem; color: var(--color-warm-charcoal); border: 1px solid rgba(10,20,30,0.06); border-radius: 10px; padding: 12px 14px; background: linear-gradient(180deg, #fff, #fbfbfb); transition: box-shadow var(--transition-fast), border-color var(--transition-fast); }
input:focus, textarea:focus, select:focus { outline: none; border-color: rgba(135,150,140,0.35); box-shadow: 0 6px 18px rgba(135,150,140,0.06); }

:focus { outline: none; }
:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 3px; border-radius: 6px; }
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Micro-interactions */
.transition-fast { transition: all var(--transition-fast) ease; }
.fade-in { opacity: 0; transform: translateY(8px); animation: utilFadeIn var(--transition-medium) ease forwards; }
@keyframes utilFadeIn { to { opacity: 1; transform: translateY(0); } }

/* Link underline */
.link-underline { position: relative; }
.link-underline::after { content: ""; position: absolute; left: 0; bottom: -4px; height: 3px; width: 0%; background: linear-gradient(90deg, var(--color-gold), var(--color-sage-2)); transition: width var(--transition-fast) ease; }
.link-underline:hover::after { width: 100%; }

/* Utility spacing */
.u-mt-sm { margin-top: var(--space-sm); }
.u-mt-md { margin-top: var(--space-md); }
.u-mt-lg { margin-top: var(--space-lg); }

/* -------------------------
   Responsive adjustments
   ------------------------- */
@media (max-width: 1024px) {
  :root { --space-xxl: 120px; --space-xl: 64px; --page-gutter: 36px; --container-narrow: 640px; }
  .nav { display: none; }
  .nav-toggle { display: inline-flex; }
  .grid--3 { grid-template-columns: 1fr; }
  h1 { font-size: calc(var(--h1) * 0.82); }
}

@media (max-width: 640px) {
  :root { --space-xxl: 72px; --space-xl: 48px; --page-gutter: 20px; --container-narrow: 560px; }
  .header__inner, .hero__nav { padding: 8px var(--page-gutter); }
  .brand__logo, .nav__logo { width: 40px; height: 40px; }
  .nav__list { display: none; }
  .mobile-menu { right: 20px; left: 20px; top: calc(100% + 8px); min-width: auto; }
}

/* -------------------------
   Print-friendly adjustments
   ------------------------- */
@media print {
  body { background: #fff; color: #000; }
  .no-print { display: none !important; }
  .header, .hero__nav, .site-footer { display: none; }
  .container, .container--wide { padding: 0; max-width: 100%; }
}

/* End of global.css */
