*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  margin: 0;
  background: #F7F5F0;
  font-family: 'Source Sans 3', sans-serif;
  color: #1A1A2E;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.site { width: 100%; margin: 0; background: #F7F5F0; }

.topnav {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(6, 14, 34, 0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(212,175,90,0.18);
  padding: 10px 56px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.nav-brand { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; color: rgba(247,245,240,0.85); white-space: nowrap; }
.nav-links { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.nav-link {
  text-decoration: none; color: #D4AF5A;
  border: 1px solid rgba(212,175,90,0.35);
  background: rgba(212,175,90,0.08);
  font-size: 9px; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 600;
  padding: 6px 10px; border-radius: 2px;
  transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.nav-link:hover { transform: translateY(-1px); background: rgba(212,175,90,0.18); border-color: rgba(212,175,90,0.55); }

.hero { background: #0D1B3E; color: #F7F5F0; padding: 56px 56px 48px; position: relative; overflow: hidden; }
.hero-ring { position: absolute; border-radius: 50%; border: 1px solid rgba(212,175,90,0.15); }
.ring1 { width: 300px; height: 300px; top: -80px; right: -80px; }
.ring2 { width: 170px; height: 170px; top: -30px; right: -30px; border-color: rgba(212,175,90,0.10); }
.eyebrow { font-size: 10px; font-weight: 600; letter-spacing: 3.5px; text-transform: uppercase; color: #D4AF5A; margin-bottom: 14px; }
.hero-subtitle {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.85rem, 4.8vw, 2.65rem);
  font-weight: 600;
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: #F7F5F0;
  margin-bottom: 26px;
  max-width: 820px;
}
.gold-bar { width: 44px; height: 2px; background: #D4AF5A; margin-bottom: 22px; }
.hero-tagline { font-size: 14px; font-weight: 400; line-height: 1.85; color: #C8C8D8; max-width: 760px; }
.badge-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 28px; }
.badge { border: 1px solid rgba(212,175,90,0.45); color: #D4AF5A; font-size: 9px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; padding: 6px 12px; border-radius: 2px; }

.sec { padding: 44px 56px; }
.sec-alt { background: #EFECE4; }
.sec-dark { background: #0D1B3E; color: #F7F5F0; }
.sec-label { font-size: 9px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: #D4AF5A; margin-bottom: 8px; }
.sec-heading { font-family: 'Playfair Display', Georgia, serif; font-size: 24px; font-weight: 600; color: #0D1B3E; margin-bottom: 22px; line-height: 1.25; }
.sec-dark .sec-heading { color: #F7F5F0; }
.hr-gold { border: none; border-top: 1px solid rgba(212,175,90,0.2); }

.about-body { font-size: 13.5px; line-height: 1.95; color: #4A4A5A; max-width: 760px; }
.about-body p + p { margin-top: 16px; }
.about-after-team { margin-top: 22px; }

.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 28px; }
.team-card { background: #fff; border-top: 3px solid #D4AF5A; padding: 22px; border-radius: 0 0 4px 4px; }
.team-role { font-size: 9px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: #D4AF5A; margin-bottom: 8px; }
.team-name { font-family: 'Playfair Display', Georgia, serif; font-size: 19px; font-weight: 600; color: #0D1B3E; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid #E5E2D8; }
.team-bio { font-size: 12.5px; line-height: 1.8; color: #4A4A5A; }

.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 13px; }
.scard { background: #fff; border-left: 3px solid #D4AF5A; padding: 18px 17px; border-radius: 0 3px 3px 0; }
.scard-num { font-size: 9px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: #D4AF5A; margin-bottom: 7px; }
.scard-title { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; font-weight: 600; color: #0D1B3E; margin-bottom: 7px; }
.scard-desc { font-size: 12px; line-height: 1.65; color: #4A4A5A; }

.cap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cap-card { border: 1px solid rgba(212,175,90,0.25); border-radius: 5px; padding: 22px 20px; }
.cap-top { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 12px; }
.cap-num { font-family: 'Playfair Display', Georgia, serif; font-size: 26px; font-weight: 700; color: #D4AF5A; line-height: 1; min-width: 80px; }
.cap-title { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; font-weight: 600; color: #F7F5F0; line-height: 1.35; }
.cap-rule { width: 28px; height: 1px; background: rgba(212,175,90,0.35); margin-bottom: 10px; }
.cap-desc { font-size: 12.5px; line-height: 1.75; color: #C8C8D8; }

.engage-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 13px; }
.ecard { background: #fff; padding: 20px 18px; border-radius: 3px; border-top: 3px solid #D4AF5A; }
.ecard-title { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; font-weight: 600; color: #0D1B3E; margin-bottom: 5px; }
.ecard-tag { display: inline-block; font-size: 8.5px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: #8B6914; background: rgba(212,175,90,0.13); padding: 3px 9px; border-radius: 2px; margin-bottom: 11px; }
.ecard-desc { font-size: 12px; line-height: 1.65; color: #4A4A5A; }

.del-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 11px; }
.del-item { display: flex; gap: 9px; align-items: flex-start; }
.del-dot { width: 16px; height: 16px; margin-top: 1px; border: 1.5px solid #D4AF5A; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 9px; color: #D4AF5A; }
.del-text { font-size: 12.5px; color: #4A4A5A; line-height: 1.5; }

.cta { background: #0D1B3E; padding: 40px 56px; }
.cta-heading { font-family: 'Playfair Display', Georgia, serif; font-size: 22px; font-weight: 600; color: #fff; margin-bottom: 6px; }
.cta-sub { font-size: 13px; color: #A0A0B8; margin-bottom: 28px; }
.cta-team { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.cta-person-name { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; font-weight: 600; color: #D4AF5A; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid rgba(212,175,90,0.2); }
.cta-contacts { display: flex; flex-direction: column; gap: 7px; }
.cta-row { display: flex; align-items: center; gap: 10px; }
.cta-lbl { font-size: 8px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; color: #D4AF5A; min-width: 52px; }
.cta-val { font-size: 12px; color: #F7F5F0; text-decoration: none; }

.footer { background: #060E22; padding: 13px 56px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.footer-name { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; color: rgba(247,245,240,0.4); }
.footer-tag { font-size: 8.5px; letter-spacing: 2px; text-transform: uppercase; color: rgba(212,175,90,0.45); }

.hero, .sec, .cta { scroll-margin-top: 88px; }
.badge, .team-card, .scard, .cap-card, .ecard, .del-item {
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}
.team-card:hover, .scard:hover, .cap-card:hover, .ecard:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(13, 27, 62, 0.12); }
.badge:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(13, 27, 62, 0.16); }
.del-item:hover { transform: translateX(2px); }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.75s ease, transform 0.75s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }

@media (max-width: 980px) {
  .topnav { padding-left: 24px; padding-right: 24px; }
  .services-grid, .engage-grid, .del-grid { grid-template-columns: repeat(2, 1fr); }
  .team-grid, .cap-grid, .cta-team { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .topnav, .hero, .sec, .cta, .footer { padding-left: 22px; padding-right: 22px; }
  .topnav { align-items: flex-start; flex-direction: column; }
  .nav-links { width: 100%; justify-content: flex-start; }
  .hero-subtitle { font-size: clamp(1.45rem, 7vw, 1.8rem); }
  .about-body { font-size: 13px; }
  .services-grid, .engage-grid, .del-grid { grid-template-columns: 1fr; }
  .footer { flex-direction: column; align-items: flex-start; }
}
