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

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

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--color-ink-700);
  background-color: var(--color-cream-50);
  background-image:
    linear-gradient(rgba(160,148,130,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(160,148,130,0.12) 1px, transparent 1px);
  background-size: 48px 48px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.container {
  width: 88%;
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
}

section {
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
}

section.alt   { background-color: var(--color-cream-100); }
section.white { background-color: var(--color-white); }

/* Transition douce depuis une section dark — fondu dans le padding uniquement */
section.dark + section {
  background: linear-gradient(to bottom, #1e1a13 0%, var(--color-white) 80px);
}

section.dark {
  background-color: var(--color-dark);
  color: var(--color-dark-text);
}
section.dark .section-rule { border-top-color: var(--color-dark-rule); }

.section-rule {
  border: 0;
  border-top: 1px solid var(--color-rule);
  margin: 0;
}

/* Section headings — no overlines, just direct typography */
.section-heading {
  font-size: var(--text-3xl);
  font-weight: var(--weight-black);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink-900);
  margin-bottom: var(--space-6);
}
@media (min-width: 1024px) { .section-heading { font-size: var(--text-4xl); } }

.section-heading.dark-text { color: var(--color-dark-text); }

.section-sub {
  font-size: var(--text-lg);
  color: var(--color-ink-500);
  line-height: var(--leading-normal);
  max-width: 540px;
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  border-radius: var(--radius-md);
  padding: 0.625rem 1.25rem;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background var(--duration-base) var(--ease-out),
              color var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
  text-decoration: none;
  white-space: nowrap;
  line-height: 1;
}

.btn-primary { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.btn-primary:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); }
.btn-outline { background: transparent; color: var(--color-ink-700); border-color: var(--color-border); }
.btn-outline:hover { background: var(--color-cream-100); border-color: var(--color-cream-300); }
.btn-lg { font-size: var(--text-base); padding: 0.8rem 1.75rem; }

main { padding-top: var(--nav-height); }

/* Legal pages */
.legal-page .container { max-width: 720px; padding-top: var(--space-16); padding-bottom: var(--space-16); }
.legal-page h1 { font-size: var(--text-3xl); font-weight: var(--weight-bold); letter-spacing: var(--tracking-tight); color: var(--color-ink-900); margin-bottom: var(--space-2); }
.legal-page .legal-date { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--color-ink-500); margin-bottom: var(--space-12); display: block; }
.legal-page h2 { font-size: var(--text-xl); font-weight: var(--weight-semibold); color: var(--color-ink-900); margin-top: var(--space-8); margin-bottom: var(--space-3); }
.legal-page p { margin-bottom: var(--space-4); line-height: var(--leading-loose); }
.legal-page ul { padding-left: var(--space-6); margin-bottom: var(--space-4); }
.legal-page li { line-height: var(--leading-loose); margin-bottom: var(--space-2); }
