:root {

  /* ─── Cores ──────────────────────────────────────── */
  --color-dark:         #111827;
  --color-dark-80:      rgba(17, 24, 39, 0.8);
  --color-dark-60:      rgba(17, 24, 39, 0.6);
  --color-dark-10:      rgba(17, 24, 39, 0.08);
  --color-light:        #f9fafb;
  --color-accent:       #ffab00;
  --color-accent-dark:  #e09600;
  --color-accent-light: #fff3cc;
  --color-muted:        #6b7280;
  --color-border:       #e5e7eb;
  --color-white:        #ffffff;

  /* Semânticas */
  --color-success:      #16a34a;
  --color-success-bg:   #f0fdf4;
  --color-error:        #dc2626;
  --color-error-bg:     #fef2f2;
  --color-warning:      #d97706;
  --color-warning-bg:   #fffbeb;

  /* ─── Tipografia ─────────────────────────────────── */
  --font-heading: 'Fraunces', Georgia, serif;
  --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;

  /* ─── Escala tipográfica ─────────────────────────── */
  --text-xs:   0.75rem;    /*  12px */
  --text-sm:   0.875rem;   /*  14px */
  --text-base: 1rem;       /*  16px */
  --text-lg:   1.125rem;   /*  18px */
  --text-xl:   1.25rem;    /*  20px */
  --text-2xl:  1.5rem;     /*  24px */
  --text-3xl:  1.875rem;   /*  30px */
  --text-4xl:  2.25rem;    /*  36px */
  --text-5xl:  3rem;       /*  48px */
  --text-6xl:  3.75rem;    /*  60px */

  /* ─── Line-heights ───────────────────────────────── */
  --leading-tight:  1.15;
  --leading-snug:   1.3;
  --leading-normal: 1.6;
  --leading-relaxed: 1.75;

  /* ─── Font-weights ───────────────────────────────── */
  --weight-light:    300;
  --weight-regular:  400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;

  /* ─── Espaçamento ────────────────────────────────── */
  --space-1:  0.25rem;   /*  4px */
  --space-2:  0.5rem;    /*  8px */
  --space-3:  0.75rem;   /* 12px */
  --space-4:  1rem;      /* 16px */
  --space-5:  1.25rem;   /* 20px */
  --space-6:  1.5rem;    /* 24px */
  --space-8:  2rem;      /* 32px */
  --space-10: 2.5rem;    /* 40px */
  --space-12: 3rem;      /* 48px */
  --space-16: 4rem;      /* 64px */
  --space-20: 5rem;      /* 80px */
  --space-24: 6rem;      /* 96px */
  --space-32: 8rem;      /* 128px */

  /* ─── Layout ─────────────────────────────────────── */
  --container-max:     1200px;
  --container-padding: 1.5rem;

  /* ─── Bordas ─────────────────────────────────────── */
  --radius-sm:   0.25rem;   /* 4px  */
  --radius-md:   0.5rem;    /* 8px  */
  --radius-lg:   1rem;      /* 16px */
  --radius-xl:   1.5rem;    /* 24px */
  --radius-full: 9999px;

  /* ─── Sombras ────────────────────────────────────── */
  --shadow-sm:  0 1px 2px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.1);
  --shadow-md:  0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:  0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);
  --shadow-xl:  0 20px 25px rgba(0,0,0,.1), 0 10px 10px rgba(0,0,0,.04);

  /* ─── Transições ─────────────────────────────────── */
  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;

  /* ─── Z-index ────────────────────────────────────── */
  --z-base:     1;
  --z-dropdown: 100;
  --z-sticky:   200;
  --z-fixed:    300;
  --z-overlay:  400;
  --z-modal:    500;
  --z-toast:    600;

  /* ─── Header ─────────────────────────────────────── */
  --topbar-height: 32px;
  --header-height:        80px;
  --header-height-scroll: 80px;
  /* Início do painel do menu mobile (abaixo da top-bar + header) */
  --site-header-offset: calc(var(--topbar-height) + var(--header-height));
}
