:root {
  --ink: #1a1714;
  --graphite: #3a3530;
  --mid: #746d65;
  --light: #c8bfb5;
  --accent: #163c31;
  --accent-light: #1f5242;
  --gold: #c9973a;
  --surface: #e8e8e8;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { color: var(--ink); background: #fff; font-family: 'DM Sans', sans-serif; overflow-x: hidden; }
nav {
  position: fixed; inset: 0 0 auto; z-index: 100; min-height: 104px;
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 8vw; background: rgba(255,255,255,.96);
  border-bottom: 1px solid rgba(200,191,181,.4); backdrop-filter: blur(12px);
}
.nav-logo img { display: block; width: auto; height: 78px; object-fit: contain; }
.nav-links { display: flex; align-items: center; gap: 2.5rem; list-style: none; }
.nav-links a { color: var(--graphite); font-size: .88rem; font-weight: 500; letter-spacing: .06em; text-decoration: none; text-transform: uppercase; }
.nav-links a:hover, .nav-links a.active { color: var(--accent); }
.nav-links .nav-cta { padding: .65rem 1.35rem; color: #fff; background: var(--accent); border-radius: 2px; }
.nav-links .nav-cta:hover { color: #fff; background: var(--accent-light); }
.hamburger { display: none; width: 50px; height: 50px; border: 1px solid rgba(22,60,49,.14); border-radius: 50%; background: #f5f5f5; }
.hamburger span { display: block; width: 22px; height: 2px; margin: 5px auto; background: var(--accent); transition: .2s; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-menu { display: none; }
.hero { min-height: 720px; padding: 9.5rem 8vw 5rem; display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: clamp(3rem,7vw,7rem); background: linear-gradient(120deg,#f7f7f5,#fff); }
.eyebrow { margin-bottom: .9rem; color: var(--accent); font-size: .76rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.hero h1 { max-width: 720px; font-family: 'Playfair Display', serif; font-size: clamp(2.7rem,5vw,5rem); font-weight: 900; line-height: 1.03; }
.hero h1 em { color: var(--accent); }
.lead { max-width: 680px; margin-top: 1.4rem; color: var(--mid); font-size: 1.08rem; font-weight: 300; line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.btn { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; padding: .9rem 1.6rem; border: 1px solid var(--accent); border-radius: 2px; font-size: .9rem; font-weight: 600; text-decoration: none; }
.btn-primary { color: #fff; background: var(--accent); }
.btn-primary:hover { background: var(--accent-light); }
.btn-secondary { color: var(--accent); background: transparent; }
.hero-image { position: relative; }
.hero-image img { display: block; width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 2px; }
.hero-badge { position: absolute; right: -1rem; bottom: 1.5rem; padding: 1rem 1.25rem; color: #fff; background: var(--accent); box-shadow: 0 12px 30px rgba(22,60,49,.25); }
.hero-badge strong { display: block; font-family: 'Playfair Display',serif; font-size: 1.6rem; }
.hero-badge span { font-size: .76rem; }
.trust { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--surface); border-bottom: 1px solid var(--surface); }
.trust div { padding: 1.5rem 2rem; text-align: center; border-right: 1px solid var(--surface); }
.trust div:last-child { border-right: 0; }
.trust strong { display: block; color: var(--accent); font-family: 'Playfair Display',serif; font-size: 1.4rem; }
.trust span { color: var(--mid); font-size: .8rem; }
main section { padding: 5rem 8vw; }
.content-grid { display: grid; grid-template-columns: minmax(0,1.25fr) minmax(280px,.75fr); gap: clamp(3rem,7vw,7rem); }
h2 { margin-bottom: 1.2rem; font-family: 'Playfair Display',serif; font-size: clamp(2rem,3.5vw,3.2rem); line-height: 1.15; }
h3 { margin-bottom: .55rem; font-family: 'Playfair Display',serif; font-size: 1.25rem; }
.copy p { margin-bottom: 1.1rem; color: var(--mid); line-height: 1.78; }
.check-list { display: grid; gap: .8rem; margin-top: 1.5rem; list-style: none; }
.check-list li { position: relative; padding-left: 1.6rem; color: var(--graphite); line-height: 1.55; }
.check-list li::before { content: '✓'; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.info-card { align-self: start; padding: 2rem; background: #f5f5f5; border-top: 3px solid var(--accent); }
.info-card p { margin-bottom: 1rem; color: var(--mid); line-height: 1.65; }
.info-card a { color: var(--accent); font-weight: 600; text-decoration: none; }
.process-section { background: #f7f7f5; }
.process-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; margin-top: 2.5rem; }
.process-card { padding: 1.8rem; background: #fff; border: 1px solid var(--surface); }
.process-num { margin-bottom: .8rem; color: var(--gold); font-family: 'Playfair Display',serif; font-size: 2rem; font-weight: 900; }
.process-card p { color: var(--mid); font-size: .9rem; line-height: 1.65; }
.related { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 2rem; }
.related a { padding: 1.4rem; color: var(--accent); background: #f5f5f5; border: 1px solid var(--surface); font-weight: 600; text-decoration: none; }
.related a:hover { border-color: var(--accent); }
.cta { display: flex; align-items: center; justify-content: space-between; gap: 2rem; padding: 4rem 8vw; color: #fff; background: var(--accent); }
.cta h2 { margin: 0; color: #fff; }
.cta p { margin-top: .7rem; color: rgba(255,255,255,.75); }
.cta .btn { flex-shrink: 0; color: var(--accent); background: #fff; border-color: #fff; }
footer { padding: 3rem 8vw 1.5rem; color: var(--light); background: var(--ink); }
.footer-inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 3rem; max-width: 1180px; margin: 0 auto 2rem; }
.footer-brand img { width: auto; height: 60px; margin-bottom: .9rem; }
.footer-brand p, footer a { color: rgba(200,191,181,.75); font-size: .86rem; line-height: 1.65; text-decoration: none; }
footer h4 { margin-bottom: .8rem; color: rgba(200,191,181,.5); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; }
footer ul { display: grid; gap: .55rem; list-style: none; }
.footer-credit { padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.08); text-align: center; color: rgba(200,191,181,.55); font-size: .75rem; }
.floating-call { position: fixed; right: 1.4rem; bottom: 1.4rem; z-index: 120; display: grid; width: 58px; height: 58px; place-items: center; color: #fff; background: var(--accent); border-radius: 50%; box-shadow: 0 12px 30px rgba(22,60,49,.35); }
.floating-call svg { width: 24px; }
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: block; }
  .mobile-menu { position: fixed; top: 96px; left: 5vw; right: 5vw; z-index: 99; flex-direction: column; padding: .8rem; background: #fff; border: 1px solid var(--surface); box-shadow: 0 20px 50px rgba(26,23,20,.14); }
  .mobile-menu.open { display: flex; }
  .mobile-menu a { padding: .9rem; color: var(--graphite); border-bottom: 1px solid var(--surface); font-weight: 600; text-decoration: none; }
  .hero { grid-template-columns: 1fr; padding-top: 8rem; }
  .hero-image { max-width: 620px; }
  .content-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: repeat(2,1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  nav { min-height: 96px; padding: .8rem 5vw; }
  .nav-logo img { height: 68px; }
  .hero, main section { padding-left: 5vw; padding-right: 5vw; }
  .hero { min-height: auto; padding-bottom: 3.5rem; }
  .hero-actions, .hero-actions .btn { width: 100%; }
  .hero-badge { right: .75rem; bottom: .75rem; }
  .trust { grid-template-columns: 1fr; }
  .trust div { border-right: 0; border-bottom: 1px solid var(--surface); }
  .process-grid, .related, .footer-inner { grid-template-columns: 1fr; }
  .cta { align-items: stretch; flex-direction: column; padding: 3rem 5vw; }
  .cta .btn { width: 100%; }
  footer { padding-left: 5vw; padding-right: 5vw; }
}
