:root {
  --green-950: #061812;
  --green-900: #08231b;
  --green-800: #0d3528;
  --green-700: #144836;
  --gold: #c7a76a;
  --gold-dark: #9e814e;
  --cream: #f5efe3;
  --cream-2: #fbf8f1;
  --white: #ffffff;
  --muted: #d9d0bf;
  --text: #1c221f;
  --shadow: 0 24px 60px rgba(4, 17, 12, 0.28);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background: var(--cream-2);
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; }

.hero {
  min-height: 100vh;
  color: var(--white);
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 20%, rgba(199, 167, 106, 0.24), transparent 28%),
    linear-gradient(135deg, rgba(6, 24, 18, 0.92), rgba(8, 35, 27, 0.76)),
    url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=2200&q=80") center/cover;
}
.hero__shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,.3), rgba(6,24,18,.75));
}
.nav,
.hero__inner { position: relative; z-index: 1; }
.nav {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
  padding: 28px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav__brand { display: flex; gap: 12px; align-items: center; text-decoration: none; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; font-size: .82rem; }
.nav__crest { width: 42px; height: 42px; object-fit: contain; }
.nav__cta { text-decoration: none; color: var(--green-950); background: var(--gold); padding: 11px 18px; border-radius: 999px; font-weight: 800; font-size: .9rem; }

.hero__inner {
  width: min(1180px, calc(100% - 40px));
  min-height: calc(100vh - 102px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr .72fr;
  gap: 56px;
  align-items: center;
  padding: 42px 0 86px;
}
.hero__logo { width: min(440px, 88vw); margin-bottom: 34px; }
.eyebrow { color: var(--gold); text-transform: uppercase; letter-spacing: .18em; font-size: .76rem; font-weight: 800; margin: 0 0 12px; }
h1, h2, h3 { font-family: Cinzel, Georgia, serif; line-height: 1.05; margin: 0; }
h1 { font-size: clamp(3rem, 7vw, 6.9rem); max-width: 820px; letter-spacing: -.045em; }
h2 { font-size: clamp(2rem, 4vw, 4rem); letter-spacing: -.035em; color: var(--green-950); }
h3 { font-size: 1.5rem; color: var(--green-950); }
.lead { font-size: clamp(1.05rem, 2vw, 1.35rem); max-width: 690px; color: rgba(255,255,255,.88); margin: 24px 0 0; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 34px 0; }
.button { appearance: none; border: 0; border-radius: 999px; padding: 14px 22px; font-weight: 800; text-decoration: none; cursor: pointer; display: inline-flex; justify-content: center; align-items: center; transition: transform .2s ease, opacity .2s ease; }
.button:hover { transform: translateY(-1px); }
.button:disabled { cursor: not-allowed; opacity: .7; }
.button--primary { background: var(--gold); color: var(--green-950); }
.button--secondary { background: rgba(255,255,255,.12); color: var(--white); border: 1px solid rgba(255,255,255,.25); }
.button--full { width: 100%; }
.trust-row { display: flex; gap: 10px; flex-wrap: wrap; }
.trust-row span { border: 1px solid rgba(255,255,255,.2); border-radius: 999px; padding: 8px 13px; font-size: .84rem; color: rgba(255,255,255,.82); backdrop-filter: blur(8px); }

.quick-card,
.application-form {
  background: rgba(255,255,255,.94);
  color: var(--text);
  border: 1px solid rgba(199,167,106,.45);
  box-shadow: var(--shadow);
}
.quick-card { border-radius: 30px; padding: 28px; backdrop-filter: blur(18px); }
.quick-card__label { margin: 0 0 18px; color: var(--green-900); font-weight: 900; font-size: 1.1rem; }
.microcopy { margin: 12px 0 0; color: #6b655b; font-size: .86rem; text-align: center; }

label { display: grid; gap: 8px; font-weight: 800; font-size: .88rem; color: var(--green-950); }
input, select, textarea {
  width: 100%;
  border: 1px solid #ded6c8;
  border-radius: 14px;
  padding: 13px 14px;
  font: inherit;
  color: var(--text);
  background: #fffdf8;
}
input:focus, select:focus, textarea:focus { outline: 2px solid rgba(199,167,106,.45); border-color: var(--gold-dark); }
.quick-card label + label { margin-top: 14px; }
.quick-card button { margin-top: 18px; }

.section { width: min(1180px, calc(100% - 40px)); margin: 0 auto; padding: 92px 0; }
.section__heading { max-width: 850px; margin-bottom: 38px; }
.section__heading p:not(.eyebrow), .split p, .club-strip p { color: #4d574f; font-size: 1.05rem; }
.pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.pillars article { background: white; border: 1px solid #eee4d4; border-radius: 26px; padding: 26px; box-shadow: 0 14px 40px rgba(8,35,27,.08); }
.icon { color: var(--gold-dark); font-weight: 900; letter-spacing: .16em; }
.pillars h3 { margin: 18px 0 10px; }
.pillars p { color: #596158; margin: 0; }

.section--cream { width: 100%; padding-left: max(20px, calc((100% - 1180px)/2)); padding-right: max(20px, calc((100% - 1180px)/2)); background: var(--cream); }
.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 50px; align-items: start; }
.benefit-list { display: grid; gap: 14px; }
.benefit-list div { background: rgba(255,255,255,.76); border: 1px solid #e5d6bd; border-radius: 20px; padding: 18px; display: grid; gap: 4px; }
.benefit-list strong { color: var(--green-950); }
.benefit-list span { color: #596158; }

.application-form { border-radius: 32px; padding: 34px; }
fieldset { border: 0; padding: 0; margin: 0 0 30px; }
legend { font-family: Cinzel, Georgia, serif; font-weight: 700; color: var(--green-950); font-size: 1.35rem; margin-bottom: 16px; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.checkbox-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.checkbox-grid label, .consent { display: flex; align-items: flex-start; gap: 10px; background: #fffdf8; border: 1px solid #e6ddcf; border-radius: 16px; padding: 14px; font-weight: 700; }
.checkbox-grid input, .consent input { width: auto; margin-top: 4px; }
.textarea-label { margin-bottom: 20px; }
.consent { margin: 18px 0; }
.form-status { min-height: 24px; margin: 14px 0 0; font-weight: 800; text-align: center; }
.form-status.success { color: #17623f; }
.form-status.error { color: #9f2d20; }
.hidden { position: absolute; left: -10000px; opacity: 0; height: 0; width: 0; }

.club-strip { background: var(--green-900); color: white; border-radius: 34px; padding: 40px; display: flex; justify-content: space-between; gap: 30px; align-items: center; margin-bottom: 90px; }
.club-strip h2 { color: white; font-size: clamp(1.8rem, 3vw, 3rem); }
.club-strip p { color: rgba(255,255,255,.78); max-width: 700px; }

footer { background: var(--green-950); color: rgba(255,255,255,.78); display: grid; place-items: center; text-align: center; padding: 48px 20px; }
footer img { width: 70px; margin-bottom: 16px; }
footer p { margin: 4px 0; }
.small { font-size: .82rem; color: rgba(255,255,255,.55); }

.thanks-page { min-height: 100vh; display: grid; place-items: center; padding: 30px; background: radial-gradient(circle at 20% 20%, rgba(199,167,106,.24), transparent 30%), var(--green-950); }
.thanks-card { width: min(720px, 100%); background: var(--cream-2); border-radius: 34px; padding: clamp(32px, 6vw, 64px); text-align: center; box-shadow: var(--shadow); }
.thanks-card img { width: 360px; margin: 0 auto 26px; }
.thanks-card h1 { color: var(--green-950); font-size: clamp(2.3rem, 5vw, 4.5rem); }
.thanks-card p:not(.eyebrow) { color: #4d574f; margin: 20px auto 30px; max-width: 540px; }

@media (max-width: 920px) {
  .hero__inner, .split { grid-template-columns: 1fr; }
  .hero__inner { padding-top: 22px; }
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .checkbox-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .nav { width: min(100% - 28px, 1180px); }
  .nav__brand span { display: none; }
  .hero__inner, .section { width: min(100% - 28px, 1180px); }
  h1 { font-size: 3.1rem; }
  .hero__actions { display: grid; }
  .pillars, .form-grid, .checkbox-grid { grid-template-columns: 1fr; }
  .application-form, .quick-card { padding: 22px; border-radius: 24px; }
  .club-strip { flex-direction: column; align-items: flex-start; border-radius: 24px; padding: 26px; }
}
