/* ── SHARED COMPONENTS ── */

.btn {
  display: inline-block;
  padding: .85rem 2rem;
  border-radius: 50px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  text-align: center;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.2); }
.btn-primary   { background: var(--gold); color: var(--dark); }
.btn-outline   { background: transparent; border: 2px solid var(--white); color: var(--white); }
.btn-maroon    { background: var(--maroon); color: var(--white); }

.section-label {
  display: inline-block;
  background: var(--gold-l);
  color: var(--maroon-d);
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .3rem .9rem;
  border-radius: 50px;
  margin-bottom: .75rem;
}
.section-title {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 900;
  margin-bottom: 1rem;
}
.section-sub {
  font-size: 1.05rem;
  color: #555;
  max-width: 600px;
}
