*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --black: #0a0a0a;
  --dark: #111111;
  --gray: #1c1c1c;
  --light-gray: #888;
  --off-white: #f0ede8;
  --white: #ffffff;
  --accent: #c9a84c;
  --accent-light: #e8c87a;
  --accent-dim: rgba(201,168,76,0.12);
  --fd: 'Arial Black', 'Helvetica Neue', Arial, sans-serif;
  --fb: 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
}

html { scroll-behavior: smooth; }
body { font-family: var(--fb); background: var(--black); color: var(--off-white); overflow-x: hidden; }

/* SHARED BUTTONS */
.btn-primary {
  background: var(--accent); color: var(--black);
  padding: .9rem 2rem; font-size: .72rem; font-weight: 700;
  letter-spacing: .15em; text-transform: uppercase;
  text-decoration: none; display: inline-block; border: none; cursor: pointer;
  transition: background .2s, transform .2s;
}
.btn-primary:hover { background: var(--accent-light); transform: translateY(-2px); }

.btn-outline {
  border: 1px solid rgba(201,168,76,.4); color: var(--off-white);
  padding: .9rem 2rem; font-size: .72rem; font-weight: 600;
  letter-spacing: .15em; text-transform: uppercase;
  text-decoration: none; display: inline-block;
  transition: border-color .2s, color .2s;
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }

/* SHARED SECTION STYLES */
section { padding: 6rem 5vw; }
.section-tag { font-size: .63rem; letter-spacing: .35em; text-transform: uppercase; color: var(--accent); margin-bottom: .8rem; }
.section-title { font-family: var(--fd); font-size: clamp(2.2rem, 4.5vw, 4rem); line-height: 1.05; color: var(--white); margin-bottom: 1.4rem; letter-spacing: .04em; }
.section-body { font-size: .95rem; font-weight: 300; color: var(--light-gray); line-height: 1.9; max-width: 58ch; }

/* REVEAL ANIMATION */
@keyframes fadeUp   { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeRight{ from { opacity:0; transform:translateX(-14px);} to { opacity:1; transform:translateX(0); } }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
