:root {
  --navy:      #0C1A2E;
  --navy-mid:  #162540;
  --gold:      #C17D2E;
  --gold-lt:   #E8A24A;
  --gold-pale: #FBF3E6;
  --cream:     #F8F6F2;
  --white:     #FFFFFF;
  --g100:      #F0EDE8;
  --g300:      #CCC8C0;
  --g500:      #888078;
  --g700:      #3E3A35;
  --text:      #18150F;
  --r:         10px;
  --rl:        16px;
  --max:       1120px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--cream);
  color: var(--text);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}

/* ── TYPOGRAPHY ── */
h1 { font-family: 'Playfair Display', serif; font-size: clamp(2.2rem, 4.5vw, 3.4rem); line-height: 1.12; letter-spacing: -.025em; }
h2 { font-family: 'Playfair Display', serif; font-size: clamp(1.7rem, 3.2vw, 2.5rem); line-height: 1.15; letter-spacing: -.02em; color: var(--navy); }
h3 { font-size: 1rem; font-weight: 600; color: var(--navy); }
p  { line-height: 1.7; }

/* ── LAYOUT ── */
.wrap     { max-width: var(--max); margin: 0 auto; width: 100%; }
.sec      { padding: 88px 5%; }
.sec-tag  { font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
.sec-sub  { font-size: .97rem; color: var(--g500); max-width: 500px; line-height: 1.75; }

/* ── BUTTONS ── */
.btn-gold {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--gold); color: var(--navy);
  text-decoration: none; font-size: .95rem; font-weight: 700;
  padding: 15px 36px; border-radius: var(--r);
  transition: background .2s, transform .1s; letter-spacing: .01em;
}
.btn-gold:hover  { background: var(--gold-lt); }
.btn-gold:active { transform: scale(.98); }
.btn-outline {
  display: block; width: 100%; background: transparent;
  border: 1px solid rgba(255,255,255,.22); color: #fff;
  text-decoration: none; font-size: .86rem; font-weight: 600;
  padding: 13px; border-radius: var(--r); text-align: center;
  transition: background .2s, border-color .2s;
}
.btn-outline:hover { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.4); }

/* ── FADE UP ── */
.fade-up { opacity: 0; transform: translateY(18px); transition: opacity .5s ease, transform .5s ease; }
.fade-up.vis { opacity: 1; transform: none; }

/* ── PROSE (blog) ── */
.prose { max-width: 720px; margin: 0 auto; }
.prose h2 { margin: 2rem 0 .75rem; }
.prose h3 { margin: 1.5rem 0 .5rem; }
.prose p  { margin-bottom: 1rem; color: var(--g700); }
.prose ul, .prose ol { margin: 0 0 1rem 1.5rem; color: var(--g700); }
.prose li { margin-bottom: .4rem; line-height: 1.65; }
.prose a  { color: var(--blue, #1B4F8A); }
.prose strong { color: var(--navy); }

@media (max-width: 600px) {
  .sec { padding-left: 4%; padding-right: 4%; }
}
