/** Site Custom Stylesheet (From File) **/ 



 /** Site Custom Styles (From DB) **/ 

:root  {
  --root-font-size: 16px;
  /* ========== PRIMITIVE DESIGN TOKENS ========== */ /* Primitives are the core building blocks of the design system, often used to define raw values (e.g., colors, font sizes, spacing). Naming Convention: --[category]-[type]-[modifier] • Category: Broad category of the design token (e.g., color, font, spacing). • Type: Specific type within the category (e.g., primary, secondary, neutral). • Modifier: Optional, used to define variations (e.g., light, dark, large). */ /* --- Colours --- */ --color-brand: black;
  --color-brand-light: color-mix(in srgb, var(--color-brand) 90%, white);
  --color-brand-lighter: color-mix(in srgb, var(--color-brand) 80%, white);
  --color-brand-lightest: color-mix(in srgb, var(--color-brand) 70%, white);
  --color-brand-dark: color-mix(in srgb, var(--color-brand) 90%, black);
  --color-brand-darker: color-mix(in srgb, var(--color-brand) 80%, black);
  --color-brand-darkest: color-mix(in srgb, var(--color-brand) 70%, black);
  --color-primary: var(--color-brand);
  --color-primary-light: color-mix(in srgb, var(--color-primary) 90%, white);
  --color-primary-lighter: color-mix(in srgb, var(--color-primary) 80%, white);
  --color-primary-lightest: color-mix(in srgb, var(--color-primary) 70%, white);
  --color-primary-dark: color-mix(in srgb, var(--color-primary) 90%, black);
  --color-primary-darker: color-mix(in srgb, var(--color-primary) 80%, black);
  --color-primary-darkest: color-mix(in srgb, var(--color-primary) 70%, black);
  --color-secondary: var(--color-brand);
  --color-secondary-light: color-mix(in srgb, var(--color-secondary) 90%, white);
  --color-secondary-lighter: color-mix(in srgb, var(--color-secondary) 80%, white);
  --color-secondary-lightest: color-mix(in srgb, var(--color-secondary) 70%, white);
  --color-secondary-dark: color-mix(in srgb, var(--color-secondary) 90%, black);
  --color-secondary-darker: color-mix(in srgb, var(--color-secondary) 80%, black);
  --color-secondary-darkest: color-mix(in srgb, var(--color-secondary) 70%, black);
  --color-accent: var(--color-brand);
  --color-accent-light: color-mix(in srgb, var(--color-accent) 90%, white);
  --color-accent-lighter: color-mix(in srgb, var(--color-accent) 80%, white);
  --color-accent-lightest: color-mix(in srgb, var(--color-accent) 70%, white);
  --color-accent-dark: color-mix(in srgb, var(--color-accent) 90%, black);
  --color-accent-darker: color-mix(in srgb, var(--color-accent) 80%, black);
  --color-accent-darkest: color-mix(in srgb, var(--color-accent) 70%, black);
  --color-neutral: #999999;
  --color-neutral-light: color-mix(in srgb, var(--color-neutral) 75%, white);
  --color-neutral-lighter: color-mix(in srgb, var(--color-neutral) 50%, white);
  --color-neutral-lightest: color-mix(in srgb, var(--color-neutral) 25%, white);
  --color-neutral-dark: color-mix(in srgb, var(--color-neutral) 95%, black);
  --color-neutral-darker: color-mix(in srgb, var(--color-neutral) 90%, black);
  --color-neutral-darkest: color-mix(in srgb, var(--color-neutral) 85%, black);
  --color-neutral-alt: #f4f4f4;
  --color-neutral-alt-light: color-mix(in srgb, var(--color-neutral-alt) 75%, white);
  --color-neutral-alt-lighter: color-mix(in srgb, var(--color-neutral-alt) 50%, white);
  --color-neutral-alt-lightest: color-mix(in srgb, var(--color-neutral-alt) 25%, white);
  --color-neutral-alt-dark: color-mix(in srgb, var(--color-neutral-alt) 95%, black);
  --color-neutral-alt-darker: color-mix(in srgb, var(--color-neutral-alt) 90%, black);
  --color-neutral-alt-darkest: color-mix(in srgb, var(--color-neutral-alt) 85%, black);
  --color-text-primary: #333333;
  --color-text-primary-dark: #222222;
  --color-text-primary-darker: #111111;
  --color-text-primary-darkest: #000000;
  --color-text-primary-light: #444444;
  --color-text-primary-lighter: #555555;
  --color-text-primary-lightest: #666666;
  --color-text-secondary: #666666;
  --color-text-inverse: #ffffff;
  --color-button-primary-bg: var(--color-primary);
  --color-button-primary-text-color: var(--color-text-inverse);
  --color-form-field-text-color: inhert;
  --color-form-field-text-disabled: #999999;
  --color-form-field-border: #CCCCCC;
  --color-form-field-border-focus: var(--color-primary);
  --color-form-field-bg: #FFFFFF;
  --color-form-field-bg-disabled: #F5F5F5;
  --color-form-button-text-color: var(--color-button-primary-text-color);
  --color-form-button-bg: var(--color-button-primary-bg);
  --color-checkbox-accent: var(--color-primary);
  /* ========== SEMANTIC DESIGN TOKENS ========== */ /* Semantic variables are context-specific and map to the primitives. They define how a primitive is used (e.g., --body-text-color, --heading-text-color). Naming Convention: --[context]-[property] • Context: Where the variable is used (e.g., body, heading, button, card). • Property: Specific property being controlled (e.g., text-color, background-color, font-size). */ /* --- Typography --- */ --body-text-color: var(--color-text-primary);
  --body-font-size: 1rem;
  --body-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --body-line-height: 1.6;
  --paragraph-spacing: 1rem;
  --heading-spacing: 1rem;
  --heading-text-color: var(--color-text-primary);
  --heading-font-family: serif;
  --heading-font-weight: var(--font-weight-bold);
  --heading-line-height: 1.1;
  --heading-1-text-color: var(--heading-text-color);
  --heading-2-text-color: var(--heading-text-color);
  --heading-3-text-color: var(--heading-text-color);
  --heading-4-text-color: var(--heading-text-color);
  --heading-5-text-color: var(--heading-text-color);
  --heading-6-text-color: var(--heading-text-color);
  --heading-1-font-weight: var(--heading-font-weight);
  --heading-2-font-weight: var(--heading-font-weight);
  --heading-3-font-weight: var(--heading-font-weight);
  --heading-4-font-weight: var(--heading-font-weight);
  --heading-5-font-weight: var(--heading-font-weight);
  --heading-6-font-weight: var(--heading-font-weight);
  /* Set h1 font-size and body font-size, and interpolated scaling for other headings between those two boundaries (with h6 being same size as body) */ --heading-1-font-size: 4rem;
  --heading-2-font-size: calc(var(--body-font-size) + (var(--heading-1-font-size) - var(--body-font-size)) * 0.8);
  --heading-3-font-size: calc(var(--body-font-size) + (var(--heading-1-font-size) - var(--body-font-size)) * 0.6);
  --heading-4-font-size: calc(var(--body-font-size) + (var(--heading-1-font-size) - var(--body-font-size)) * 0.45);
  --heading-5-font-size: calc(var(--body-font-size) + (var(--heading-1-font-size) - var(--body-font-size)) * 0.32);
  --heading-6-font-size: var(--body-font-size);
  --heading-1-line-height: var(--heading-line-height);
  --heading-2-line-height: var(--heading-line-height);
  --heading-3-line-height: var(--heading-line-height);
  --heading-4-line-height: var(--heading-line-height);
  --heading-5-line-height: var(--heading-line-height);
  --heading-6-line-height: var(--heading-line-height);
  /* Buttons */ /* --button-primary-bg: var(--color-primary);
  --button-primary-text: var(--color-neutral-light);
  --button-secondary-bg: var(--color-secondary);
  --button-secondary-text: var(--color-neutral-light);
  */ /* Links */ --link-color: var(--body-text-color);
  --link-hover-color: color-mix(in srgb, var(--link-color) 80%, white);
  --nav-link-color: var(--link-color);
  --nav-link-hover-color: var(--link-hover-color);
}
/* ========== CSS RESET ========== */ *, *::before, *::after  {
  box-sizing: border-box;
}
body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd  {
  margin: 0;
}
p  {
  margin-top: 0;
  margin-bottom: var(--paragraph-spacing);
}
html  {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}
input, textarea  {
  width: 100%;
}
button, input, select, textarea  {
  font-family: inherit;
}
button  {
  cursor: pointer;
}
hr  {
  border: 0;
  height: 1px;
  background: var(--color-text-primary, #ddd);
  margin: 1rem 0;
}
a  {
  text-decoration: none;
}
a  {
  color: var(--link-color);
}
/* note that we don't set a:visited because it overrides other colour settings for other classes unless we specificaly set the :visited option on all other link classes */ a:hover, a:focus  {
  color: var(--link-hover-color);
  text-decoration: underline;
}
/* ========== OVERALL DOCUMENT DEFAULTS ========== */ html  {
  font-size: var(--root-font-size);
}
body  {
  font-family: var(--body-font-family);
  font-size: var(--body-font-size);
  color: var(--body-text-color);
  line-height: var(--body-line-height);
  margin: 0;
}
/* ========== HEADINGS ========== */ h1, h2, h3, h4, h5, h6  {
  font-family: var(--heading-font-family);
  color: var(--heading-text-color);
  font-weight: var(--heading-font-weight);
  margin-top: 0;
  margin-bottom: var(--heading-spacing);
}
h1, .heading-style-h1  {
  font-size: var(--heading-1-font-size);
  font-weight: var(--heading-1-font-weight);
  line-height: var(--heading-1-line-height);
  color: var(--heading-1-text-color);
}
h2, .heading-style-h2  {
  font-size: var(--heading-2-font-size);
  font-weight: var(--heading-2-font-weight);
  line-height: var(--heading-2-line-height);
  color: var(--heading-2-text-color);
}
h3, .heading-style-h3  {
  font-size: var(--heading-3-font-size);
  font-weight: var(--heading-3-font-weight);
  line-height: var(--heading-3-line-height);
  color: var(--heading-3-text-color);
}
h4, .heading-style-h4  {
  font-size: var(--heading-4-font-size);
  font-weight: var(--heading-4-font-weight);
  line-height: var(--heading-4-line-height);
  color: var(--heading-4-text-color);
}
h5, .heading-style-h5  {
  font-size: var(--heading-5-font-size);
  font-weight: var(--heading-5-font-weight);
  line-height: var(--heading-5-line-height);
  color: var(--heading-5-text-color);
}
h6, .heading-style-h6  {
  font-size: var(--heading-6-font-size);
  font-weight: var(--heading-6-font-weight);
  line-height: var(--heading-6-line-height);
  color: var(--heading-6-text-color);
}
/* ========== BUTTONS ========== */ .btn-primary  {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-button-primary-bg);
  color: var(--color-button-primary-text-color);
  border-radius: 9999px;
  padding: 0.7rem 1.5rem;
  font-weight: var(--font-weight-medium);
  border-width: 0px;
  font-size: var(--font-size-small);
  text-decoration: none;
}
.btn-primary:hover  {
  filter: brightness(110%);
  color: var(--color-button-primary-text-color);
  cursor: pointer;
  text-decoration: none;
}
.btn-ghost  {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-primary);
  border-radius: 9999px;
  padding: 0.7rem 1.5rem;
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-small);
  text-decoration: none;
}
.btn-ghost:hover  {
  /*background-color: var(--color-accent-dark);
  */ filter: brightness(110%);
  cursor: pointer;
  color: var(--color-text-primary);
  text-decoration: none;
}
.btn-light  {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-text-inverse);
  color: var(--color-text-primary);
  border: 2px solid var(--color-secondary-dark);
  border-radius: 9999px;
  padding: 0.7rem 1.5rem;
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-small);
  text-decoration: none;
}
.btn-light:hover  {
  background-color: var(--color-secondary-light);
  cursor: pointer;
  color: var(--color-text-primary);
  text-decoration: none;
}


 /** Content Section Styles **/ 

.content-section-154  {
}
.content-section-155  {
}
.content-section-156  {
  .my-hero-container p  {
    font-size: 1.1rem;
  }
  img.my-hero-image  {
    width: 100%;
    height: 100%;
  }
  .my-hero-container  {
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    display: grid;
    column-gap: clamp(2rem, 5vw, 6rem);
    row-gap: 0;
  }
  @media (max-width: 767px)  {
    .my-hero-container  {
      grid-template-columns: 1fr;
      row-gap: 2rem;
      column-gap: 0;
    }
  }
}
.content-section-159  {
  .my-grid  {
    display: grid;
    gap: 3rem;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  }
}
.content-section-160  {
  .my-grid  {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    align-items: center;
    column-gap: clamp(2rem, 5vw, 7rem);
    row-gap: 0;
  }
  @media (max-width: 767px)  {
    .my-grid  {
      grid-template-columns: 1fr;
      row-gap: 2rem;
      column-gap: 0;
    }
    /* Reversing col order when stacking */ .my-grid .col-1  {
      order: 2;
    }
    .my-grid .col-2  {
      order: 1;
    }
  }
}
.content-section-161  {
  h1,h2,h3,h4,h5,h6,p  {
    color: white;
  }
  .my-grid  {
    display: grid;
    gap: 3rem;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  }
}
.content-section-183  {
}
.content-section-184  {
}
.content-section-185  {
}
.content-section-186  {
}
