
:root{
  --navy:#0f2747;
  --navy-2:#14345f;
  --navy-3:#1b457a;
  --gold:#d7a941;
  --gold-2:#e7c060;
  --text:#1a2433;
  --muted:#60708a;
  --line:#dfe5ee;
  --white:#ffffff;
  --soft:#f4f6fa;
  --shadow:0 18px 45px rgba(8, 23, 46, 0.12);
  --radius:22px;
  --radius-sm:16px;
  --max:1180px;
}

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

.container{
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter:blur(14px);
  background:rgba(10, 28, 52, 0.82);
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  min-height:84px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:#fff;
  font-weight:700;
  letter-spacing:.2px;
}
.brand img{width:34px;height:34px}

.site-nav{
  display:flex;
  align-items:center;
  gap:28px;
  color:rgba(255,255,255,0.86);
  font-weight:500;
}

.site-nav a:hover,
.footer-nav a:hover{color:var(--gold-2)}

.nav-toggle{
  display:none;
  border:0;
  background:transparent;
  color:#fff;
  font-size:1.65rem;
  cursor:pointer;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 24px;
  border-radius:14px;
  font-weight:700;
  transition:.25s ease;
  box-shadow:var(--shadow);
}
.btn:hover{transform:translateY(-1px)}
.btn-gold{
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  color:#17263f;
}
.btn-dark{
  background:#17365f;
  color:#fff;
}
.nav-cta{min-height:46px}

.hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, #17355f 0%, #102a4a 100%);
  color:#fff;
}
.hero-bg,
.community-bg{
  position:absolute;
  inset:0;
  background-image:url("../images/hero-mountains.png");
  background-size:cover;
  background-position:center bottom;
  opacity:.5;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 72% 28%, rgba(255,255,255,.22), transparent 22%),
    linear-gradient(90deg, rgba(9,24,48,.92) 0%, rgba(14,34,62,.76) 45%, rgba(14,34,62,.38) 100%);
}
.hero-content{
  position:relative;
  z-index:2;
  min-height:760px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:120px 0 180px;
  max-width:720px;
}
.eyebrow,
.kicker{
  margin:0 0 12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.8rem;
  font-weight:800;
  color:rgba(255,255,255,.76);
}
.kicker{color:var(--gold); letter-spacing:.12em}
.kicker-light{color:#f4d58c}
.hero h1,
h2,h3{margin:0}
.hero h1{
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(3rem, 6vw, 5.4rem);
  line-height:.98;
  letter-spacing:-.03em;
}
.hero h1 span{color:var(--gold-2)}
.hero-text{
  margin:24px 0 34px;
  max-width:640px;
  font-size:1.08rem;
  color:rgba(255,255,255,.86);
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}
.hero-wave{
  position:absolute;
  left:-5%;
  right:-5%;
  bottom:-58px;
  height:140px;
  background:#eef1f6;
  border-radius:50% 50% 0 0 / 100% 100% 0 0;
  z-index:1;
}

.section{
  padding:88px 0;
}
.section-light{background:#fff}
.section-soft{background:var(--soft)}
.section-dark{
  background:linear-gradient(180deg, #102d52 0%, #0f2544 100%);
  color:#fff;
}
.section-heading{
  margin-bottom:34px;
}
.section-heading.centered{
  text-align:center;
}
.section-heading h2{
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(2rem, 3vw, 3rem);
  line-height:1.08;
  color:var(--navy);
}
.section-heading.on-dark h2{color:#fff}

.card-grid{
  display:grid;
  gap:24px;
}
.card-grid.three{
  grid-template-columns:repeat(3, 1fr);
}
.info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:30px 26px;
  box-shadow:var(--shadow);
  text-align:center;
}
.info-card img{
  width:72px;
  height:72px;
  margin:0 auto 18px;
}
.info-card h3{
  font-family:"Playfair Display", Georgia, serif;
  font-size:1.55rem;
  color:var(--navy);
  margin-bottom:10px;
}
.info-card p{
  margin:0;
  color:var(--muted);
}
.compact .info-card{padding:28px 22px}

.split{
  display:grid;
  grid-template-columns:1.04fr .96fr;
  gap:42px;
  align-items:center;
}
.split-copy h2{
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(2rem, 3vw, 2.9rem);
  line-height:1.1;
  color:var(--navy);
  margin-bottom:16px;
}
.split-copy p{
  color:#53657d;
  margin:0 0 14px;
  font-size:1.05rem;
}
.split-media img{
  width:100%;
  border-radius:26px;
  box-shadow:var(--shadow);
  border:1px solid rgba(15,39,71,.08);
}

.resource-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.resource-card{
  position:relative;
  min-height:220px;
  border-radius:20px;
  overflow:hidden;
  padding:24px;
  border:1px solid rgba(255,255,255,.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04)),
    linear-gradient(135deg, #2f5e93 0%, #173f6e 45%, #d7a941 180%);
  box-shadow:var(--shadow);
}
.resource-card::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:70px;
  background:
    linear-gradient(to top, rgba(255,255,255,.16), transparent),
    repeating-linear-gradient(90deg, rgba(255,214,122,.55) 0 16px, transparent 16px 28px);
  opacity:.75;
}
.resource-tag{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-size:.82rem;
  font-weight:700;
}
.resource-card h3{
  position:relative;
  z-index:1;
  margin-top:14px;
  max-width:210px;
  color:#fff;
  font-size:1.35rem;
  line-height:1.15;
}
.center-action{
  text-align:center;
  margin-top:28px;
}

.community{
  position:relative;
  overflow:hidden;
  color:#fff;
  background:linear-gradient(180deg, #1a375f 0%, #102746 100%);
}
.community-bg{
  opacity:.42;
  background-position:center center;
}
.community-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(11,28,52,.86) 0%, rgba(11,28,52,.6) 45%, rgba(11,28,52,.8) 100%);
}
.community-inner{
  position:relative;
  z-index:1;
  text-align:center;
  padding:30px 0;
}
.community h2{
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(2rem, 4vw, 3.2rem);
  line-height:1.08;
  margin-bottom:14px;
}
.community p{
  max-width:760px;
  margin:0 auto 24px;
  color:rgba(255,255,255,.84);
}

.disclaimer .narrow{
  max-width:860px;
  text-align:center;
}
.disclaimer p{
  margin:0;
  color:#5a6b84;
  font-size:1.02rem;
}

.site-footer{
  background:#0d223f;
  color:rgba(255,255,255,.82);
  padding:26px 0;
}
.footer-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.footer-wrap p{
  margin:0;
}
.footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
}

@media (max-width: 1040px){
  .resource-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid.three{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
}

@media (max-width: 820px){
  .nav-toggle{display:block}
  .site-nav{
    display:none;
    position:absolute;
    top:84px;
    left:20px;
    right:20px;
    flex-direction:column;
    align-items:flex-start;
    gap:16px;
    padding:20px;
    border-radius:18px;
    background:#102a4a;
    box-shadow:var(--shadow);
  }
  .site-nav.open{display:flex}
  .nav-cta{display:none}
  .hero-content{
    min-height:690px;
    padding:90px 0 150px;
  }
}

@media (max-width: 640px){
  .container{width:min(var(--max), calc(100% - 24px))}
  .section{padding:72px 0}
  .resource-grid{grid-template-columns:1fr}
  .footer-wrap{
    flex-direction:column;
    align-items:flex-start;
  }
  .btn{width:100%}
  .hero-actions{width:100%}
}
