:root {
  --bg-default: #FAFAF7;
  --bg-subtle: #FFFFFF;
  --bg-surface-low: #F4F2EA;
  --bg-surface-high: #FFFFFF;
  --bg-inverse: #1F2A2B;
  --bg-brand: #EAF5F2;
  --bg-accent: #EEF2FD;
  --fg-on-default: #1F2A2B;
  --fg-on-inverse: #FAFAF7;
  --fg-on-brand: #FFFFFF;
  --fg-on-accent: #FFFFFF;
  --fg-secondary: #53605E;
  --fg-disabled: #A9B2B0;
  --brand-primary: #2F7D6D;
  --brand-primary-hover: #1E5B4F;
  --brand-secondary: #C98F3B;
  --brand-secondary-hover: #936827;
  --brand-accent: #6D8BE5;
  --brand-accent-hover: #3E60C9;
  --border-color-default: #D7DED9;
  --border-color-subtle: #E7ECE8;
  --border-color-strong: #B8C4BF;
  --color-error: #C8463D;
  --color-warning: #E7A63C;
  --color-info: #4D7BD1;
  --color-success: #2E8F62;

  --font-display-lg-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-display-lg-size: 2.6rem;
  --font-display-lg-weight: 700;
  --font-display-lg-line-height: 1.25;
  --font-display-lg-letter-spacing: -0.02em;
  --font-display-md-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-display-md-size: 2.2rem;
  --font-display-md-weight: 700;
  --font-display-md-line-height: 1.25;
  --font-display-md-letter-spacing: -0.02em;
  --font-headline-lg-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-headline-lg-size: 2.1rem;
  --font-headline-lg-weight: 700;
  --font-headline-lg-line-height: 1.25;
  --font-headline-lg-letter-spacing: -0.015em;
  --font-headline-md-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-headline-md-size: 1.8rem;
  --font-headline-md-weight: 700;
  --font-headline-md-line-height: 1.25;
  --font-headline-md-letter-spacing: -0.01em;
  --font-headline-sm-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-headline-sm-size: 1.5rem;
  --font-headline-sm-weight: 700;
  --font-headline-sm-line-height: 1.25;
  --font-headline-sm-letter-spacing: -0.005em;
  --font-title-lg-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-title-lg-size: 1.25rem;
  --font-title-lg-weight: 600;
  --font-title-lg-line-height: 1.25;
  --font-title-lg-letter-spacing: 0em;
  --font-title-md-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-title-md-size: 1.05rem;
  --font-title-md-weight: 600;
  --font-title-md-line-height: 1.25;
  --font-title-md-letter-spacing: 0em;
  --font-body-lg-family: 'Source Sans 3', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-body-lg-size: 1.125rem;
  --font-body-lg-weight: 400;
  --font-body-lg-line-height: 1.7;
  --font-body-lg-letter-spacing: 0em;
  --font-body-md-family: 'Source Sans 3', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-body-md-size: 1.0625rem;
  --font-body-md-weight: 400;
  --font-body-md-line-height: 1.7;
  --font-body-md-letter-spacing: 0em;
  --font-body-sm-family: 'Source Sans 3', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-body-sm-size: 0.9rem;
  --font-body-sm-weight: 400;
  --font-body-sm-line-height: 1.7;
  --font-body-sm-letter-spacing: 0em;
  --font-label-lg-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-label-lg-size: 1rem;
  --font-label-lg-weight: 600;
  --font-label-lg-line-height: 1.2;
  --font-label-lg-letter-spacing: 0.01em;
  --font-label-md-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-label-md-size: 0.9375rem;
  --font-label-md-weight: 600;
  --font-label-md-line-height: 1.2;
  --font-label-md-letter-spacing: 0.01em;
  --font-label-sm-family: 'Quicksand', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-label-sm-size: 0.875rem;
  --font-label-sm-weight: 600;
  --font-label-sm-line-height: 1.2;
  --font-label-sm-letter-spacing: 0.02em;

  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2.5rem;
  --spacing-container-padding: 1.5rem;
  --spacing-section-margin: 4rem;

  --border-radius-sm: 0.375rem;
  --border-radius-md: 0.75rem;
  --border-radius-lg: 1.25rem;
  --border-radius-xl: 1.75rem;
  --border-radius-full: 9999px;

  --shadow-sm: 0 1px 2px rgba(31, 42, 43, 0.06);
  --shadow-md: 0 8px 24px rgba(31, 42, 43, 0.10);
  --shadow-lg: 0 16px 40px rgba(31, 42, 43, 0.14);

  --container-max-width: 1280px;
  --container-padding-x: 1.5rem;

/* Aliases legacy — pour blocs créés avant migration DESIGN.md */
  --color-primary: var(--brand-primary);
  --color-primary-main: var(--brand-primary);
  --color-primary-light: var(--brand-primary);
  --color-primary-dark: var(--brand-primary-hover);
  --color-primary-contrast: var(--fg-on-brand);
  --color-secondary: var(--brand-secondary);
  --color-secondary-main: var(--brand-secondary);
  --color-secondary-light: var(--brand-secondary);
  --color-secondary-dark: var(--brand-secondary-hover);
  --color-secondary-contrast: var(--fg-on-brand);
  --color-accent: var(--brand-accent);
  --color-accent-main: var(--brand-accent);
  --color-accent-light: var(--brand-accent);
  --color-accent-dark: var(--brand-accent-hover);
  --color-accent-contrast: var(--fg-on-accent);
  --color-background: var(--bg-default);
  --color-background-default: var(--bg-default);
  --color-background-paper: var(--bg-subtle);
  --color-paper: var(--bg-subtle);
  --color-text-primary: var(--fg-on-default);
  --color-text-secondary: var(--fg-secondary);
  --color-text-disabled: var(--fg-disabled);
  --font-family-body: var(--font-body-md-family);
  --font-family-heading: var(--font-headline-lg-family);
  --font-size-base: var(--font-body-md-size);
  --font-size-small: var(--font-body-sm-size);
  --font-size-h1: var(--font-display-lg-size);
  --font-size-h2: var(--font-headline-lg-size);
  --font-size-h3: var(--font-headline-md-size);
  --font-size-h4: var(--font-headline-sm-size);
  --font-size-h5: var(--font-title-lg-size);
  --font-size-h6: var(--font-title-md-size);
  --line-height-body: var(--font-body-md-line-height);
  --line-height-heading: var(--font-headline-lg-line-height);
  --border-radius: var(--border-radius-md);
  --heading-letter-spacing: var(--font-headline-lg-letter-spacing);
  --heading-weight: var(--font-headline-lg-weight);
  --transition-fast: 0.15s ease;
  --transition-normal: 0.3s ease;
}

[data-theme="dark"] {
  --bg-default: #141C1D;
  --bg-subtle: #1B2526;
  --bg-surface-low: #1F2A2B;
  --bg-surface-high: #243031;
  --bg-inverse: #FAFAF7;
  --bg-brand: #183F37;
  --bg-accent: #1D2A52;
  --fg-on-default: #F4F6F3;
  --fg-on-inverse: #1F2A2B;
  --fg-on-brand: #FFFFFF;
  --fg-on-accent: #FFFFFF;
  --fg-secondary: #B6C2BF;
  --fg-disabled: #6F7D7A;
  --brand-primary: #4F9E90;
  --brand-primary-hover: #2F7D6D;
  --brand-secondary: #D8A65E;
  --brand-secondary-hover: #C98F3B;
  --brand-accent: #91A9F0;
  --brand-accent-hover: #6D8BE5;
  --border-color-default: #334243;
  --border-color-subtle: #273435;
  --border-color-strong: #415355;
  --color-error: #D06A63;
  --color-warning: #E1B157;
  --color-info: #6A93DE;
  --color-success: #50A77E;
}

.block--tone-inverse {
  --bg-default: var(--bg-inverse);
  --bg-subtle: var(--bg-inverse);
  --bg-surface-low: var(--bg-inverse);
  --bg-surface-high: var(--bg-inverse);
  --bg-brand: var(--bg-inverse);
  --bg-accent: var(--bg-inverse);
  --fg-on-default: var(--fg-on-inverse);
  --fg-on-subtle: var(--fg-on-inverse);
  --fg-on-brand: var(--fg-on-inverse);
  --fg-on-accent: var(--fg-on-inverse);
  --fg-secondary: color-mix(in srgb, var(--fg-on-inverse) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-inverse) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-inverse) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-inverse) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-inverse) 36%, transparent);
}

.block--tone-shell-inverse [class$="__shell"],
.block--tone-shell-inverse [class*="__shell "] {
  --bg-default: var(--bg-inverse);
  --bg-subtle: var(--bg-inverse);
  --bg-surface-low: var(--bg-inverse);
  --bg-surface-high: var(--bg-inverse);
  --bg-brand: var(--bg-inverse);
  --bg-accent: var(--bg-inverse);
  --fg-on-default: var(--fg-on-inverse);
  --fg-on-subtle: var(--fg-on-inverse);
  --fg-on-brand: var(--fg-on-inverse);
  --fg-on-accent: var(--fg-on-inverse);
  --fg-secondary: color-mix(in srgb, var(--fg-on-inverse) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-inverse) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-inverse) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-inverse) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-inverse) 36%, transparent);
}

.block--tone-brand {
  --bg-default: var(--bg-brand);
  --bg-subtle: var(--bg-brand);
  --bg-surface-low: var(--bg-brand);
  --bg-surface-high: var(--bg-brand);
  --bg-inverse: var(--bg-brand);
  --bg-accent: var(--bg-brand);
  --fg-on-default: var(--fg-on-brand);
  --fg-on-subtle: var(--fg-on-brand);
  --fg-on-inverse: var(--fg-on-brand);
  --fg-on-accent: var(--fg-on-brand);
  --fg-secondary: color-mix(in srgb, var(--fg-on-brand) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-brand) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-brand) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-brand) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-brand) 36%, transparent);
}

.block--tone-shell-brand [class$="__shell"],
.block--tone-shell-brand [class*="__shell "] {
  --bg-default: var(--bg-brand);
  --bg-subtle: var(--bg-brand);
  --bg-surface-low: var(--bg-brand);
  --bg-surface-high: var(--bg-brand);
  --bg-inverse: var(--bg-brand);
  --bg-accent: var(--bg-brand);
  --fg-on-default: var(--fg-on-brand);
  --fg-on-subtle: var(--fg-on-brand);
  --fg-on-inverse: var(--fg-on-brand);
  --fg-on-accent: var(--fg-on-brand);
  --fg-secondary: color-mix(in srgb, var(--fg-on-brand) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-brand) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-brand) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-brand) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-brand) 36%, transparent);
}

.block--tone-accent {
  --bg-default: var(--bg-accent);
  --bg-subtle: var(--bg-accent);
  --bg-surface-low: var(--bg-accent);
  --bg-surface-high: var(--bg-accent);
  --bg-inverse: var(--bg-accent);
  --bg-brand: var(--bg-accent);
  --fg-on-default: var(--fg-on-accent);
  --fg-on-subtle: var(--fg-on-accent);
  --fg-on-inverse: var(--fg-on-accent);
  --fg-on-brand: var(--fg-on-accent);
  --fg-secondary: color-mix(in srgb, var(--fg-on-accent) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-accent) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-accent) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-accent) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-accent) 36%, transparent);
}

.block--tone-shell-accent [class$="__shell"],
.block--tone-shell-accent [class*="__shell "] {
  --bg-default: var(--bg-accent);
  --bg-subtle: var(--bg-accent);
  --bg-surface-low: var(--bg-accent);
  --bg-surface-high: var(--bg-accent);
  --bg-inverse: var(--bg-accent);
  --bg-brand: var(--bg-accent);
  --fg-on-default: var(--fg-on-accent);
  --fg-on-subtle: var(--fg-on-accent);
  --fg-on-inverse: var(--fg-on-accent);
  --fg-on-brand: var(--fg-on-accent);
  --fg-secondary: color-mix(in srgb, var(--fg-on-accent) 72%, transparent);
  --fg-disabled: color-mix(in srgb, var(--fg-on-accent) 45%, transparent);
  --border-color-default: color-mix(in srgb, var(--fg-on-accent) 18%, transparent);
  --border-color-subtle: color-mix(in srgb, var(--fg-on-accent) 8%, transparent);
  --border-color-strong: color-mix(in srgb, var(--fg-on-accent) 36%, transparent);
}
