/* Midorick — design tokens & base */
:root {
  --green-50:  #F1F9F4;
  --green-100: #E1F2E8;
  --green-200: #C7E7D2;
  --green-300: #A8DABE;
  --green-400: #86C8A8;
  --green-500: #6BB892;
  --green-600: #4FA277;
  --green-700: #3F8A66;
  --green-800: #2F6B4F;
  --green-900: #21503B;

  --ink-900: #0E1512;
  --ink-800: #1A2420;
  --ink-700: #2D3833;
  --ink-600: #4A5853;
  --ink-500: #6B7873;
  --ink-400: #8E9A95;
  --ink-300: #B5BEB9;
  --ink-200: #D8DDD9;
  --ink-100: #ECEFEC;
  --ink-50:  #F5F7F4;

  --bg:       #FAFBF8;
  --surface:  #FFFFFF;
  --surface-2:#F4F7F2;

  --warn: #E8B43A;
  --rose: #E07A6E;
  --blue: #6E9AE0;

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --shadow-sm: 0 1px 2px rgba(15, 30, 22, 0.04), 0 1px 1px rgba(15, 30, 22, 0.03);
  --shadow:    0 4px 16px rgba(15, 30, 22, 0.06), 0 1px 2px rgba(15, 30, 22, 0.04);
  --shadow-lg: 0 24px 60px -20px rgba(15, 30, 22, 0.18), 0 8px 20px -8px rgba(15, 30, 22, 0.08);

  --container: 1240px;
  --section-y: 120px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Geist', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-feature-settings: 'ss01', 'cv11';
  background: var(--bg);
  color: var(--ink-900);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
}

.mono { font-family: 'Geist Mono', 'JetBrains Mono', ui-monospace, monospace; }

.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
img, svg { display: block; max-width: 100%; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: 999px;
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -0.01em;
  transition: all 160ms ease;
  white-space: nowrap;
}
.btn-primary {
  background: var(--ink-900);
  color: white;
}
.btn-primary:hover { background: var(--green-700); transform: translateY(-1px); }
.btn-ghost {
  color: var(--ink-800);
}
.btn-ghost:hover { color: var(--green-700); }
.btn-outline {
  border: 1px solid var(--ink-200);
  color: var(--ink-800);
  background: white;
}
.btn-outline:hover { border-color: var(--ink-900); }
.btn-green {
  background: var(--green-400);
  color: var(--ink-900);
}
.btn-green:hover { background: var(--green-500); transform: translateY(-1px); }

/* ---------- type ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-700);
}
.eyebrow .dot {
  width: 6px; height: 6px;
  background: var(--green-400);
  border-radius: 999px;
}
h1, h2, h3, h4 {
  font-weight: 500;
  letter-spacing: -0.025em;
  margin: 0;
  line-height: 1.05;
}
h1 { font-size: clamp(48px, 6.2vw, 84px); letter-spacing: -0.035em; }
h2 { font-size: clamp(34px, 3.8vw, 54px); letter-spacing: -0.03em; line-height: 1.05; }
h3 { font-size: 22px; letter-spacing: -0.02em; }
p { margin: 0; }

.section { padding: var(--section-y) 0; }
.section-tight { padding: 80px 0; }

.card {
  background: var(--surface);
  border: 1px solid var(--ink-100);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

/* divider */
.divider {
  height: 1px;
  background: var(--ink-100);
  width: 100%;
}

/* tag */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--green-50);
  color: var(--green-800);
  border: 1px solid var(--green-100);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  font-family: 'Geist Mono', monospace;
  letter-spacing: 0.02em;
}

/* density */
body.density-compact { --section-y: 88px; }
body.density-roomy { --section-y: 144px; }

/* utility */
.grid { display: grid; }
.flex { display: flex; }
.gap-1 { gap: 4px; } .gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; } .gap-6 { gap: 24px; } .gap-8 { gap: 32px; }
.muted { color: var(--ink-500); }
.text-sm { font-size: 13px; }
.text-xs { font-size: 12px; }

/* scroll behavior */
html { scroll-behavior: smooth; }

/* selection */
::selection { background: var(--green-200); color: var(--ink-900); }

/* hover for pillar cards */
.ml-pillar-card { will-change: transform; }
.ml-pillar-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* prose for blog */
.ml-prose h2 { font-size: 28px; margin: 48px 0 16px; }
.ml-prose h3 { font-size: 21px; margin: 36px 0 12px; }
.ml-prose p { margin: 0 0 20px; }
.ml-prose ul, .ml-prose ol { margin: 0 0 20px; padding-left: 22px; }
.ml-prose li { margin-bottom: 8px; }
.ml-prose blockquote {
  margin: 28px 0; padding: 16px 22px;
  background: var(--surface-2);
  border-left: 3px solid var(--green-500);
  border-radius: 8px;
  font-size: 17px; color: var(--ink-700);
}
.ml-prose code {
  background: var(--ink-50); padding: 2px 6px;
  border-radius: 4px; font-size: 0.92em;
  font-family: 'Geist Mono', monospace;
}
.ml-prose a { color: var(--green-800); text-decoration: underline; }

/* responsive */
@media (max-width: 960px) {
  :root { --section-y: 80px; }
  .container { padding: 0 22px; }
  h1 { font-size: clamp(38px, 8vw, 56px); }
  h2 { font-size: clamp(28px, 5vw, 40px); }
  .ml-nav-links { display: none !important; }
  .ml-pillar-grid,
  .ml-approach-grid,
  .ml-combined-grid,
  .ml-audience-grid,
  .ml-footer-grid,
  .ml-twocol,
  .ml-services-grid {
    grid-template-columns: 1fr !important;
  }
  .ml-approach-steps { grid-template-columns: 1fr !important; }
  .ml-three-col { grid-template-columns: 1fr !important; }
  .ml-mcp-grid { grid-template-columns: 1fr !important; }
  .ml-services-2col { grid-template-columns: 1fr !important; }
}
@media (max-width: 640px) {
  .container { padding: 0 18px; }
  .ml-stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
