/* =========================================================
   BASE
   ========================================================= */

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

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--ink-2);
  background: var(--bg);
  font-feature-settings: 'ss01', 'cv11';
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  color: var(--ink);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.08;
  margin: 0 0 var(--s-4);
  font-variation-settings: "opsz" 144, "SOFT" 30;
}

h1 { font-size: var(--text-hero); line-height: 1.02; letter-spacing: -0.035em; }
h2 { font-size: var(--text-display); line-height: 1.08; letter-spacing: -0.028em; }
h3 { font-size: var(--text-xl); line-height: 1.15; }
h4 { font-size: var(--text-lg); line-height: 1.25; font-weight: 600; font-family: var(--font-body); letter-spacing: -0.01em; }
h5 { font-size: var(--text-md); font-family: var(--font-body); font-weight: 600; letter-spacing: -0.005em; }

p { margin: 0 0 1em; max-width: 65ch; }
p.lede { font-size: var(--text-md); color: var(--ink-2); max-width: 60ch; }

a {
  color: var(--accent);
  text-decoration: none;
  text-decoration-color: color-mix(in srgb, var(--accent) 35%, transparent);
  text-underline-offset: 4px;
  transition: color var(--t-fast) var(--ease);
}
a:hover { text-decoration: underline; color: var(--accent-hover); }

img, svg { max-width: 100%; display: block; }

::selection { background: var(--cz-vision-soft); color: var(--ink); }

hr {
  border: 0;
  height: 1px;
  background: var(--line);
  margin: var(--s-7) 0;
}

button { font: inherit; cursor: pointer; }

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* =========================================================
   LAYOUT
   ========================================================= */

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--s-5); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--s-5); }
.container-wide { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--s-5); }

.section { padding: var(--s-9) 0; }
.section-lg { padding: var(--s-10) 0; }
.section-sm { padding: var(--s-7) 0; }

@media (max-width: 720px) {
  .section { padding: var(--s-8) 0; }
  .section-lg { padding: var(--s-9) 0; }
}

/* Eyebrow / kicker */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-4);
}
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 28px; height: 1px;
  background: currentColor;
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 0.95em 1.6em;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: -0.005em;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  text-decoration: none;
  line-height: 1;
}
.btn-primary { background: var(--ink); color: #fff; }
.btn-primary:hover { background: #000; color: #fff; transform: translateY(-1px); }
.btn-accent { background: var(--accent); color: var(--accent-ink); }
.btn-accent:hover { background: var(--accent-hover); color: #fff; transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover { background: var(--surface); border-color: var(--ink); text-decoration: none; }

.btn .arrow { transition: transform var(--t-fast) var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

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

/* Pill / tag */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 0.4em 0.85em;
  border-radius: var(--radius-pill);
  background: var(--surface-2);
  border: 1px solid var(--line);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: -0.005em;
}

/* Grids */
.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: 920px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* Utilities */
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.text-muted { color: var(--ink-3); }
.text-faint { color: var(--ink-4); }
.text-ink { color: var(--ink); }
.text-center { text-align: center; }
.max-w-prose { max-width: 65ch; }
.max-w-narrow { max-width: 48ch; }
.mx-auto { margin-left: auto; margin-right: auto; }

/* Zone tints — used contextually */
.tint-vision   { background: var(--cz-vision-tint); }
.tint-alignment{ background: var(--cz-alignment-tint); }
.tint-deepdive { background: var(--cz-deepdive-tint); }
.tint-bridge   { background: var(--cz-bridge-tint); }
.tint-sand     { background: var(--surface-2); }
.tint-ink      { background: var(--ink); color: #e7e5dc; }
.tint-ink h1, .tint-ink h2, .tint-ink h3, .tint-ink h4 { color: #fff; }
.tint-ink .text-muted { color: #a8a59c; }
.tint-ink .eyebrow { color: #c9c4b3; }

/* Reveal animation */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 600ms var(--ease-soft), transform 600ms var(--ease-soft);
}
.reveal.in {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
