/* ---- Navbar ---- */
nav#nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background .35s, box-shadow .35s; }
nav#nav.sc { background: rgba(255,255,255,.96); backdrop-filter: blur(20px) saturate(1.6); box-shadow: 0 1px 0 rgba(13,21,33,.07), var(--ds-shadow-sm); }
.ds-nav-in { display: flex; align-items: center; justify-content: space-between; max-width: 1180px; margin: 0 auto; padding: .95rem 1.75rem; }
.ds-nav-logo { display: flex; align-items: center; gap: .7rem; }
.ds-nav-logo-img { height: 40px; width: auto; transition: filter .3s, opacity .3s; filter: brightness(0) invert(1); opacity: .92; }
nav#nav.sc .ds-nav-logo-img { filter: none; opacity: 1; }
.ds-nav-logo-text { font-family: var(--ds-font-serif); font-size: 1.1rem; font-weight: 600; color: var(--ds-white); letter-spacing: .02em; transition: color .3s; }
nav#nav.sc .ds-nav-logo-text { color: var(--ds-blue-900); }

/* Primary nav list */
.ds-nav-ul { display: flex; gap: .1rem; align-items: center; }
.ds-nav-ul > li > a { font-size: .8rem; font-weight: 500; color: rgba(255,255,255,.82); padding: .45rem .8rem; border-radius: var(--ds-r-sm); transition: color .2s, background .2s; }
nav#nav.sc .ds-nav-ul > li > a { color: var(--ds-ink-70); }
.ds-nav-ul > li > a:hover { color: var(--ds-white); background: rgba(255,255,255,.12); }
nav#nav.sc .ds-nav-ul > li > a:hover { color: var(--ds-blue-700); background: var(--ds-blue-050); }

/* Dropdown */
.ds-nav-dd { position: relative; }
.ds-nav-dd-p { position: absolute; top: calc(100% + .6rem); left: 50%; transform: translateX(-50%) translateY(6px); background: var(--ds-white); border-radius: var(--ds-r-lg); box-shadow: var(--ds-shadow-lg); border: 1px solid var(--ds-blue-100); min-width: 210px; padding: .4rem; opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s var(--ds-ease); }
.ds-nav-dd:hover .ds-nav-dd-p, .ds-nav-dd:focus-within .ds-nav-dd-p { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0); }
.ds-nav-dd-p a { display: block; padding: .55rem .9rem; border-radius: var(--ds-r-sm); color: var(--ds-ink); font-size: .8rem; font-weight: 500; }
.ds-nav-dd-p a:hover { background: var(--ds-blue-050); color: var(--ds-blue-700); }

/* CTA */
.ds-nav-cta { margin-left: .5rem; }

/* Hamburger */
.ds-hbg { display: none; flex-direction: column; gap: 5px; padding: .5rem; }
.ds-hbg span { display: block; width: 22px; height: 1.5px; background: rgba(255,255,255,.85); border-radius: 2px; transition: all .3s; }
nav#nav.sc .ds-hbg span { background: var(--ds-ink); }

/* Footer nav styles */
.ds-footer { background: var(--ds-blue-950); color: rgba(255,255,255,.52); }
.ds-ft-top { padding: 4.5rem 0; }
.ds-ft-g { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3.5rem; }
.ds-ft-brand-name { font-family: var(--ds-font-serif); font-size: 1.15rem; color: var(--ds-white); }
.ds-ft-brand p { font-size: .84rem; line-height: 1.68; margin: 1rem 0 1.5rem; color: rgba(255,255,255,.40); }
.ds-ft-soc { display: flex; gap: .6rem; }
.ds-soc { width: 34px; height: 34px; border-radius: var(--ds-r); border: 1px solid rgba(255,255,255,.11); color: rgba(255,255,255,.48); display: flex; align-items: center; justify-content: center; transition: border-color .2s, color .2s, background .2s; }
.ds-soc:hover { border-color: rgba(255,255,255,.32); color: var(--ds-white); background: rgba(255,255,255,.07); }
.ds-ft-ct { font-family: var(--ds-font-serif); font-size: .95rem; color: var(--ds-white); margin-bottom: 1.1rem; }
.ds-ft-lks { display: flex; flex-direction: column; gap: .55rem; }
.ds-ft-lks a { font-size: .8rem; transition: color .2s; color: rgba(255,255,255,.52); }
.ds-ft-lks a:hover { color: var(--ds-white); }
.ds-ft-cont { margin-top: 1.5rem; }
.ds-ft-cl { font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: .3rem; }
.ds-ft-cont a { display: block; font-size: .84rem; font-weight: 500; color: rgba(255,255,255,.70); margin-bottom: .3rem; }
.ds-ft-cont a:hover { color: var(--ds-white); }
.ds-ft-bot { border-top: 1px solid rgba(255,255,255,.06); padding: 1.5rem 0; }
.ds-ft-bot-in { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.ds-ft-bot p { font-size: .72rem; }
.ds-ft-leg { display: flex; gap: 1.25rem; }
.ds-ft-leg a { font-size: .72rem; transition: color .2s; color: rgba(255,255,255,.52); }
.ds-ft-leg a:hover { color: var(--ds-white); }

/* ── Mega menu ───────────────────────────────────────────── */
.nav-mega-host { position: static; }
.nav-mega-host > a { position: relative; padding-bottom: 1.5rem !important; margin-bottom: -1.5rem; }
.nav-mega {
  position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%) translateY(6px);
  width: min(1180px, calc(100vw - 3.5rem));
  background: var(--ds-white); border-radius: var(--ds-r-xl);
  box-shadow: var(--ds-shadow-lg); border: 1px solid var(--ds-blue-100);
  padding: 1.5rem; margin-top: 0;
  opacity: 0; pointer-events: none;
  transition: opacity .25s, transform .25s var(--ds-ease);
  z-index: 200;
}
.nav-mega::before {
  content: ''; position: absolute; left: 0; right: 0; top: -1.5rem;
  height: 1.5rem; background: transparent; pointer-events: none;
}
.nav-mega-host:hover .nav-mega::before,
.nav-mega-host:focus-within .nav-mega::before { pointer-events: auto; }
.nav-mega-host:hover .nav-mega,
.nav-mega-host:focus-within .nav-mega { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0); }
.nav-mega-grid { display: grid; grid-template-columns: 1.15fr 1fr 1fr; gap: 1.25rem; }
.nav-mega-grid--two { grid-template-columns: 1.2fr 1fr; }

/* Feature panel */
.nm-feat {
  position: relative; border-radius: var(--ds-r-lg); overflow: hidden;
  min-height: 280px; padding: 1.5rem;
  display: flex; flex-direction: column; justify-content: flex-end;
  color: var(--ds-white);
  background: linear-gradient(148deg, #0d2240 0%, #143d70 55%, #0d2240 100%);
}
.nm-feat::before { content: ''; position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; }
.nm-feat::after  { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(155deg, rgba(7,24,48,.42) 0%, rgba(13,42,82,.28) 50%, rgba(7,24,48,.52) 100%); }
.nm-feat > * { position: relative; z-index: 2; }
.nm-feat-glass { padding: 1.1rem 1.25rem; background: rgba(255,255,255,.10); backdrop-filter: blur(14px) saturate(1.3); border: 1px solid rgba(255,255,255,.18); border-radius: var(--ds-r); display: flex; flex-direction: column; align-items: flex-start; }
.nm-feat .kicker { font-size: .65rem; letter-spacing: .16em; color: var(--ds-gold-light); font-weight: 700; text-transform: uppercase; margin-bottom: .5rem; display: inline-block; }
.nm-feat h4 { font-family: var(--ds-font-serif); font-size: 1.45rem; font-weight: 400; color: var(--ds-white); line-height: 1.18; margin: 0 0 .65rem; }
.nm-feat h4 em { color: var(--ds-gold-light); font-style: italic; }
.nm-feat p  { font-size: .82rem; line-height: 1.55; color: rgba(255,255,255,.78); margin: 0 0 1rem; max-width: 320px; }
.nm-feat .btn { align-self: flex-start; padding: .6rem 1.3rem; font-size: .76rem; }
.nm-feat-meta { position: absolute; top: 1.5rem; right: 1.5rem; z-index: 2; display: flex; align-items: center; gap: .4rem; padding: .3rem .65rem; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.25); border-radius: 9999px; font-size: .6rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--ds-gold-light); }
.nm-feat--prices .nm-feat-acts { display: flex; flex-direction: column; gap: .55rem; align-self: flex-start; }
.nm-feat--prices .nm-feat-acts .btn { align-self: flex-start; }
.nm-feat-alt { font-family: var(--ds-font-sans); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.78); border-bottom: 1px solid rgba(255,255,255,.28); padding-bottom: 2px; align-self: flex-start; transition: color .15s, border-color .15s; }
.nm-feat-alt:hover { color: var(--ds-white); border-color: rgba(255,255,255,.7); }

/* Link columns */
.nm-col   { padding: .35rem .25rem; display: flex; flex-direction: column; }
.nm-col-h { font-family: var(--ds-font-serif); font-size: .82rem; font-weight: 600; color: var(--ds-blue-700); letter-spacing: .04em; padding: 0 .8rem .6rem; border-bottom: 1px solid var(--ds-blue-100); margin-bottom: .3rem; }
.nm-col-h em { color: var(--ds-gold); font-style: italic; font-weight: 500; }
.nm-link { display: flex; align-items: center; gap: .65rem; padding: .55rem .8rem; border-radius: var(--ds-r); font-family: var(--ds-font-sans); font-size: .82rem; font-weight: 500; color: var(--ds-ink) !important; transition: background .15s, color .15s, transform .15s var(--ds-ease); }
.nm-link:hover { background: var(--ds-blue-050) !important; color: var(--ds-blue-700) !important; transform: translateX(2px); }
.nm-link .nm-ico { width: 28px; height: 28px; border-radius: var(--ds-r); background: var(--ds-blue-050); color: var(--ds-blue-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .15s, color .15s; }
.nm-link:hover .nm-ico { background: var(--ds-blue-100); color: var(--ds-blue-800); }
.nm-link .nm-tx { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.nm-link .nm-t  { font-size: .82rem; font-weight: 600; color: var(--ds-ink); line-height: 1.25; }
.nm-link .nm-s  { font-size: .68rem; color: var(--ds-ink-50); line-height: 1.4; font-weight: 400; }
.nm-link.featured .nm-ico { background: rgba(200,168,75,.13); color: var(--ds-gold); border: 1px solid rgba(200,168,75,.25); }
.nm-link--summary { margin-bottom: .25rem; background: rgba(200,168,75,.06); border: 1px solid rgba(200,168,75,.18); }
.nm-link--summary .nm-ico { background: rgba(200,168,75,.14); color: var(--ds-gold); border: 1px solid rgba(200,168,75,.28); }
.nm-link--summary .nm-t { color: var(--ds-ink); }
.nm-link--summary:hover { background: rgba(200,168,75,.12) !important; }
.nm-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-items: start; }

@media (max-width: 1024px) {
  .nav-mega { width: calc(100vw - 3rem); padding: 1rem; }
  .nav-mega-grid, .nav-mega-grid--two { grid-template-columns: 1fr; }
  .nm-twocol { grid-template-columns: 1fr; }
  .nm-feat { min-height: 0; padding: 1.25rem; }
}

/* Responsive nav */
@media (max-width: 768px) {
  .ds-nav-ul { display: none; }
  .ds-nav-ul.open { display: flex; flex-direction: column; position: fixed; inset: 0; top: 64px; background: var(--ds-blue-900); padding: 2rem 1.75rem; gap: .4rem; z-index: 99; overflow-y: auto; }
  nav#nav.sc .ds-nav-ul.open { background: var(--ds-white); }
  nav#nav.sc .ds-nav-ul.open > li > a { color: var(--ds-ink-70); }
  .ds-hbg { display: flex; }
  .ds-ft-g { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 480px) {
  .ds-ft-g { grid-template-columns: 1fr; }
}
