@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,500&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

html { scroll-behavior: smooth; }
body { font-family: 'Hanken Grotesk', system-ui, sans-serif; background: #0B0B0B; color: #F8F7F3; -webkit-font-smoothing: antialiased; }
.font-display { font-family: 'Cormorant Garamond', Georgia, serif; }
.eyebrow { font-family: 'Hanken Grotesk', sans-serif; text-transform: uppercase; letter-spacing: 0.15em; font-weight: 500; font-size: 13px; }
.hero-h { font-size: 60px; line-height: 1.12; letter-spacing: -0.01em; }
.section-h { font-size: 42px; line-height: 1.14; letter-spacing: -0.005em; }
.body-lg { font-size: 20px; line-height: 1.6; }
.body-md { font-size: 16.5px; line-height: 1.75; }
@media (max-width: 768px) {
  .hero-h { font-size: 40px; }
  .section-h { font-size: 30px; }
  .body-lg { font-size: 17px; }
}
::selection { background: #8A6A44; color: #0B0B0B; }
section[id] { scroll-margin-top: 80px; }

/* Brand horizon mark */
.rt-mark { display: block; color: #F8F7F3; }
.rt-lockup { display: inline-flex; align-items: center; gap: 12px; }
.rt-wordmark { font-family: 'Hanken Grotesk', sans-serif; font-weight: 500; letter-spacing: 0.34em; text-transform: uppercase; color: #F8F7F3; line-height: 1; padding-left: 0.17em; }

/* Nav */
#nav { transition: background-color .35s ease, border-color .35s ease; }
#nav.scrolled { background-color: rgba(11,11,11,0.92); backdrop-filter: blur(8px); border-bottom: 1px solid #262521; }
.nav-link { font-size: 14px; color: rgba(248,247,243,0.8); transition: color .2s ease; }
.nav-link:hover { color: #F8F7F3; }
.nav-link.active { color: #F8F7F3; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; font-family: 'Hanken Grotesk', sans-serif; font-weight: 500; cursor: pointer; transition: all .25s ease; white-space: nowrap; }
.btn-primary { background: #8A6A44; color: #0B0B0B; border: 1px solid #8A6A44; }
.btn-primary:hover { background: #6F5436; border-color: #6F5436; }
.btn-secondary { background: transparent; color: #F8F7F3; border: 1px solid #F8F7F3; }
.btn-secondary:hover { background: #F8F7F3; color: #0B0B0B; }
.btn-nav { background: transparent; color: #F8F7F3; border: 1px solid #8A6A44; padding: 10px 18px; font-size: 13px; }
.btn-nav:hover { background: #8A6A44; color: #0B0B0B; }
.link-bronze { color: #8A6A44; border-bottom: 1px solid rgba(138,106,68,0.4); padding-bottom: 2px; transition: border-color .2s ease; }
.link-bronze:hover { border-color: #8A6A44; }

/* Form */
.field { width: 100%; background: transparent; border: 1px solid #262521; color: #F8F7F3; padding: 13px 15px; font-size: 15px; transition: border-color .2s ease; }
.field:focus { outline: none; border-color: #8A6A44; }
.field::placeholder { color: #5C5C56; }
label.lbl { display: block; font-size: 13px; letter-spacing: 0.04em; color: #9A9C95; margin-bottom: 8px; }

/* Decorative horizon */
.horizon { position: absolute; left: 0; right: 0; bottom: 0; pointer-events: none; }

/* ============== ICON SYSTEM ============== */
.ic { width: 100%; height: 100%; display: block; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.icon-circle { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; border: 1px solid currentColor; flex: none; }
.icon-circle .ic { width: 50%; height: 50%; }
/* bronze stroke variant on dark */
.ic-bronze { color: #8A6A44; }
.ic-ivory { color: #F8F7F3; }
.ic-ink { color: #0B0B0B; }

/* ============== CARDS ============== */
.rt-card { border: 1px solid #2A2824; border-radius: 4px; background: linear-gradient(180deg, rgba(255,255,255,0.018), rgba(255,255,255,0)); padding: 34px 30px; transition: border-color .3s ease, transform .3s ease; }
.rt-card:hover { border-color: #4A4338; }

/* ============== STAT BLOCK ============== */
.stat-grid { border: 1px solid #3A332A; display: grid; grid-template-columns: repeat(3, 1fr); }
.stat-cell { padding: 26px 22px; }
.stat-cell + .stat-cell { border-left: 1px solid #3A332A; }
.stat-num { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; color: #8A6A44; font-size: 52px; line-height: 1; }
.stat-label { font-family: 'Hanken Grotesk', sans-serif; text-transform: uppercase; letter-spacing: 0.13em; font-size: 11px; line-height: 1.5; color: #9A9C95; margin-top: 12px; }
@media (max-width: 640px){ .stat-num { font-size: 40px; } }

/* ============== FAQ ACCORDION ============== */
.faq-item { border-bottom: 1px solid; }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 20px; text-align: left; background: none; border: 0; cursor: pointer; padding: 26px 0; font-family: 'Hanken Grotesk', sans-serif; font-size: 19px; transition: color .2s ease; }
.faq-sign { flex: none; width: 22px; height: 22px; position: relative; color: #8A6A44; transition: transform .35s ease; }
.faq-sign::before, .faq-sign::after { content: ''; position: absolute; background: currentColor; left: 50%; top: 50%; }
.faq-sign::before { width: 16px; height: 1.4px; transform: translate(-50%,-50%); }
.faq-sign::after { width: 1.4px; height: 16px; transform: translate(-50%,-50%); transition: transform .35s ease; }
.faq-item.open .faq-sign::after { transform: translate(-50%,-50%) scaleY(0); }
.faq-a { overflow: hidden; max-height: 0; transition: max-height .4s ease; }
.faq-a-inner { padding: 0 0 28px; max-width: 760px; }

/* ============== PROCESS STEPS ============== */
.proc-rail { display: grid; grid-template-columns: repeat(5, 1fr); align-items: center; }
.proc-arrow { color: #4A4338; }
@media (max-width: 860px){ .proc-rail { display: none; } }

/* ============== ANIM ============== */
@media (prefers-reduced-motion: no-preference){
  .rise { opacity: 0; transform: translateY(18px); transition: opacity .8s ease, transform .8s ease; }
  .rise.in { opacity: 1; transform: none; }
}

/* placeholder imagery */
.ph-img { background-color: #15140F; background-image: repeating-linear-gradient(135deg, rgba(138,106,68,0.10) 0 2px, transparent 2px 11px); position: relative; }
.ph-tag { position: absolute; left: 14px; bottom: 12px; font-family: 'Hanken Grotesk', monospace; font-size: 11px; letter-spacing: 0.08em; color: rgba(248,247,243,0.45); text-transform: uppercase; }
