/* ── SPA PAGE SHELL ── */
.page         { display: none; }
.page.active  { display: block; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  overflow: hidden;
  white-space: nowrap;
}
/* Primary (gold fill) */
.bp {
  background: linear-gradient(135deg, var(--gold-b), var(--gold) 60%, var(--gold-d));
  color: var(--on-gold);
  padding: 16px 40px;
  box-shadow: 0 4px 24px rgba(201, 151, 44, .22);
}
.bp:hover {
  box-shadow: 0 6px 36px rgba(201, 151, 44, .38);
  transform: translateY(-1px);
}
/* Ghost (white border) */
.bg {
  background: transparent;
  color: var(--iv);
  padding: 15px 39px;
  border: 1px solid rgba(255, 255, 255, .2);
}
.bg:hover {
  border-color: var(--gold-br);
  color: var(--gold);
}
/* Outline (gold border) */
.bo {
  background: transparent;
  color: var(--gold);
  padding: 15px 39px;
  border: 1px solid var(--gold-br);
}
.bo:hover {
  background: var(--gold-t);
  border-color: var(--gold);
}

/* ── ICON BOX ── */
.ibox {
  width: 52px;
  height: 52px;
  background: var(--gold-t);
  border: 1px solid var(--gold-br);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}
.ibox svg      { width: 24px; height: 24px; }
.ibox-lg       { width: 56px; height: 56px; }
.ibox-lg svg   { width: 26px; height: 26px; }

/* ── GRID DIVIDER ── */
.gg {
  display: grid;
  gap: 1px;
  background: var(--bds);
  border: 1px solid var(--bds);
}

/* ── CTA BANNER ── */
.ctab {
  padding: 80px 40px;
  background: linear-gradient(135deg, var(--chdk), var(--chmd));
  border-top: 1px solid var(--bds);
}
.ctabi {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}
.ctab h2 {
  font-family: var(--fd);
  font-size: 34px;
  font-weight: 600;
  color: var(--iv);
  margin-bottom: 8px;
  letter-spacing: -.3px;
}
.ctab p {
  font-family: var(--fa);
  font-size: 18px;
  font-style: italic;
  color: var(--stl);
  font-weight: 300;
}
.ctaa {
  display: flex;
  gap: 14px;
  flex-shrink: 0;
}

/* ── SECTION LABELS / HEADERS ── */
.ey {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}
.st {
  font-family: var(--fd);
  font-size: 32px;
  font-weight: 600;
  color: var(--iv);
  letter-spacing: -.3px;
  margin-bottom: 6px;
}
.ss {
  font-size: 14px;
  font-weight: 300;
  color: var(--stl);
  margin-bottom: 48px;
  max-width: 540px;
  line-height: 1.7;
}

/* ── TAGS ── */
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 14px;
}
.tag {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  padding: 4px 10px;
  border: 1px solid var(--gold-br);
  background: var(--gold-ts);
}

/* ── SCROLL FADE-UP ── */
.fu {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}
.fu.vis {
  opacity: 1;
  transform: none;
}
.s1 { transition-delay: .1s; }
.s2 { transition-delay: .2s; }
.s3 { transition-delay: .3s; }
