/* Velocity Merchant Energy v2 — light institutional (e360-class vibe, our own voice)
   White ground · navy ink · amber energy. Sora display / Inter text. */

:root {
  --navy: #0F2740;
  --navy-2: #16304e;
  --ink: #1d2b3a;          /* headings on white */
  --body: #5a6678;         /* body grey */
  --line: #e4e9f0;
  --tint: #f5f8fb;         /* section tint */
  --amber: #DB7B33;   /* logo orange (sampled from VME mark) */
  --amber-d: #C06525;
  --white: #ffffff;
  --max: 1180px;
  --disp: "Sora", -apple-system, sans-serif;
  --sans: "Inter", -apple-system, system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; }
html { scroll-behavior: smooth; }
body { background: var(--white); color: var(--body); font: 16px/1.7 var(--sans); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
::selection { background: var(--amber); color: var(--navy); }
a { color: inherit; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 28px; }
.center { text-align: center; margin-left: auto; margin-right: auto; }

/* ── nav ── */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 50; display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px; transition: all .3s; }
.nav.scrolled { background: rgba(255,255,255,.92); backdrop-filter: blur(12px); padding: 10px 32px; box-shadow: 0 1px 0 var(--line), 0 8px 30px rgba(15,39,64,.06); }
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; font-family: var(--disp); font-weight: 600; font-size: 15px; color: #fff; transition: color .3s; }
.nav.scrolled .brand { color: var(--navy); }
.brand em { font-style: normal; font-weight: 400; opacity: .75; }
.brand-mark { width: 30px; height: auto; display: block; filter: drop-shadow(0 1px 2px rgba(0,0,0,.25)); }
.nav-links { display: flex; gap: 26px; align-items: center; font-size: 14px; font-weight: 500; }
.nav-links a { text-decoration: none; color: rgba(255,255,255,.85); transition: color .2s; }
.nav.scrolled .nav-links a { color: var(--body); }
.nav-links a:hover { color: var(--amber); }
.nav.scrolled .nav-links a:hover { color: var(--navy); }
.nav-cta { background: var(--amber); color: var(--navy) !important; padding: 9px 18px; border-radius: 99px; font-weight: 600; }
.nav-cta:hover { background: #ED934E; }
.nav-burger { display: none; background: none; border: 0; cursor: pointer; padding: 8px; z-index: 60; }
.nav-burger span { display: block; width: 22px; height: 2px; background: #fff; margin: 5px 0; transition: all .25s; }
.nav.scrolled .nav-burger span { background: var(--navy); }

/* ── hero ── */
.hero { position: relative; min-height: 92svh; display: flex; align-items: center; overflow: hidden; background: var(--navy); }
.hero-art { position: absolute; inset: 0; }
.hero-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 62%; }
#emberCanvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(100deg, rgba(7,15,26,.78) 0%, rgba(7,15,26,.45) 48%, rgba(7,15,26,.08) 100%); }
.hero-inner { position: relative; z-index: 2; max-width: var(--max); margin: 0 auto; padding: 140px 28px 90px; width: 100%; }
.hero-kicker { font-size: 13px; letter-spacing: .3em; text-transform: uppercase; color: var(--amber); font-weight: 600; margin-bottom: 20px; }
.hero-title { font-family: var(--disp); font-weight: 600; color: #fff; font-size: clamp(34px, 5.4vw, 62px); line-height: 1.14; letter-spacing: -.015em; max-width: 15.5em; }
.hero-title em { font-style: normal; color: var(--amber); }
.hero-sub { margin-top: 24px; max-width: 540px; font-size: clamp(16px, 1.9vw, 19px); color: rgba(255,255,255,.82); }
.hero-sub strong { color: #fff; }
.hero-actions { margin-top: 36px; display: flex; gap: 14px; flex-wrap: wrap; }
.btn { text-decoration: none; font-weight: 600; font-size: 15px; padding: 14px 28px; border-radius: 99px; border: 0; cursor: pointer; transition: all .15s; }
.btn:active { transform: scale(.97); }
.btn-solid { background: var(--amber); color: var(--navy); }
.btn-solid:hover { background: #ED934E; }
.btn-glass { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.35); backdrop-filter: blur(6px); }
.btn-glass:hover { background: rgba(255,255,255,.22); }

/* ── sections ── */
.section { padding: clamp(80px, 10vw, 130px) 0; }
.section-tint { background: var(--tint); border-block: 1px solid var(--line); }
.eyebrow { font-size: 12px; letter-spacing: .3em; text-transform: uppercase; color: var(--amber-d); font-weight: 700; margin-bottom: 14px; }
.h2 { font-family: var(--disp); font-weight: 600; color: var(--ink); font-size: clamp(28px, 4vw, 44px); line-height: 1.18; letter-spacing: -.01em; max-width: 22em; }
.h2 em { font-style: normal; color: var(--amber-d); }
.h2.onnavy { color: #fff; }
.lede { margin-top: 20px; max-width: 660px; font-size: clamp(16px, 1.9vw, 18.5px); }

/* trio */
.trio { margin-top: 56px; display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 24px; }
.trio-card { background: var(--white); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; box-shadow: 0 1px 2px rgba(15,39,64,.04); transition: all .25s; }
.trio-photo { aspect-ratio: 3 / 2; overflow: hidden; }
.trio-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.trio-card:hover .trio-photo img { transform: scale(1.05); }
.trio-body { padding: 0 28px 32px; }
.trio-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(15,39,64,.10); border-color: #d4ddea; }
.trio-ic { width: 64px; height: 64px; display: grid; place-items: center; background: var(--white); border: 1px solid var(--line); border-radius: 16px; margin: -32px 0 18px; position: relative; box-shadow: 0 8px 24px rgba(15,39,64,.14); }

.trio-ic svg { width: 38px; height: 38px; }
.trio-card h3 { font-family: var(--disp); font-size: 19px; font-weight: 600; color: var(--ink); margin-bottom: 10px; }
.trio-card p { font-size: 15px; }

/* alternating blocks */
.block { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, 5vw, 70px); align-items: center; margin-top: clamp(56px, 7vw, 90px); }
.block.flip .block-art { order: 2; }
.block-art img { width: 100%; height: auto; border-radius: 18px; box-shadow: 0 18px 50px rgba(15,39,64,.16); display: block; }
.block-txt h3 { font-family: var(--disp); font-size: clamp(21px, 2.6vw, 27px); font-weight: 600; color: var(--ink); margin-bottom: 14px; }
.block-txt p { margin-bottom: 12px; max-width: 54ch; }

/* markets */
.mkts { margin-top: 56px; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.mkt { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4 / 5; box-shadow: 0 10px 34px rgba(15,39,64,.16); }
.mkt-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.mkt:hover .mkt-photo { transform: scale(1.06); }
.mkt-ov { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 26px 24px;
  background: linear-gradient(180deg, rgba(10,22,38,0) 30%, rgba(10,22,38,.55) 62%, rgba(10,22,38,.92) 100%); }
.mkt-tag { font-size: 11px; letter-spacing: .26em; text-transform: uppercase; color: var(--amber); font-weight: 700; margin-bottom: 8px; }
.mkt-ov h3 { font-family: var(--disp); font-size: 24px; font-weight: 600; color: #fff; margin-bottom: 8px; }
.mkt-ov p { color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.6; margin: 0; }

/* statement band */
.band { background: var(--navy); padding: clamp(60px, 8vw, 90px) 0; }
.band-txt { font-family: var(--disp); font-weight: 400; color: rgba(255,255,255,.92); font-size: clamp(20px, 3vw, 30px); line-height: 1.45; max-width: 30em; margin: 0 auto; text-align: center; }
.band-txt em { font-style: normal; color: var(--amber); font-weight: 600; }

/* team */
.people { margin-top: 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.card-person { background: var(--white); border: 1px solid var(--line); border-radius: 16px; padding: 34px; box-shadow: 0 1px 2px rgba(15,39,64,.04); }
.cp-head { display: flex; gap: 16px; align-items: center; margin-bottom: 18px; }
.cp-avatar { width: 58px; height: 58px; flex: none; border-radius: 50%; display: grid; place-items: center; font-family: var(--disp); font-weight: 700; color: #fff; background: linear-gradient(135deg, var(--navy), #2c5c8f); letter-spacing: .03em; }
.cp-head h3 { font-family: var(--disp); font-size: 21px; font-weight: 600; color: var(--ink); }
.cp-role { font-size: 12.5px; letter-spacing: .05em; text-transform: uppercase; color: var(--amber-d); font-weight: 600; margin-top: 4px; }
.card-person > p { font-size: 15px; }

/* contact */
.section-navy { background: linear-gradient(180deg, var(--navy), #0a1c30); }
.section-navy .eyebrow { color: var(--amber); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.addr { font-style: normal; margin-top: 26px; color: rgba(255,255,255,.78); line-height: 1.95; }
.addr strong { color: #fff; font-size: 17px; }
.addr a { color: var(--amber); text-decoration: none; }
.addr a:hover { text-decoration: underline; }
.cform { display: flex; flex-direction: column; gap: 18px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); border-radius: 18px; padding: 34px; backdrop-filter: blur(8px); }
.cform label { display: flex; flex-direction: column; gap: 8px; font-size: 13.5px; font-weight: 600; color: #fff; letter-spacing: .02em; }
.cform label span { color: rgba(255,255,255,.55); font-weight: 400; }
.cform input, .cform textarea { background: rgba(10,22,38,.6); border: 1px solid rgba(255,255,255,.18); border-radius: 10px; padding: 13px 14px; color: #fff; font: 15px/1.5 var(--sans); resize: vertical; transition: border-color .15s; }
.cform input::placeholder, .cform textarea::placeholder { color: rgba(255,255,255,.35); }
.cform input:focus, .cform textarea:focus { outline: none; border-color: var(--amber); }

/* footer */
.foot { background: #0a1c30; border-top: 1px solid rgba(255,255,255,.08); padding: 28px 0; }
.foot-row { display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; color: rgba(255,255,255,.55); font-size: 13.5px; }

/* reveal targets (GSAP adds in) — scoped to the home page so member/account pages render instantly */
.home-page .trio-card, .home-page .block, .home-page .mkt, .home-page .card-person, .home-page .h2, .home-page .lede, .home-page .eyebrow, .home-page .band-txt, .home-page .cform, .home-page .addr { opacity: 0; transform: translateY(26px); }
.reduced .trio-card, .reduced .block, .reduced .mkt, .reduced .card-person, .reduced .h2, .reduced .lede, .reduced .eyebrow, .reduced .band-txt, .reduced .cform, .reduced .addr { opacity: 1; transform: none; }

/* ── mobile ── */
@media (max-width: 880px) {
  .nav { padding: 12px 18px; }
  .nav-links { position: fixed; inset: 0; background: rgba(10,22,38,.97); backdrop-filter: blur(10px); flex-direction: column; justify-content: center; gap: 28px; font-size: 20px; transform: translateY(-100%); transition: transform .35s cubic-bezier(.7,0,.3,1); }
  .nav-links.open { transform: translateY(0); }
  /* The open menu is a dark overlay regardless of bar state, so its links are always
     white. `header.nav.solid/.scrolled` out-specifies the grey/body-coloured bar rules
     (.nav.solid .nav-links a etc.) that are defined later in the file. */
  .nav-links a, header.nav.scrolled .nav-links a, header.nav.solid .nav-links a { color: #fff; }
  .nav-burger { display: block; }
  .nav-burger[aria-expanded="true"] span { background: #fff; }
  .nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  /* The frosted blur on the scrolled/solid bar makes .nav the containing block for
     the fixed full-screen menu, collapsing #navLinks into the ~60px bar so its links
     (incl. Investor Login) land on top of the page. Drop the blur on mobile — the bar
     background is already near-opaque — so the menu fills the viewport again. The
     `header` prefix raises specificity above the base `.nav.solid` blur rule below,
     which is later in the file and would otherwise win the tie and re-add the blur. */
  header.nav.scrolled, header.nav.solid { backdrop-filter: none; }
  /* Keep the open burger a white X on the dark overlay even when the bar is scrolled or
     solid (those states otherwise repaint the bars navy, hiding the close button). */
  .nav.scrolled .nav-burger[aria-expanded="true"] span,
  .nav.solid .nav-burger[aria-expanded="true"] span { background: #fff; }
  .block, .block.flip { grid-template-columns: 1fr; }
  .block.flip .block-art { order: 0; }
  .people, .contact-grid { grid-template-columns: 1fr; gap: 24px; }
  .hero-inner { padding-top: 120px; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* ══ Member pages (Structure / Performance / Documents) — confidential area ══ */
.nav.solid { background: rgba(255,255,255,.96); backdrop-filter: blur(12px); box-shadow: 0 1px 0 var(--line), 0 8px 30px rgba(15,39,64,.06); }
.conf-strip { background: #eef1f5; color: #626c7d; text-align: center; font: 600 11px/1 var(--sans);
  letter-spacing: .32em; text-transform: uppercase; padding: 12px 16px 11px; border-bottom: 1px solid var(--line);
  margin-top: 76px; }
.member-head { padding: 64px 0 8px; }
.member-head .kicker { color: var(--amber); font: 600 12px/1 var(--sans); letter-spacing: .24em; text-transform: uppercase; }
.member-head h1 { color: var(--ink); font: 600 clamp(30px,4.2vw,46px)/1.12 var(--disp); margin: 12px 0 14px; }
.member-head .lede { max-width: 880px; font-size: 16.5px; }
.member-sub { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin: 26px 0 0; flex-wrap: wrap; }
.member-sub a { padding: 11px 18px 12px; font: 500 14px/1 var(--sans); color: var(--body); text-decoration: none;
  border-bottom: 2px solid transparent; margin-bottom: -1px; }
.member-sub a.on { color: var(--navy); border-bottom-color: var(--amber); font-weight: 600; }
.member-sub a:hover { color: var(--navy); }
.member-section { padding: 38px 0 10px; }
.member-section h2 { color: var(--ink); font: 600 22px/1.25 var(--disp); margin-bottom: 18px; }
.member-section .note { font-size: 13.5px; color: #76808f; max-width: 980px; line-height: 1.65; }
.kv-table { width: 100%; border-collapse: collapse; margin: 6px 0 8px; }
.kv-table td { padding: 11px 14px; border-bottom: 1px solid var(--line); font-size: 14.5px; vertical-align: top; }
.kv-table td:first-child { color: var(--ink); font-weight: 600; width: 38%; }
.kv-table tr:nth-child(odd) td { background: var(--tint); }
.perf-tabs { display: flex; gap: 8px; margin: 22px 0 14px; }
.perf-tabs button { font: 600 13.5px/1 var(--sans); letter-spacing: .02em; color: var(--body); background: var(--white);
  border: 1px solid var(--line); border-radius: 999px; padding: 10px 22px; cursor: pointer; transition: all .18s; }
.perf-tabs button.on { background: var(--navy); border-color: var(--navy); color: #fff; }
.perf-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--line); border-radius: 10px; }
.perf-table { width: 100%; border-collapse: collapse; min-width: 920px; font-variant-numeric: tabular-nums; }
.perf-table th { background: var(--navy); color: #cfdaeb; font: 600 12px/1 var(--sans); letter-spacing: .06em;
  padding: 11px 8px; text-align: right; }
.perf-table th:first-child { text-align: left; padding-left: 16px; }
.perf-table td { padding: 9px 8px; text-align: right; font-size: 13px; color: var(--ink); border-bottom: 1px solid var(--line); }
.perf-table td:first-child { text-align: left; padding-left: 16px; font-weight: 600; }
.perf-table td.neg { color: #b54034; }
.perf-table td.yr { font-weight: 700; color: var(--navy); background: var(--tint); }
.perf-table tr:hover td { background: #f8fafc; }
.perf-table tr:hover td.yr { background: #eef3f8; }
.doc-group { margin: 0 0 8px; }
.doc-list { list-style: none; padding: 0; margin: 0 0 6px; }
.doc-list li { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border-bottom: 1px solid var(--line); font-size: 14.5px; color: var(--ink); }
.doc-list li:nth-child(odd) { background: var(--tint); }
.doc-ico { color: var(--amber); flex: none; display: flex; }
.doc-req { margin-left: auto; font: 500 12.5px/1 var(--sans); color: var(--body); text-decoration: none; border: 1px solid var(--line);
  border-radius: 999px; padding: 7px 14px; white-space: nowrap; transition: all .18s; }
.doc-req:hover { color: var(--navy); border-color: var(--navy); }
.member-foot-pad { padding-bottom: 70px; }
.conf-strip.foot-strip { margin-top: 0; border-top: 1px solid var(--line); border-bottom: 0;
  letter-spacing: .08em; text-transform: none; font-weight: 500; font-size: 12px; line-height: 1.6; }
@media (max-width: 640px) {
  .conf-strip { letter-spacing: .18em; font-size: 10px; margin-top: 62px; }
  .conf-strip.foot-strip { margin-top: 0; letter-spacing: .06em; }
  .kv-table td:first-child { width: 46%; }
  .member-sub a { padding: 10px 12px 11px; font-size: 13px; }
}

/* ══ V4 additions — auth-aware nav + account pages (Login / Register / Forgot / Change Password / Questions) ══ */
.nav-user { font-weight: 600; opacity: .75; white-space: nowrap; }
.nav-logout-form { display: inline; margin: 0; }
button.nav-cta { border: 0; cursor: pointer; font: inherit; font-size: 14px; font-weight: 600; }

/* account pages */
.account-wrap { max-width: 560px; margin: 0 auto; padding: 150px 28px 90px; min-height: 72svh; }
.account-wrap.wide { max-width: 920px; }
.account-head { margin-bottom: 26px; }
.account-head .kicker { color: var(--amber-d); font: 700 12px/1 var(--sans); letter-spacing: .3em; text-transform: uppercase; }
.account-head h1 { color: var(--ink); font: 600 clamp(28px,3.6vw,40px)/1.15 var(--disp); margin: 12px 0 10px; }
.account-head p { max-width: 60ch; }
.account-card { background: var(--white); border: 1px solid var(--line); border-radius: 18px; padding: 34px; box-shadow: 0 10px 34px rgba(15,39,64,.08); }
.vform { display: flex; flex-direction: column; gap: 18px; }
.vform label { display: flex; flex-direction: column; gap: 8px; font-size: 13.5px; font-weight: 600; color: var(--ink); letter-spacing: .02em; }
.vform label span { color: var(--body); font-weight: 400; }
.vform input, .vform select, .vform textarea { background: var(--white); border: 1px solid #cfd8e3; border-radius: 10px; padding: 12px 14px; color: var(--ink); font: 15px/1.5 var(--sans); resize: vertical; transition: border-color .15s; width: 100%; box-sizing: border-box; }
.vform input:focus, .vform select:focus, .vform textarea:focus { outline: none; border-color: var(--amber); }
.vform .checkbox-row { flex-direction: row; align-items: center; gap: 10px; }
.vform .checkbox-row input { width: auto; }
.account-links { margin-top: 18px; font-size: 14px; display: flex; flex-direction: column; gap: 8px; }
.account-links a { color: var(--amber-d); text-decoration: none; font-weight: 500; }
.account-links a:hover { text-decoration: underline; }
.form-msg { margin-top: 16px; font-size: 14.5px; font-weight: 600; }
.form-msg.error { color: #b54034; }
.form-msg.success { color: #1d7a4f; }

@media (max-width: 880px) {
  .nav-logout-form { display: block; }
  .nav-user { display: block; text-align: center; color: #fff; }
}

/* nav.solid (inner pages, not yet scrolled): give brand/links their ink colors so they are
   readable on the white bar — same palette as .nav.scrolled */
.nav.solid .brand { color: var(--navy); }
.nav.solid .nav-links a { color: var(--body); }
.nav.solid .nav-links a:hover { color: var(--navy); }
.nav.solid .nav-burger span { background: var(--navy); }

/* ══ "Explore" dropdown (logged-in nav) — groups the marketing links so the authenticated
   desktop bar stays short. CSS-only: opens on hover and on keyboard focus (focus-within),
   which also keeps it open after a mouse click. On mobile (≤880px) the wrappers use
   display:contents so the links flatten into the full-screen burger menu as normal items. ══ */
.nav-dropdown { position: relative; display: flex; align-items: center; }
.nav-dropdown-trigger { background: none; border: 0; cursor: pointer; font: inherit; font-weight: 500;
  display: inline-flex; align-items: center; gap: 6px; padding: 0; color: rgba(255,255,255,.85); transition: color .2s; }
.nav.scrolled .nav-dropdown-trigger, .nav.solid .nav-dropdown-trigger { color: var(--body); }
.nav-dropdown-trigger:hover { color: var(--amber); }
.nav.scrolled .nav-dropdown-trigger:hover, .nav.solid .nav-dropdown-trigger:hover { color: var(--navy); }
.nav-caret { font-size: 10px; transition: transform .2s; }
.nav-dropdown:hover .nav-caret, .nav-dropdown:focus-within .nav-caret { transform: rotate(180deg); }

@media (min-width: 881px) {
  .nav-dropdown-menu { position: absolute; top: calc(100% + 14px); left: 50%;
    display: flex; flex-direction: column; gap: 2px; min-width: 190px; padding: 8px;
    background: #fff; border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 16px 40px rgba(15,39,64,.14);
    opacity: 0; visibility: hidden; transform: translateX(-50%) translateY(-6px);
    transition: opacity .18s ease, transform .18s ease; z-index: 60; }
  /* invisible bridge over the gap so the menu doesn't close as the cursor travels to it */
  .nav-dropdown-menu::before { content: ""; position: absolute; left: 0; right: 0; top: -14px; height: 14px; }
  .nav-dropdown:hover .nav-dropdown-menu, .nav-dropdown:focus-within .nav-dropdown-menu {
    opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
  /* panel links stay dark on the white card (override the bar's white/grey link theming) */
  .nav-dropdown-menu a, .nav.scrolled .nav-dropdown-menu a, .nav.solid .nav-dropdown-menu a {
    color: var(--ink); padding: 9px 14px; border-radius: 8px; font-size: 14px; font-weight: 500; white-space: nowrap; }
  .nav-dropdown-menu a:hover, .nav.scrolled .nav-dropdown-menu a:hover, .nav.solid .nav-dropdown-menu a:hover {
    background: var(--tint); color: var(--navy); }
}

@media (max-width: 880px) {
  /* flatten the dropdown into the full-screen menu: the 5 links become direct stacked items */
  .nav-dropdown, .nav-dropdown-menu { display: contents; }
  .nav-dropdown-trigger { display: none; }
}
