/* ============================================================
   VFIntel mega menu  ·  /_ds/megamenu.css
   Shared across every page. Loads after each page's inline
   <style> block so it overrides the base nav rules.
   Branded SVG tiles. No photography. No em dashes.
   ============================================================ */

/* ---- nav row ---- */
.nav-links{gap:6px;}
.nav-item{position:relative;}
.nav-trigger{display:inline-flex;align-items:center;gap:5px;color:var(--graphite);font-size:14.5px;font-weight:500;letter-spacing:-0.01em;background:transparent;border:0;cursor:pointer;font-family:inherit;padding:10px 13px;border-radius:4px;transition:color .2s,background .2s;}
.nav-trigger .caret{width:7px;height:7px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg) translateY(-1px);opacity:.55;transition:transform .25s,opacity .2s;}
.nav-trigger:hover,.nav-item.open .nav-trigger,.nav-trigger.active{color:var(--navy);}
.nav-item.open .nav-trigger{background:rgba(15,27,51,0.04);}
.nav-item.open .nav-trigger .caret{transform:rotate(225deg) translateY(-1px);opacity:.9;}
.nav.on-dark .nav-trigger{color:rgba(255,255,255,0.78);}
.nav.on-dark .nav-trigger:hover,.nav.on-dark .nav-item.open .nav-trigger,.nav.on-dark .nav-trigger.active{color:var(--white);}
.nav.on-dark .nav-item.open .nav-trigger{background:rgba(255,255,255,0.06);}
.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;margin-left:6px;background:var(--navy);color:var(--white)!important;border-radius:3px;font-weight:600;font-size:14.5px;text-decoration:none;border:1px solid var(--navy);letter-spacing:-0.01em;transition:all .2s;}
.nav-cta::after{content:'\2192';transition:transform .2s;}
.nav-cta:hover{background:var(--ink);transform:translateY(-1px);}
.nav-cta:hover::after{transform:translateX(3px);}

/* ---- panel shell (fixed + centered so it never overflows) ---- */
.mega{position:fixed;top:70px;left:0;max-width:94vw;opacity:0;transform:translateY(-8px);pointer-events:none;visibility:hidden;transition:opacity .2s ease,transform .2s ease,visibility .2s;background:var(--white);border:1px solid rgba(15,27,51,0.08);border-radius:12px;box-shadow:0 30px 70px -24px rgba(15,27,51,0.30),0 8px 24px -12px rgba(15,27,51,0.16);overflow:hidden;z-index:999;}
/* invisible bridge so moving from the menu word into the panel never crosses dead space */
.mega::before{content:'';position:absolute;left:0;right:0;top:-26px;height:26px;}
.nav-item.open .mega{opacity:1;transform:translateY(0);pointer-events:auto;visibility:visible;}
.mega-inner{padding:28px;}
.mega-head{font-family:'Inter Tight',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--emerald);margin-bottom:18px;display:flex;align-items:center;gap:10px;}
.mega-head::before{content:'';width:22px;height:1px;background:var(--emerald);}

/* ---- tiles ---- */
.tile-grid{display:grid;gap:6px;}
.mega .tile{display:flex;gap:14px;align-items:flex-start;padding:13px;border-radius:9px;border:1px solid transparent;text-decoration:none;transition:background .18s,border-color .18s,transform .18s;}
.mega .tile:hover{background:var(--paper-warm);border-color:rgba(15,27,51,0.08);transform:translateY(-1px);}
.tile-ico{width:46px;height:46px;flex-shrink:0;border-radius:9px;background:var(--pale-green);display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,107,63,0.12);transition:background .18s;}
.mega .tile:hover .tile-ico{background:#dff7ec;}
.tile-ico svg{width:26px;height:26px;display:block;}
.tile-txt h4{font-size:15px;font-weight:700;color:var(--navy);letter-spacing:-0.02em;margin-bottom:3px;}
.tile-txt p{font-size:12.5px;line-height:1.45;color:var(--slate);}
.tile-num{display:block;font-family:'Inter Tight',sans-serif;font-size:10px;font-weight:600;color:var(--emerald);letter-spacing:0.12em;margin-bottom:2px;}

/* ---- products panel ---- */
.mega-products .mega-inner{display:grid;grid-template-columns:248px 1px 1fr;gap:28px;width:min(860px,94vw);}
.mega-products .tile-grid{grid-template-columns:1fr 1fr;}
.rail-div{background:rgba(15,27,51,0.08);}
.feature{display:flex;flex-direction:column;height:100%;border-radius:10px;background:var(--navy);padding:22px;color:var(--white);text-decoration:none;position:relative;overflow:hidden;}
.feature::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 70% at 80% 20%,rgba(16,185,129,0.18) 0%,transparent 70%);}
.feature-svg{position:relative;z-index:1;margin-bottom:auto;}
.feature-svg svg{width:100%;height:auto;display:block;}
.feature-tag{position:relative;z-index:1;font-family:'Inter Tight',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--mint);margin-bottom:8px;}
.feature h4{position:relative;z-index:1;font-size:20px;color:var(--white);letter-spacing:-0.03em;margin-bottom:8px;line-height:1.1;}
.feature p{position:relative;z-index:1;font-size:13px;line-height:1.5;color:rgba(255,255,255,0.74);margin-bottom:16px;}
.feature-link{position:relative;z-index:1;font-size:12.5px;font-weight:600;color:var(--mint);display:inline-flex;align-items:center;gap:6px;}
.feature-link::after{content:'\2192';transition:transform .2s;}
.feature:hover .feature-link::after{transform:translateX(3px);}

/* ---- audience panels (real estate, financial) ---- */
.mega-aud .mega-inner{width:min(560px,94vw);}
.mega-aud .tile-grid{grid-template-columns:1fr 1fr;}
.aud-foot{margin-top:18px;padding-top:16px;border-top:1px solid rgba(15,27,51,0.08);display:flex;align-items:center;justify-content:space-between;gap:16px;}
.aud-foot .who{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:0.08em;color:var(--fog);}
.aud-foot a{font-size:13px;font-weight:600;color:var(--emerald);text-decoration:none;display:inline-flex;gap:6px;align-items:center;}
.aud-foot a::after{content:'\2192';}

/* ---- company panel ---- */
.mega-co .mega-inner{width:min(460px,94vw);}
.mega-co .tile-grid{grid-template-columns:1fr 1fr;}

/* ---- insights panel ---- */
.mega-ins .mega-inner{width:min(760px,94vw);}
.ins-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.mega .ins-tile{border:1px solid rgba(15,27,51,0.08);border-radius:10px;overflow:hidden;text-decoration:none;display:block;transition:border-color .18s,transform .18s,box-shadow .18s;background:var(--white);}
.mega .ins-tile:hover{border-color:var(--emerald);transform:translateY(-2px);box-shadow:0 16px 30px -18px rgba(15,27,51,0.25);}
.ins-thumb{height:96px;display:block;}
.ins-thumb svg{width:100%;height:100%;display:block;}
.ins-body{padding:14px 16px 16px;}
.ins-body .ic-tag{font-family:'Inter Tight',sans-serif;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--emerald);margin-bottom:8px;}
.ins-body h4{font-size:14.5px;font-weight:700;color:var(--navy);line-height:1.25;letter-spacing:-0.02em;margin-bottom:8px;}
.ins-body .ic-meta{font-family:'Inter Tight',sans-serif;font-size:11px;color:var(--fog);}
.ins-foot{margin-top:18px;display:flex;justify-content:flex-end;}
.ins-foot a{font-size:13px;font-weight:600;color:var(--emerald);text-decoration:none;display:inline-flex;gap:6px;align-items:center;}
.ins-foot a::after{content:'\2192';}

/* ============================================================
   MOBILE  ·  panels collapse into tap-to-open accordions.
   Reuses the existing .nav.nav-open toggle already on each page.
   ============================================================ */
@media(max-width:960px){
  .nav-links{gap:0;}
  .nav-item{border-bottom:1px solid rgba(15,27,51,0.07);}
  .nav.on-dark .nav-item{border-bottom-color:rgba(255,255,255,0.08);}
  .nav-trigger{width:100%;justify-content:space-between;padding:15px 2px;font-size:16px;}
  .nav.on-dark .nav-trigger{color:rgba(255,255,255,0.82);}
  .nav-cta{margin:18px 0 0;justify-content:center;width:100%;}

  /* panel becomes inline accordion */
  .mega{position:static;left:auto;top:auto;transform:none;opacity:1;visibility:hidden;display:none;box-shadow:none;border:0;border-radius:0;background:transparent;}
  .nav-item.open .mega{display:block;visibility:visible;}
  .mega-inner{width:auto!important;display:block!important;padding:2px 0 14px!important;grid-template-columns:1fr!important;gap:0!important;}
  .mega-products .tile-grid,.mega-aud .tile-grid,.mega-co .tile-grid,.ins-row{grid-template-columns:1fr!important;}
  .rail-div{display:none;}
  .feature{margin-bottom:10px;}
  .mega-head{margin-top:4px;}

  /* neutralise the base ".nav-links a:not(.btn)" rule inside panels */
  .mega a{padding:0!important;border-bottom:0!important;font-size:inherit!important;}
  .mega .tile{padding:11px 2px!important;}
  .mega .ins-tile{margin-bottom:10px;}
  .ins-body{padding:12px 14px 14px;}
}
