/* Local helpers for the website. Brings in the design system tokens. */
@import url('colors_and_type.css');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--bg); color: var(--fg); font-family: var(--font-body); }

.container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 24px; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: 13px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 14px 26px; border-radius: 999px; border: 1.5px solid transparent;
  cursor: pointer; text-decoration: none;
  transition: background var(--dur-quick) var(--ease-out),
              color var(--dur-quick) var(--ease-out),
              border-color var(--dur-quick) var(--ease-out),
              transform var(--dur-quick) var(--ease-out);
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--color-cocoa-800); color: var(--color-saffron-400); }
.btn-primary:hover { background: var(--color-cocoa-900); color: var(--color-saffron-400); }
.btn-accent { background: var(--color-saffron-600); color: var(--color-cocoa-900); }
.btn-accent:hover { background: var(--color-saffron-700); color: var(--color-paper-50); }
.btn-ghost { background: transparent; color: var(--color-paper-50); border-color: var(--color-saffron-500); }
.btn-ghost:hover { background: var(--color-saffron-600); color: var(--color-cocoa-900); border-color: var(--color-saffron-600); }
.btn-ghost-dark { background: transparent; color: var(--color-cocoa-800); border-color: var(--color-cocoa-800); }
.btn-ghost-dark:hover { background: var(--color-cocoa-800); color: var(--color-saffron-400); }
.btn-sm { padding: 10px 18px; font-size: 11px; }

a { text-decoration: none; color: inherit; }

/* Sections */
section { padding: 96px 0; }
@media (max-width: 720px) { section { padding: 64px 0; } }

.eyebrow {
  font-family: var(--font-body);
  font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: var(--accent);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-cocoa-900);
  margin: 12px 0 16px;
  text-wrap: balance;
}
.section-lead {
  font-size: 18px;
  line-height: 1.55;
  color: var(--color-ink-700);
  max-width: 640px;
  text-wrap: pretty;
}

/* Cards */
.card {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.card:hover { box-shadow: var(--shadow-md); }
.card img, .card .img {
  display: block; width: 100%; height: 200px; object-fit: cover;
  transition: transform var(--dur-base) var(--ease-out);
}
.card:hover img, .card:hover .img { transform: scale(1.025); }

/* Dot grid decorator */
.dot-grid {
  background-image: radial-gradient(circle, var(--color-paper-300) 1px, transparent 1.5px);
  background-size: 18px 18px;
}
