:root {
  --gold: #C9A84C;
  --gold-light: #E8C96A;
  --gold-dim: #7A5C1E;
  --black: #031810;
  --charcoal: #0b261b;
  --dark: #12402b;
  --mid: #1a5a3b;
  --cream: #F5F0E8;
  --text: #ECF8EF;
  --muted: #B8D8C0;
  --red-accent: #8B2E2E;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
img, svg, video { max-width: 100%; height: auto; }
body {
  background-color: var(--black);
  background-image:
    radial-gradient(circle at 25% 25%, rgba(255,255,255,0.06) 1px, transparent 1.5px),
    radial-gradient(circle at 75% 75%, rgba(255,255,255,0.05) 1px, transparent 1.5px),
    linear-gradient(135deg, rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(160deg, #031810 0%, #073323 45%, #0f5137 100%);
  background-size: 26px 26px, 26px 26px, 42px 42px, cover;
  background-position: 0 0, 13px 13px, 0 0, 0 0;
  color: var(--text);
  font-family: 'Josefin Sans', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
  cursor: none;
}
.cursor { width: 12px; height: 12px; background: var(--gold); border-radius: 50%; position: fixed; pointer-events: none; z-index: 9999; transform: translate(-50%, -50%); transition: transform .1s ease,width .2s ease,height .2s ease; mix-blend-mode: difference; }
.cursor-ring { width: 36px; height: 36px; border: 1px solid var(--gold); border-radius: 50%; position: fixed; pointer-events: none; z-index: 9998; transform: translate(-50%, -50%); transition: transform .15s ease,width .3s ease,height .3s ease,opacity .3s ease; opacity: .5; }
nav { position: sticky; top: 0; z-index: 1000; padding: 20px 60px; display: flex; justify-content: space-between; align-items: center; background: rgba(3,24,16,0.96); border-bottom: 1px solid rgba(201,168,76,.15); }
.nav-logo { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; font-weight: 600; letter-spacing: .12em; color: var(--gold); text-decoration: none; text-transform: uppercase; }
.nav-logo span { font-style: italic; font-weight: 300; color: var(--cream); font-size: .85rem; display: block; letter-spacing: .3em; margin-top: -4px; }
.nav-toggle { display: none; position: relative; width: 92px; height: 44px; padding: 0 38px 0 14px; border: 1px solid rgba(201,168,76,.45); background: rgba(255,255,255,.05); color: var(--gold); cursor: pointer; font-family: inherit; }
.nav-toggle::before { content: "Menu"; font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; }
.nav-toggle span { position: absolute; right: 13px; display: block; width: 18px; height: 1px; background: currentColor; transition: top .2s ease, transform .2s ease, opacity .2s ease; }
.nav-toggle span:nth-child(1) { top: 15px; }
.nav-toggle span:nth-child(2) { top: 21px; }
.nav-toggle span:nth-child(3) { top: 27px; }
.nav-links { display: flex; gap: 28px; list-style: none; }
.nav-links a { color: var(--text); text-decoration: none; font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; }
.nav-links a.active, .nav-links a:hover { color: var(--gold); }
.hero { min-height: 80vh; display: grid; place-items: center; padding: 80px 24px; background: radial-gradient(ellipse at 70% 30%, rgba(201,168,76,0.08) 0%, transparent 60%), radial-gradient(circle at 20% 20%, rgba(255,255,255,0.06) 1px, transparent 1.6px), linear-gradient(160deg, #031810 0%, #073323 45%, #0f5137 100%); background-size: auto, 28px 28px, auto; text-align: center; }
.hero-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(3rem, 8vw, 7rem); font-weight: 300; color: var(--cream); line-height: .92; }
.hero-title em { color: var(--gold); font-style: italic; }
.hero-subtitle { margin-top: 18px; font-size: .82rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text); }
section { padding: 90px 60px; }
.container { max-width: 1200px; margin: 0 auto; }
.section-eyebrow { font-size: .64rem; letter-spacing: .45em; color: var(--gold-light); text-transform: uppercase; margin-bottom: 16px; }
.section-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 300; color: var(--cream); line-height: 1.1; }
.section-title em { color: var(--gold); }
.section-body { font-size: .9rem; line-height: 1.9; color: var(--muted); max-width: 720px; margin-top: 20px; }
.section-body a { color: var(--text); text-decoration: none; }
.section-body a:hover { color: var(--gold); }
.core-pillar-list { display: grid; gap: 8px; }
.core-pillar-list a, .core-pillar-list span { display: block; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; margin-top: 40px; }
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 40px; }
.feature { background: rgba(255,255,255,.03); border: 1px solid rgba(201,168,76,.12); padding: 30px 26px; }
.feature h3 { font-family: 'Cormorant Garamond', serif; color: var(--cream); font-size: 1.8rem; margin-bottom: 16px; font-weight: 300; }
.feature p { color: var(--muted); line-height: 1.9; font-size: .9rem; }
.card { background: var(--charcoal); border: 1px solid rgba(255,255,255,.03); padding: 36px 30px; }
.card h3 { font-family: 'Cormorant Garamond', serif; color: var(--cream); font-weight: 300; font-size: 2rem; margin: 10px 0 12px; }
.card p { color: var(--muted); font-size: .8rem; line-height: 1.8; }
.list { margin-top: 14px; padding-left: 18px; color: var(--text); line-height: 1.8; font-size: .78rem; }
.site-footer { padding: 32px 40px 16px; background: linear-gradient(160deg, #071f14 0%, #0c3a27 100%); border-top: 1px solid rgba(201,168,76,.12); }
.footer-top { max-width: 1200px; margin: 0 auto 10px; display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer-eyebrow { text-transform: uppercase; letter-spacing: .3em; color: var(--gold-light); font-size: .68rem; margin-bottom: 6px; }
.footer-copy { max-width: 360px; color: var(--muted); line-height: 1.7; }
.footer-links, .footer-contact, .footer-social { min-width: 180px; }
.footer-label { text-transform: uppercase; letter-spacing: .35em; color: var(--gold); font-size: .7rem; margin-bottom: 10px; }
.footer-links ul, .footer-social ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.footer-links a { color: rgba(255,255,255,.8); text-decoration: none; transition: color .2s ease; }
.footer-social a, .footer-social a:visited, .footer-social a:active { color: rgba(255,255,255,.8); -webkit-text-fill-color: rgba(255,255,255,.8); text-decoration: none; transition: color .2s ease; }
.footer-links a:hover, .footer-social a:hover { color: var(--text); -webkit-text-fill-color: var(--text); }
.footer-contact p { color: var(--muted); margin-bottom: 6px; }
.footer-bottom { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: .82rem; }
.footer-marquee { position: relative; overflow: hidden; width: 100%; min-height: 24px; }
.marquee-track { display: inline-block; white-space: nowrap; color: rgba(255,255,255,.72); animation: marquee 45s linear infinite; }
@keyframes marquee { 0% { transform: translateX(100%); } 100% { transform: translateX(-100%); } }
.btn-outline { display:inline-block; margin-top:20px; color: var(--gold); border:1px solid rgba(201,168,76,.3); text-decoration:none; padding:12px 20px; letter-spacing:.2em; text-transform:uppercase; font-size:.65rem; }
.contact-form { display: grid; gap: 12px; max-width: 720px; margin-top: 24px; }
.contact-form input, .contact-form textarea, .contact-form select { background: rgba(255,255,255,.05); border: 1px solid rgba(201,168,76,.18); color: var(--text); padding: 14px 16px; font-family: inherit; font-size: .9rem; border-radius: 8px; }
.contact-form select { appearance: none; min-height: 48px; }
.contact-form select option { color: var(--text); background: var(--charcoal); }
.contact-form button { background: var(--gold); color: var(--black); border: 0; padding: 14px 20px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; cursor: pointer; }
@media (max-width: 900px) {
  nav, section, footer { padding-left: 24px; padding-right: 24px; }
  nav { align-items: center; flex-wrap: wrap; gap: 14px; padding-top: 16px; padding-bottom: 16px; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: flex-start; margin-left: auto; }
  nav.is-open .nav-toggle::before { content: "Close"; }
  nav.is-open .nav-toggle span:nth-child(1) { top: 21px; transform: rotate(45deg); }
  nav.is-open .nav-toggle span:nth-child(2) { opacity: 0; }
  nav.is-open .nav-toggle span:nth-child(3) { top: 21px; transform: rotate(-45deg); }
  .nav-links { display: none; width: 100%; gap: 0; padding-top: 14px; overflow: hidden; border-top: 1px solid rgba(201,168,76,.14); }
  nav.is-open .nav-links, .nav-toggle:focus-visible + .nav-links { display: grid; }
  .nav-links li + li { border-top: 1px solid rgba(255,255,255,.06); }
  .nav-links a { display: block; font-size: .7rem; letter-spacing: .2em; padding: 14px 0; white-space: normal; }
  .grid-2, .card-grid, .feature-grid { grid-template-columns: 1fr; }
  .hero { min-height: 72vh; }
  section { padding-top: 64px; padding-bottom: 64px; }
}

.hero-subtitle-long { max-width: 760px; margin-left: auto; margin-right: auto; letter-spacing: 0.05em; text-transform: none; line-height: 1.75; color: var(--text); }

@media (max-width: 640px) {
  nav { padding: 14px 18px; }
  .nav-logo { font-size: 1.2rem; }
  .nav-logo span { font-size: .72rem; letter-spacing: .24em; }
  .nav-toggle { width: 88px; height: 40px; }
  .nav-links { grid-template-columns: 1fr; gap: 0; }
  .nav-links a { letter-spacing: .14em; line-height: 1.4; }
  .hero { min-height: auto; padding: 68px 18px; }
  .hero-title { font-size: clamp(2.45rem, 17vw, 4rem); line-height: 1; }
  .hero-subtitle { font-size: .78rem; letter-spacing: .08em; line-height: 1.6; }
  section { padding: 56px 18px; }
  .section-eyebrow { letter-spacing: .28em; line-height: 1.8; }
  .section-title { font-size: clamp(2rem, 12vw, 3.2rem); }
  .grid-2 { gap: 28px; }
  .card-grid { gap: 14px; }
  .feature-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 32px 0 0;
  }
  .feature {
    width: 100%;
  }
  .card, .feature { padding: 26px 20px; }
  .feature h3, .card h3 { font-size: 1.65rem; }
  .btn-outline, .contact-form button { width: 100%; text-align: center; letter-spacing: .14em; }
  .contact-form input, .contact-form textarea, .contact-form select { width: 100%; }
  .site-footer { padding: 28px 18px 14px; }
  .footer-top, .footer-bottom { display: grid; gap: 22px; }
  .footer-links, .footer-contact, .footer-social { min-width: 0; }
  .marquee-track { animation-duration: 60s; }
}

@media (hover: none), (pointer: coarse) {
  body { cursor: auto; }
  .cursor, .cursor-ring { display: none; }
}
