/* ── Self-hosted: Harlow Duo Serif Plain ──────────────────── */
@font-face {
  font-family : "harlow-duo-serif-plain";
  src         : url("fonts/harlow-duo-serif-plain/HarlowDuoSerifPlain.woff2") format("woff2");
  font-weight : 400;
  font-style  : normal;
  font-display: swap;
}


:root {

  /* ── Fluid type scale (375px → 1728px) ───────────────────── */
  --text-xl       : clamp(2.5rem,   2.084rem + 1.774vw, 4rem);     /* 40px → 64px */
  --text-lg       : clamp(2.375rem, 2.132rem + 1.035vw, 3.25rem);  /* 38px → 52px */
  --text-md       : clamp(1.625rem, 1.382rem + 1.035vw, 2.5rem);   /* 26px → 40px */
  --text-sm       : clamp(1.5rem,   1.361rem + 0.591vw, 2rem);     /* 24px → 32px */
  --text-sub-xl   : clamp(1.5rem,   1.223rem + 1.183vw, 2.5rem);   /* 24px → 40px */
  --text-sub-lg   : clamp(1.25rem,  1.181rem + 0.296vw, 1.5rem);   /* 20px → 24px */
  --text-sub-md   : clamp(0.875rem, 0.771rem + 0.443vw, 1.25rem);  /* 14px → 20px */
  --text-sub-sm   : clamp(0.75rem,  0.681rem + 0.296vw, 1rem);     /* 12px → 16px */
  --text-body-xl  : clamp(1.25rem,  1.181rem + 0.296vw, 1.5rem);   /* 20px → 24px */
  --text-body-lg  : clamp(1rem,     0.931rem + 0.296vw, 1.25rem);  /* 16px → 20px */
  --text-body-md  : clamp(0.875rem, 0.840rem + 0.148vw, 1rem);     /* 14px → 16px */
  --text-body-sm  : clamp(0.75rem,  0.75rem  + 0vw,     0.75rem);  /* 12px fixed  */

}


h1, h2, h3, h4, h5, h6 { padding-bottom: 0; color: inherit; }


/* ── Font weight ──────────────────────────────────────────── */
/* Loaded weights: Harlow Duo Serif Plain 400 · Sweet Sans Pro 400/500 */
.font-thin       { font-weight: 100 !important; }
.font-extralight { font-weight: 200 !important; }
.font-light      { font-weight: 300 !important; }
.font-normal     { font-weight: 400 !important; }
.font-medium     { font-weight: 500 !important; }
.font-semibold   { font-weight: 600 !important; }
.font-bold       { font-weight: 700 !important; }
.font-extrabold  { font-weight: 800 !important; }
.font-black      { font-weight: 900 !important; }

/* ── Line height ──────────────────────────────────────────── */
.leading-none    { line-height: 1; }
.leading-tight   { line-height: 1.1; }
.leading-snug    { line-height: 1.25; }
.leading-normal  { line-height: normal; }
.leading-relaxed { line-height: 1.5; }
.leading-loose   { line-height: 1.75; }

/* ── Type scale weights ──────────────────────────────────── */
.heading-xl, .heading-lg, .heading-md, .heading-sm { font-weight: 500; }
.subheading-xl, .subheading-lg, .subheading-md, .subheading-sm { font-weight: 700; }
.body-xl, .body-lg, .body-md, .body-sm, .rich-text p, .rich-text li { font-weight: 600; }

/* ── Type scale ───────────────────────────────────────────── */
/* line-height and letter-spacing come from Figma per token    */
/* Override line-height per instance using .leading-* classes  */
.heading-xl { font-size: var(--text-xl); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.heading-xl h1, .heading-xl h2, .heading-xl h3,
.heading-xl h4, .heading-xl h5, .heading-xl h6,
.heading-xl p  { font-size: inherit; font-family: inherit; line-height: inherit; font-weight: inherit; }

.heading-lg { font-size: var(--text-lg); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.heading-lg h1, .heading-lg h2, .heading-lg h3,
.heading-lg h4, .heading-lg h5, .heading-lg h6,
.heading-lg p  { font-size: inherit; font-family: inherit; line-height: inherit; font-weight: inherit; }

.heading-md { font-size: var(--text-md); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.heading-md h1, .heading-md h2, .heading-md h3,
.heading-md h4, .heading-md h5, .heading-md h6,
.heading-md p  { font-size: inherit; font-family: inherit; line-height: inherit; font-weight: inherit; }

.heading-sm { font-size: var(--text-sm); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.heading-sm h1, .heading-sm h2, .heading-sm h3,
.heading-sm h4, .heading-sm h5, .heading-sm h6,
.heading-sm p  { font-size: inherit; font-family: inherit; line-height: inherit; font-weight: inherit; }

.subheading-xl { font-size: var(--text-sub-xl); font-family: var(--font-sweet-sans-pro); line-height: normal; letter-spacing: 0.08em; }
.subheading-xl p, .subheading-xl li, .subheading-xl h1, .subheading-xl h2, .subheading-xl h3, .subheading-xl h4, .subheading-xl h5, .subheading-xl h6 { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 700 !important; }

.subheading-lg { font-size: var(--text-sub-lg); font-family: var(--font-sweet-sans-pro); line-height: normal; letter-spacing: 0.08em; }
.subheading-lg p, .subheading-lg li, .subheading-lg h1, .subheading-lg h2, .subheading-lg h3, .subheading-lg h4, .subheading-lg h5, .subheading-lg h6 { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 700 !important; }

.subheading-md { font-size: var(--text-sub-md); font-family: var(--font-sweet-sans-pro); line-height: normal; letter-spacing: 0.08em; }
.subheading-md p, .subheading-md li, .subheading-md h1, .subheading-md h2, .subheading-md h3, .subheading-md h4, .subheading-md h5, .subheading-md h6 { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 700 !important; }

.subheading-sm { font-size: var(--text-sub-sm); font-family: var(--font-sweet-sans-pro); line-height: normal; letter-spacing: 0.08em; }
.subheading-sm p, .subheading-sm li, .subheading-sm h1, .subheading-sm h2, .subheading-sm h3, .subheading-sm h4, .subheading-sm h5, .subheading-sm h6 { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 700 !important; }

.body-xl { font-size: var(--text-body-xl); font-family: var(--font-sweet-sans-pro); line-height: normal; }
.body-xl p, .body-xl li { font-size: inherit; font-family: inherit; line-height: inherit; font-weight: 600 !important; }

.body-lg { font-size: var(--text-body-lg); font-family: var(--font-sweet-sans-pro); line-height: 1.4; letter-spacing: 0.07em; }
.body-lg p, .body-lg li { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 600 !important; }

.body-md { font-size: var(--text-body-md); font-family: var(--font-sweet-sans-pro); line-height: 1.375; letter-spacing: 0.07em; }
.body-md p, .body-md li { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 600 !important; }

.body-sm { font-size: var(--text-body-sm); font-family: var(--font-sweet-sans-pro); line-height: normal; letter-spacing: 0.07em; }
.body-sm p, .body-sm li { font-size: inherit; font-family: inherit; line-height: inherit; letter-spacing: inherit; font-weight: 600 !important; }


/* ── Rich text ────────────────────────────────────────────── */
/* Apply to Code modules or WP editor content outside Divi's control */
.rich-text h1 { font-size: var(--text-xl); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.rich-text h2 { font-size: var(--text-lg); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.rich-text h3 { font-size: var(--text-md); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }
.rich-text h4,
.rich-text h5,
.rich-text h6 { font-size: var(--text-sm); font-family: var(--font-harlow-duo-serif-plain); line-height: normal; }

.rich-text p,
.rich-text li {
  font-size   : var(--text-body-xl);
  font-family : var(--font-sweet-sans-pro);
  line-height : normal;
}

.rich-text ol,
.rich-text ul  { padding-left: 1.5em; }

.rich-text a   { text-decoration: underline; color: inherit; }