/* ===== VARIABLES ===== */
:root {
  /* Colors */
  --brand:        #4079A0;   /* primary blue" links, buttons */
  --brand-dark:   #26526D;   /* teal " hover states, headings */
  --navy:         #061C2D;   /* alias for ink */
  --ink:          #061C2D;   /* primary text" dark navy */
  --ink-mid:      #07253E;   /* secondary headings */
  --ink-light:    #5F5F5F;   /* body secondary text */
  --ink-muted:    #707070;   /* captions, meta */
  --gold:         #FFD400;   /* gold CTA " buttons, highlights */
  --accent:       #FFD400;   /* alias for gold */
  --accent-warm:  #9E864C;   /* ornamental gold-brown */
  --charcoal:     #3A3A3A;   /* dark gray " buttons, overlays */
  --charcoal-mid: #404C5A;   /* blue-gray " newsletter bg */
  --bg:           #FFFFFF;   /* page background */
  --bg-warm:      #F7F4EF;   /* warm off-white sections */
  --bg-soft:      #F9F6F3;   /* slightly warmer cream */
  --bg-light:     #E7ECEF;   /* light blue-gray sections */
  --bg-alt:       #E1E7EB;   /* alternate section bg */
  --border:       #E4E4E4;   /* dividers, input borders */
  --border-soft:  #C8C9CD;   /* soft outline buttons */

  /* Typography */
  --sans:         "Poppins", sans-serif;    /* headings, UI */
  --serif:        "Lora", serif;            /* body copy */
  --display:      "Rufina", serif;          /* large display titles */
  --base-size:    20px;
  --line-height:  1.6;

  /* Spacing */
  --section-pad:        80px;
  --section-pad-mobile: 40px;
  --gap:                32px;
  --gap-sm:             16px;
  --gap-mobile:         20px;

  /* Layout */
  --gutter:              20px;
  --gutter-mobile:       16px;
  --container:           1420px;
  --container-md:        1200px;
  --container-sm:        991px;
  --container-xs:        768px;
  --container-lg:        1920px;
  --radius:              4px;
  --radius-lg:           8px;
}

/* ===== RESET & BASE ===== */

/* Box model reset */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Base typography */
body {
  font-family: var(--font-body, "Lora", serif);
  font-size: var(--base-size, 20px);
  line-height: var(--line-height, 1.6);
  color: var(--ink, #061C2D);
  background: var(--bg, #FFFFFF);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading, "Poppins", sans-serif);
  font-weight: 700;
  line-height: 1.2;
  color: var(--ink, #061C2D);
}

a {
  color: var(--brand, #4079A0);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--brand-dark, #26526D);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Section headings */
.section-eyebrow {
  font-family: var(--sans, "Poppins", sans-serif);
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  text-transform: uppercase;
  color: var(--ink, #061C2D);
}

.section-title {
  font-family: var(--sans, "Poppins", sans-serif);
  font-size: 50px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.06;
  color: var(--ink, #061C2D);
}

.section-body p {
  font-size: var(--base-size, 20px);
  color: var(--ink, #061C2D);
  font-family: var(--sans, "Poppins", sans-serif);
  font-style: normal;
  font-weight: 300;
  line-height: 28px;
  letter-spacing: 0.12px;
  margin-bottom: 34px;
}

.section-body p:last-child {
  margin-bottom: 0;
}

.section-body--lead > p:first-child {
  color: var(--brand, #4079A0);
  font-weight: 600;
}

/* Containers */
.container {
  --container-current: var(--container, 1420px);
  --container-gutter: 100px;
  width: 100%;
  max-width: calc(var(--container-current) + (var(--container-gutter) * 2));
  margin-inline: auto;
  padding-inline: var(--container-gutter);
  position: relative;
}

.container-lg {
  width: 100%;
  max-width: var(--container-lg, 1920px);
  margin-inline: auto;
  position: relative;
}

.container-fluid,
.container-full {
  width: 100%;
  max-width: none;
  margin-inline: auto;
  padding-inline: var(--gutter, 20px);
  position: relative;
}

@media (max-width: 520px) {
  .container {
    --container-gutter: var(--gutter-mobile, 16px);
  }

  .container-fluid,
  .container-full {
    padding-inline: var(--gutter-mobile, 16px);
  }

}

@media (max-width: 1420px) {
  .container {
    --container-current: var(--container-md, 1200px);
  }
}

@media (max-width: 1200px) {
  .container {
    --container-current: var(--container-sm, 991px);
    --container-gutter: 40px;
  }
}

@media (max-width: 991px) {
  .container {
    --container-current: var(--container-xs, 768px);
    --container-gutter: var(--gutter, 20px);
  }
}

/* Button base */
.btn-layout {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 50px;
  border-radius: var(--radius, 0px);
  font-family: var(--font-heading, "Poppins", sans-serif);
  font-size: 20px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
  border: 1px solid transparent;
}

.btn-layout.yellow {
  background: var(--gold, #FFD400);
  color: var(--navy, #061C2D);
  border-color: var(--gold, #FFD400);
}

.btn-layout.yellow:hover {
  background: var(--navy, #061C2D);
  color: var(--gold, #FFD400);
  border-color: var(--navy, #061C2D);
}

.btn-layout.white-hollow {
  background: transparent;
  color: #fff;
  border-color: #fff;
}

.btn-layout.white-hollow:hover {
  background: #fff;
  color: var(--ink, #061C2D);
  border-color: #fff;
}

.btn-layout.blue {
  background: #26526D;
  color: #FFFFFF;
  border-color: #26526D;
}

.btn-layout.blue:hover {
  background: transparent;
  color: var(--ink, #061C2D);
  border-color: var(--brand, #4079A0);
}

.btn-layout.dark {
  background: var(--charcoal, #3A3A3A);
  color: #FFFFFF;
  border-color: var(--charcoal, #3A3A3A);
}

.btn-layout.dark:hover {
  background: transparent;
  color: var(--ink, #061C2D);
  border-color: var(--charcoal, #3A3A3A);
}

.btn-layout.warm {
  background: var(--accent-warm, #9E864C);
  color: #FFFFFF;
  border-color: var(--accent-warm, #9E864C);
}

.btn-layout.warm:hover {
  background: transparent;
  color: var(--ink, #061C2D);
  border-color: var(--accent-warm, #9E864C);
}

.btn-layout.soft-hollow {
  background: transparent;
  color: var(--ink, #061C2D);
  border-color: var(--border-soft, #C8C9CD);
}

.btn-layout.soft-hollow:hover {
  background: var(--ink, #061C2D);
  color: #FFFFFF;
  border-color: var(--ink, #061C2D);
}

/* Icon system → see icons.css */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* Scroll reveal utilities */
.reveal-pending {
  opacity: 0;
  will-change: opacity, transform;
}

.reveal-pending.scroll,
.reveal-pending.scroll-up,
.reveal-pending[data-reveal="up"] {
  transform: translate3d(0, var(--reveal-distance, 48px), 0);
}

.reveal-pending.scroll-down,
.reveal-pending[data-reveal="down"] {
  transform: translate3d(0, calc(var(--reveal-distance, 48px) * -1), 0);
}

.reveal-pending.scroll-left,
.reveal-pending[data-reveal="left"] {
  transform: translate3d(calc(var(--reveal-distance, 48px) * -1), 0, 0);
}

.reveal-pending.scroll-right,
.reveal-pending[data-reveal="right"] {
  transform: translate3d(var(--reveal-distance, 48px), 0, 0);
}

.ready,
.ready-up,
.ready-down,
.ready-left,
.ready-right {
  opacity: 1;
  animation-duration: var(--reveal-duration, 1.2s);
  animation-delay: var(--reveal-delay, 0ms);
  animation-fill-mode: both;
  animation-timing-function: var(--reveal-ease, cubic-bezier(0.22, 1, 0.36, 1));
  will-change: opacity, transform;
}

.ready,
.ready-up {
  animation-name: fadeInUp;
}

.ready-down {
  animation-name: fadeInDown;
}

.ready-left {
  animation-name: fadeInLeft;
}

.ready-right {
  animation-name: fadeInRight;
}

.reveal-visible {
  opacity: 1;
  transform: none;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, calc(var(--reveal-distance, 48px) * -1), 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, var(--reveal-distance, 48px), 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(calc(var(--reveal-distance, 48px) * -1), 0, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translate3d(var(--reveal-distance, 48px), 0, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .reveal-pending,
  .ready,
  .ready-up,
  .ready-down,
  .ready-left,
  .ready-right,
  .reveal-visible {
    opacity: 1 !important;
    animation: none !important;
    transform: none !important;
    transition: none !important;
  }
}

@media (max-width: 540px) {
  .btn-layout {
    font-size: 18px;
  }
}

