/* ============================================================
   BASE — resets, typography, layout primitives
   ============================================================ */

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

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

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-14);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg-app);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
}

h1, h2, h3, h4, h5 {
  margin: 0 0 var(--sp-3);
  color: var(--text);
  font-family: var(--font-display);
  line-height: var(--lh-snug);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
}
h1 { font-size: var(--fs-32); letter-spacing: var(--ls-display); line-height: var(--lh-tight); font-weight: var(--fw-black); }
h2 { font-size: var(--fs-24); letter-spacing: var(--ls-display); }
h3 { font-size: var(--fs-20); letter-spacing: var(--ls-tight); }
h4 { font-size: var(--fs-18); letter-spacing: var(--ls-tight); font-weight: var(--fw-semi); }
h5 { font-size: var(--fs-16); font-weight: var(--fw-semi); }
h6 { margin: 0 0 var(--sp-3); font-size: var(--fs-12); text-transform: uppercase; letter-spacing: var(--ls-caps); color: var(--text-muted); font-weight: var(--fw-semi); }

p { margin: 0 0 var(--sp-3); }

a { color: var(--brand-700); text-decoration: none; }
a:hover { text-decoration: underline; }

small, .text-sm { font-size: var(--fs-13); }
.text-xs { font-size: var(--fs-12); }
.text-muted { color: var(--text-muted); }
.text-subtle { color: var(--text-subtle); }
.text-right { text-align: right; }
.text-center { text-align: center; }
.fw-semi { font-weight: var(--fw-semi); }
.fw-bold { font-weight: var(--fw-bold); }
.mono { font-family: var(--font-mono); }
.truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

hr { border: 0; border-top: 1px solid var(--border); margin: var(--sp-5) 0; }

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

button { font-family: inherit; cursor: pointer; }

/* Focus ring — visible only for keyboard */
:focus-visible {
  outline: 2px solid var(--brand-600);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}

/* Screen-reader only */
.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;
}

/* ---------- Layout primitives ---------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--sp-5);
}
.container-narrow {
  max-width: 920px;
  margin: 0 auto;
  padding: 0 var(--sp-5);
}

.stack > * + * { margin-top: var(--sp-4); }
.stack-sm > * + * { margin-top: var(--sp-2); }
.stack-lg > * + * { margin-top: var(--sp-6); }

.row { display: flex; gap: var(--sp-3); align-items: center; flex-wrap: wrap; }
.row-between { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.row-end { display: flex; justify-content: flex-end; gap: var(--sp-2); flex-wrap: wrap; }

.grid { display: grid; gap: var(--sp-4); }
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }

.section { padding: var(--sp-8) 0; }
.section-tight { padding: var(--sp-6) 0; }

.divider { height: 1px; background: var(--border); margin: var(--sp-5) 0; }

/* ---------- Page heading ---------- */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  flex-wrap: wrap;
}
.page-header h1 { margin: 0; }
.page-header .subtitle { color: var(--text-muted); margin-top: var(--sp-1); font-size: var(--fs-14); }

/* ---------- Mock ribbon ---------- */
.mock-ribbon {
  position: fixed;
  top: 12px; right: -38px;
  transform: rotate(35deg);
  background: var(--warning-600);
  color: #fff;
  padding: 3px 44px;
  font-size: 11px;
  font-weight: var(--fw-semi);
  letter-spacing: 0.08em;
  z-index: 2000;
  box-shadow: var(--shadow-sm);
  pointer-events: none;
  text-transform: uppercase;
}

/* ---------- Utility ---------- */
.hidden { display: none !important; }
.visually-hidden { visibility: hidden; }
.full { width: 100%; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-6 { margin-top: var(--sp-6); }
.mb-2 { margin-bottom: var(--sp-2); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }
.gap-1 { gap: var(--sp-1); }
.gap-2 { gap: var(--sp-2); }
.gap-3 { gap: var(--sp-3); }
.gap-4 { gap: var(--sp-4); }

/* ---------- Anchor buttons ---------- */
.link-btn {
  background: none;
  border: none;
  color: var(--brand-700);
  font-weight: var(--fw-med);
  padding: 0;
  cursor: pointer;
}
.link-btn:hover { text-decoration: underline; }
