@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

:root {
  --navy:      #0C2340;
  --navy-80:   rgba(12,35,64,0.80);
  --navy-mid:  #183658;
  --navy-lt:   #264D75;
  --gold:      #C9A84C;
  --gold-lt:   #E0C06A;
  --gold-pale: #F5ECD6;
  --sand:      #F7F3ED;
  --sand-dk:   #EDE6DA;
  --white:     #FFFFFF;
  --ink:       #0C1A28;
  --body:      #3D4F60;
  --muted:     #7A8C9A;
  --rule:      rgba(12,35,64,0.10);
  --rule-lt:   rgba(12,35,64,0.06);

  --ff-d: 'Playfair Display', Georgia, serif;
  --ff-s: 'DM Sans', system-ui, sans-serif;

  --r:    4px;
  --r-md: 8px;
  --r-lg: 16px;
  --r-xl: 24px;
  --max:  1280px;
  --pad:  72px;
  --sec:  110px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--ff-s);color:var(--ink);background:var(--white);overflow-x:hidden;line-height:1}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
svg{display:block;flex-shrink:0}

/* ── TYPOGRAPHY ── */
.disp  {font-family:var(--ff-d);font-weight:400;line-height:1.02}
.h1    {font-family:var(--ff-d);font-size:clamp(52px,7.5vw,96px);font-weight:400;line-height:.97;letter-spacing:-.02em}
.h2    {font-family:var(--ff-d);font-size:clamp(34px,4vw,54px);font-weight:400;line-height:1.08;letter-spacing:-.01em}
.h3    {font-family:var(--ff-d);font-size:clamp(22px,2.5vw,32px);font-weight:400;line-height:1.15}
.h4    {font-family:var(--ff-d);font-size:22px;font-weight:400;line-height:1.2}
.em    {font-style:italic;color:var(--gold-lt)}
.em-nv {font-style:italic;color:var(--navy)}
.white {color:var(--white)!important}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-s);font-size:10px;font-weight:500;
  letter-spacing:3.5px;text-transform:uppercase;color:var(--gold);
}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor;flex-shrink:0}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:'';width:24px;height:1px;background:currentColor;flex-shrink:0}
.eyebrow.white{color:var(--gold-lt)}
.eyebrow.white::before,.eyebrow.white::after{background:var(--gold-lt)}

.lead{font-size:16px;font-weight:300;color:var(--body);line-height:1.78;max-width:580px}
.lead.center{text-align:center;margin:0 auto}
.body-sm{font-size:13px;color:var(--body);line-height:1.72}

/* ── LAYOUT ── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.sec{padding:var(--sec) var(--pad);max-width:var(--max);margin:0 auto}
.sec-full{padding:var(--sec) var(--pad)}
.bg-sand  {background:var(--sand)}
.bg-white {background:var(--white)}
.bg-navy  {background:var(--navy)}
.bg-sand-dk{background:var(--sand-dk)}

/* ── SECTION HEADER ── */
.sh{margin-bottom:56px}
.sh .eyebrow{margin-bottom:16px}
.sh .h2{margin-bottom:16px}
.sh.center{text-align:center}
.sh.center .eyebrow{justify-content:center}
.sh.center .eyebrow::after{content:'';width:24px;height:1px;background:currentColor}
.sh.center .lead{margin:0 auto}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:13px 30px;
  font-family:var(--ff-s);font-size:11px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;border-radius:var(--r);border:none;cursor:pointer;
  transition:all .22s ease;white-space:nowrap;
}
.btn svg{width:14px;height:14px;stroke-width:2}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:#b8922a;transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,168,76,.35)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-1px)}
.btn-ol{background:transparent;color:var(--navy);border:1.5px solid var(--navy);padding:12px 30px}
.btn-ol:hover{background:var(--navy);color:var(--white)}
.btn-ol-w{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.45);padding:12px 30px}
.btn-ol-w:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.btn-ghost{background:none;border:none;padding:0;color:var(--gold);font-family:var(--ff-s);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.btn-ghost svg{width:14px;height:14px;stroke-width:1.5;transition:transform .2s}
.btn-ghost:hover svg{transform:translateX(3px)}

/* ── NAV ── */
.nav{
  position:sticky;top:0;z-index:200;height:72px;
  background:rgba(12,35,64,.97);backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,168,76,.15);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
  height:100%;display:flex;align-items:center;justify-content:space-between;
}
.nav-logo img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{
  font-size:11px;font-weight:400;letter-spacing:1.8px;text-transform:uppercase;
  color:rgba(255,255,255,.62);transition:color .18s;
}
.nav-links a:hover,.nav-links a.active{color:var(--gold-lt)}
.nav-cta{
  background:var(--gold);color:var(--white);padding:9px 22px;
  border-radius:var(--r);font-family:var(--ff-s);font-size:10px;
  font-weight:500;letter-spacing:2px;text-transform:uppercase;
  border:none;cursor:pointer;transition:background .18s;
}
.nav-cta:hover{background:#b8922a}

/* ── PAGE HERO ── */
.page-hero{
  background:var(--navy);padding:86px var(--pad) 74px;
  position:relative;overflow:hidden;
}
.page-hero-bg{
  position:absolute;inset:0;
  background:url('') center/cover no-repeat;opacity:.18;
}
.page-hero-inner{
  max-width:var(--max);margin:0 auto;position:relative;z-index:1;
}
.page-hero .eyebrow{margin-bottom:20px}
.page-hero h1{
  font-family:var(--ff-d);font-size:clamp(42px,5.5vw,64px);
  font-weight:400;color:var(--white);line-height:1.06;margin-bottom:18px;letter-spacing:-.015em;
}
.page-hero h1 em{font-style:italic;color:var(--gold-lt)}
.page-hero p{font-size:15px;font-weight:300;color:rgba(255,255,255,.6);max-width:560px;line-height:1.75}

/* ── CARD BASE ── */
.card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--rule);overflow:hidden}
.card:hover{box-shadow:0 20px 56px rgba(12,35,64,.1)}
.card-img{overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-img img{transform:scale(1.04)}

/* ── FOOTER ── */
.footer{background:#060E1A;padding:80px var(--pad) 32px}
.footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07);
}
.f-logo{font-family:var(--ff-d);font-size:26px;font-weight:400;color:rgba(255,255,255,.9);margin-bottom:6px}
.f-logo em{font-style:italic;color:var(--gold-lt)}
.f-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.f-desc{font-size:13px;color:rgba(255,255,255,.36);line-height:1.75;max-width:275px}
.f-col h5{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:18px}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.f-col ul li a{font-size:13px;color:rgba(255,255,255,.4);transition:color .18s}
.f-col ul li a:hover{color:var(--gold-lt)}
.f-bottom{
  max-width:var(--max);margin:26px auto 0;
  display:flex;justify-content:space-between;align-items:center;
}
.f-copy{font-size:11px;color:rgba(255,255,255,.22)}
.f-soc{display:flex;gap:10px}
.f-soc a{
  width:32px;height:32px;border-radius:50%;
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.38);transition:all .18s;
}
.f-soc a:hover{border-color:var(--gold);color:var(--gold)}
.f-soc a svg{width:14px;height:14px}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .72s ease,transform .72s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.18s}.d3{transition-delay:.26s}.d4{transition-delay:.34s}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
