/* ============================================================
   TUEPAC — Hub modules: mega-menu, Index Intelligence,
   People Index, Editorial/Positions, Opportunities, Events, Media
   ============================================================ */

/* ---------- MEGA NAV ---------- */
.mega{ position:sticky; top:0; z-index:80; background:rgba(255,255,255,0.96); backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--hairline); }
.mega__bar{ display:flex; align-items:center; gap:22px; height:70px; }
.mega__items{ display:flex; align-items:center; gap:2px; margin-left:8px; }
.mega__item{ }
.mega__btn{ font-family:var(--sans); font-size:var(--fs-small); font-weight:600; color:var(--ink); background:transparent; border:0; cursor:pointer;
  padding:10px 14px; border-radius:var(--r); display:inline-flex; align-items:center; gap:7px; white-space:nowrap; }
.mega__btn:hover, .mega__item.open .mega__btn{ color:var(--blue); background:var(--off); }
.mega__btn .tag{ font-family:var(--sans); font-size:0.56rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:#fff; background:var(--red); padding:2px 6px; border-radius:var(--r-pill); }
.mega__right{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.mega__search{ width:34px; height:34px; border-radius:50%; border:1.5px solid var(--mist); background:#fff; color:var(--blue); display:flex; align-items:center; justify-content:center; cursor:pointer; }
.mega__search:hover{ border-color:var(--blue); }
.mega__signin{ font-size:var(--fs-small); font-weight:600; color:var(--blue); white-space:nowrap; }

.mega__panel{ position:absolute; left:0; right:0; top:100%; background:#fff; border-top:1px solid var(--hairline); border-bottom:1px solid var(--mist);
  box-shadow:var(--shadow-2); opacity:0; visibility:hidden; transform:translateY(-8px); transition:opacity .16s, transform .16s, visibility .16s; }
.mega__item.open .mega__panel{ opacity:1; visibility:visible; transform:translateY(0); }
.mega__panel-inner{ display:grid; grid-template-columns:repeat(3,1fr) 1.1fr; gap:34px; padding:32px clamp(20px,4vw,48px); max-width:var(--container); margin-inline:auto; }
.mega__col h5{ font-family:var(--sans); font-size:var(--fs-overline); font-weight:700; letter-spacing:0.13em; text-transform:uppercase; color:var(--ink-45); margin:0 0 14px; }
.mega__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.mega__col a{ font-size:var(--fs-small); font-weight:600; color:var(--ink); }
.mega__col a:hover{ color:var(--red); }
.mega__feature{ background:var(--blue-deep); border-radius:var(--r-lg); padding:24px; color:#fff; display:flex; flex-direction:column; justify-content:flex-end; min-height:170px; }
.mega__feature .k{ font-family:var(--sans); font-size:var(--fs-overline); font-weight:700; letter-spacing:0.13em; text-transform:uppercase; color:#9BC4FF; }
.mega__feature h4{ font-family:var(--serif); font-size:1.3rem; font-weight:700; color:#fff; line-height:1.2; margin-top:10px; }
.mega__feature .go{ margin-top:14px; font-family:var(--sans); font-size:var(--fs-small); font-weight:700; color:#fff; }
@media (max-width:1080px){ .mega__items{ display:none; } }
@media (max-width:1240px){ .mega .wordmark__full{ display:none; } }
.mega .wordmark{ flex:none; }

/* quick-access apps launcher */
.mega__apps-wrap{ position:relative; }
.mega__apps{ display:inline-flex; align-items:center; gap:8px; font-family:var(--sans); font-size:var(--fs-small); font-weight:700; color:var(--blue);
  background:rgba(10,49,97,.06); border:1px solid var(--line); border-radius:var(--r-pill); padding:8px 14px; cursor:pointer; white-space:nowrap; }
.mega__apps:hover{ background:rgba(10,49,97,.1); border-color:var(--line-strong); }
.mega__apps svg{ width:15px; height:15px; }
@media (max-width:560px){ .mega__apps span{ display:none; } }
.mega__apps-panel{ position:absolute; right:0; top:calc(100% + 12px); width:296px; background:#fff; border:1px solid var(--mist); border-radius:var(--r-lg);
  box-shadow:var(--shadow-3); padding:8px; display:none; z-index:95; }
.mega__apps-panel.open{ display:block; animation:appsIn .14s ease; }
@keyframes appsIn{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
.appcard{ display:flex; gap:12px; align-items:center; padding:11px 12px; border-radius:var(--r); }
.appcard:hover{ background:var(--off); }
.appcard__ic{ width:38px; height:38px; border-radius:10px; flex:none; display:flex; align-items:center; justify-content:center; color:#fff; }
.appcard__ic svg{ width:19px; height:19px; }
.appcard__ic.navy{ background:var(--blue); } .appcard__ic.red{ background:var(--red); }
.appcard__t{ display:flex; flex-direction:column; min-width:0; }
.appcard__t b{ font-family:var(--sans); font-weight:700; font-size:0.95rem; color:var(--blue); }
.appcard__t b em{ font-style:normal; font-size:0.66rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-45); }
.appcard__t i{ font-style:normal; font-size:0.78rem; color:var(--ink-60); margin-top:1px; }
.appcard.donate:hover{ background:rgba(179,25,66,.06); }
.appcard__div{ height:1px; background:var(--line-2); margin:6px 12px; }
@media (max-width:760px){ .mega__panel-inner{ grid-template-columns:1fr 1fr; } .mega__feature{ grid-column:1/-1; min-height:120px; } }

/* mobile drawer */
.mega__burger{ display:none; width:40px; height:40px; border-radius:var(--r); border:1.5px solid var(--mist); background:#fff; color:var(--blue); align-items:center; justify-content:center; cursor:pointer; }
.mega__burger:hover{ border-color:var(--blue); }
@media (max-width:1080px){ .mega__burger{ display:inline-flex; } .mega__signin{ display:none; } }
.mega__drawer{ position:fixed; inset:0; z-index:90; background:rgba(7,30,61,0.4); opacity:0; visibility:hidden; transition:opacity .2s, visibility .2s; }
.mega__drawer.open{ opacity:1; visibility:visible; }
.mega__drawer-inner{ position:absolute; top:0; right:0; bottom:0; width:min(86vw,360px); background:#fff; overflow-y:auto; padding:20px 22px 40px;
  transform:translateX(100%); transition:transform .24s ease; box-shadow:var(--shadow-3); }
.mega__drawer.open .mega__drawer-inner{ transform:none; }
.mega__drawer-sect{ padding:14px 0; border-bottom:1px solid var(--hairline); display:flex; flex-direction:column; }
.mega__drawer-top{ font-family:var(--serif); font-size:1.25rem; font-weight:700; color:var(--blue); margin-bottom:8px; display:flex; align-items:center; gap:9px; }
.mega__drawer-top .tag{ font-family:var(--sans); font-size:0.56rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:#fff; background:var(--red); padding:2px 6px; border-radius:var(--r-pill); }
.mega__drawer-link{ font-size:var(--fs-small); font-weight:600; color:var(--ink-60); padding:7px 0 7px 14px; }
.mega__drawer-link:hover{ color:var(--red); }
.mega__drawer-cta{ margin-top:22px; }
body.mega-drawer-open{ overflow:hidden; }

/* page hero band for hubs */
.hubhead{ background:var(--blue-deep); color:#fff; }
.hubhead__inner{ padding-block:clamp(38px,5vw,64px); }
.hubhead .eyebrow{ color:#9BC4FF; }
.hubhead h1{ font-size:var(--fs-display); color:#fff; line-height:1.06; letter-spacing:-0.02em; margin-top:16px; max-width:18ch; }
.hubhead h1 em{ font-style:italic; color:#9BC4FF; }
.hubhead__lead{ margin-top:18px; color:var(--white-72); font-size:var(--fs-body-lg); max-width:60ch; }
.hubtabs{ display:flex; gap:8px; flex-wrap:wrap; margin-top:26px; }
.hubtabs button, .hubtabs a{ font-family:var(--sans); font-size:0.86rem; font-weight:600; color:#fff; background:var(--white-08); border:1px solid var(--white-16); border-radius:var(--r-pill); padding:8px 16px; cursor:pointer; white-space:nowrap; }
.hubtabs button.is-active, .hubtabs a.is-active{ background:#fff; color:var(--blue-deep); border-color:#fff; }

/* ============================================================
   INDEX INTELLIGENCE
   ============================================================ */
.intel-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:28px; align-items:start; }
@media (max-width:960px){ .intel-grid{ grid-template-columns:1fr; } }

/* NC coverage map (schematic) */
.ncmap{ border:1px solid var(--mist); border-radius:var(--r-lg); background:var(--paper); padding:22px; }
.ncmap__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.ncmap__head h3{ font-family:var(--serif); font-size:1.2rem; font-weight:700; color:var(--blue); }
.ncmap__legend{ display:flex; gap:14px; font-size:0.72rem; color:var(--ink-45); }
.ncmap__legend i{ width:10px; height:10px; border-radius:2px; display:inline-block; margin-right:5px; vertical-align:middle; }
.mapwrap{ position:relative; }
.mapdot{ position:absolute; transform:translate(-50%,-50%); border-radius:50%; cursor:pointer; transition:transform .15s; box-shadow:0 0 0 3px rgba(255,255,255,.7); }
.mapdot:hover{ transform:translate(-50%,-50%) scale(1.18); z-index:3; }
.mapdot span{ position:absolute; left:50%; top:-26px; transform:translateX(-50%); font-family:var(--sans); font-size:0.66rem; font-weight:700; color:var(--ink); background:#fff; border:1px solid var(--mist); border-radius:var(--r-sm); padding:2px 7px; white-space:nowrap; opacity:0; pointer-events:none; transition:.15s; }
.mapdot:hover span{ opacity:1; }

/* coverage matrix */
.matrix{ border:1px solid var(--mist); border-radius:var(--r-lg); overflow:hidden; background:#fff; overflow-x:auto; }
.matrix table{ border-collapse:collapse; width:100%; min-width:620px; }
.matrix th, .matrix td{ padding:0; text-align:center; }
.matrix thead th{ font-family:var(--sans); font-size:0.66rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-45); padding:12px 8px; border-bottom:1px solid var(--mist); position:sticky; top:0; background:#fff; }
.matrix tbody th{ text-align:left; font-family:var(--sans); font-size:var(--fs-small); font-weight:600; color:var(--blue); padding:0 14px; white-space:nowrap; border-right:1px solid var(--hairline); }
.matrix .cell{ width:46px; height:42px; margin:3px auto; border-radius:4px; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:0.66rem; font-weight:600; cursor:default; }
.matrix tbody tr{ border-bottom:1px solid var(--line-2); }
.lvl-0{ background:#F4D9DF; color:var(--red-soft); } /* desert */
.lvl-1{ background:#FBEBC9; color:#8a6d1c; }
.lvl-2{ background:#D9E6F2; color:var(--blue-mid); }
.lvl-3{ background:#BFD8C6; color:var(--green-grade); }
.lvl-4{ background:#0A3161; color:#fff; }

/* strength gauges */
.gauge-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:760px){ .gauge-row{ grid-template-columns:1fr 1fr; } }
.gauge{ border:1px solid var(--mist); border-radius:var(--r-lg); padding:20px; background:#fff; text-align:center; }
.gauge__num{ font-family:var(--serif); font-weight:700; font-size:2.2rem; color:var(--blue); line-height:1; }
.gauge__bar{ height:8px; border-radius:4px; background:var(--off); margin:12px 0 8px; overflow:hidden; }
.gauge__bar i{ display:block; height:100%; background:var(--blue); border-radius:4px; }
.gauge__l{ font-family:var(--sans); font-size:var(--fs-overline); font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-45); }

/* deserts / opportunity callouts */
.desert{ display:flex; gap:14px; padding:16px 18px; border:1px solid var(--mist); border-left:3px solid var(--red); border-radius:var(--r); background:var(--paper); align-items:flex-start; }
.desert__icon{ width:30px; height:30px; border-radius:50%; background:rgba(179,25,66,.1); color:var(--red); display:flex; align-items:center; justify-content:center; flex:none; font-weight:800; }
.desert b{ color:var(--blue); }
.desert span{ display:block; color:var(--ink-60); font-size:var(--fs-small); margin-top:3px; }

/* ============================================================
   PEOPLE INDEX
   ============================================================ */
.people-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media (max-width:760px){ .people-grid{ grid-template-columns:1fr; } }
.person{ display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center; border:1px solid var(--mist); border-radius:var(--r-lg); padding:20px 22px; background:#fff; transition:box-shadow .2s; }
.person:hover{ box-shadow:var(--shadow-2); }
.person__rank{ font-family:var(--serif); font-weight:700; font-size:1.8rem; color:var(--mist); width:42px; text-align:center; }
.person__rank.top{ color:var(--red); }
.person__av{ width:56px; height:56px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:700; font-size:1.4rem; color:#fff; background:var(--blue); }
.person__name{ font-family:var(--serif); font-size:1.2rem; font-weight:700; color:var(--blue); line-height:1.15; }
.person__meta{ font-size:0.82rem; color:var(--ink-60); margin-top:3px; }
.person__tags{ display:flex; gap:6px; margin-top:8px; flex-wrap:wrap; }
.person__track{ font-family:var(--sans); font-size:0.72rem; font-weight:700; color:var(--blue); background:#fff; border:1.5px solid var(--mist); border-radius:var(--r-pill); padding:6px 13px; cursor:pointer; white-space:nowrap; }
.person__track:hover{ border-color:var(--blue); }
.person__track.on{ background:var(--blue); color:#fff; border-color:var(--blue); }
.person__net{ font-family:var(--serif); font-weight:700; color:var(--blue); font-size:1.05rem; white-space:nowrap; }

/* ============================================================
   EDITORIAL / POSITIONS (The Desk)
   ============================================================ */
.position{ border:1px solid var(--mist); border-radius:var(--r-lg); overflow:hidden; background:#fff; }
.position__bar{ height:4px; }
.position--editorial .position__bar{ background:var(--blue); }
.position--position .position__bar{ background:var(--red); }
.position--factcheck .position__bar{ background:var(--green-grade); }
.position__body{ padding:26px 28px; }
.position__type{ display:inline-flex; align-items:center; gap:7px; font-family:var(--sans); font-size:var(--fs-overline); font-weight:700; letter-spacing:0.12em; text-transform:uppercase; }
.position--editorial .position__type{ color:var(--blue); }
.position--position .position__type{ color:var(--red); }
.position--factcheck .position__type{ color:var(--green-grade); }
.position h3{ font-family:var(--serif); font-size:1.6rem; font-weight:700; color:var(--blue); line-height:1.16; margin-top:12px; letter-spacing:-0.01em; }
.position__dek{ margin-top:12px; color:var(--ink-60); font-size:var(--fs-body); }
.position__foot{ margin-top:18px; padding-top:16px; border-top:1px solid var(--hairline); display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-size:var(--fs-small); color:var(--ink-45); }
.verdict{ font-family:var(--sans); font-size:0.7rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:4px 10px; border-radius:var(--r-pill); }
.verdict.true{ background:rgba(31,122,77,.12); color:var(--green-grade); }
.verdict.false{ background:rgba(179,25,66,.1); color:var(--red); }
.verdict.mixed{ background:rgba(10,49,97,.08); color:var(--blue); }

/* ============================================================
   OPPORTUNITIES
   ============================================================ */
.opp{ display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center; border:1px solid var(--mist); border-radius:var(--r-lg); padding:20px 22px; background:#fff; transition:box-shadow .2s; }
.opp:hover{ box-shadow:var(--shadow-2); }
.opp__logo{ width:52px; height:52px; border-radius:11px; flex:none; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:700; font-size:1.3rem; color:#fff; background:var(--blue); }
.opp__title{ font-family:var(--serif); font-size:1.18rem; font-weight:700; color:var(--blue); }
.opp__meta{ font-size:0.82rem; color:var(--ink-60); margin-top:3px; display:flex; gap:12px; flex-wrap:wrap; }
.opp__tags{ display:flex; gap:6px; margin-top:8px; flex-wrap:wrap; }
.opp__right{ text-align:right; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }
.opp__amt{ font-family:var(--serif); font-weight:700; color:var(--blue); font-size:1.15rem; }
@media (max-width:680px){ .opp{ grid-template-columns:auto 1fr; } .opp__right{ grid-column:2; align-items:flex-start; text-align:left; } }

/* launch ticker */
.launch-ticker{ background:var(--blue-deep); color:#fff; overflow:hidden; display:flex; align-items:center; height:46px; }
.launch-ticker .pin{ flex:none; display:flex; align-items:center; gap:8px; padding:0 16px; height:100%; background:var(--red); font-family:var(--sans); font-size:0.66rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; }
.launch-ticker .strip{ display:flex; gap:40px; white-space:nowrap; padding-left:24px; animation:lt 38s linear infinite; }
.launch-ticker .strip span{ display:inline-flex; align-items:center; gap:8px; font-size:var(--fs-small); color:var(--white-72); }
.launch-ticker .strip b{ color:#fff; }
.launch-ticker .strip i{ color:#9BC4FF; font-style:normal; }
@keyframes lt{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ============================================================
   EVENTS
   ============================================================ */
.event{ display:grid; grid-template-columns:78px 1fr auto; gap:20px; align-items:center; border:1px solid var(--mist); border-radius:var(--r-lg); padding:18px 22px; background:#fff; transition:box-shadow .2s; }
.event:hover{ box-shadow:var(--shadow-2); }
.event__date{ text-align:center; border-right:1px solid var(--hairline); padding-right:16px; }
.event__mo{ font-family:var(--sans); font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--red); }
.event__day{ font-family:var(--serif); font-weight:700; font-size:1.8rem; color:var(--blue); line-height:1; }
.event__title{ font-family:var(--serif); font-size:1.2rem; font-weight:700; color:var(--blue); line-height:1.2; }
.event__meta{ font-size:0.82rem; color:var(--ink-60); margin-top:4px; display:flex; gap:12px; flex-wrap:wrap; }
@media (max-width:640px){ .event{ grid-template-columns:64px 1fr; } .event > .btn{ grid-column:2; justify-self:start; } }

/* ============================================================
   MEDIA
   ============================================================ */
.media-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:900px){ .media-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .media-grid{ grid-template-columns:1fr; } }
.media-card{ border:1px solid var(--mist); border-radius:var(--r-lg); overflow:hidden; background:#fff; display:flex; flex-direction:column; transition:box-shadow .2s, transform .2s; }
.media-card:hover{ box-shadow:var(--shadow-2); transform:translateY(-2px); }
.media-card__frame{ aspect-ratio:16/9; background:#000; position:relative; }
.media-card__frame iframe{ width:100%; height:100%; border:0; display:block; }
.media-card__play{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.media-card__body{ padding:18px 20px 22px; display:flex; flex-direction:column; gap:8px; flex:1; }
.media-card__type{ font-family:var(--sans); font-size:var(--fs-overline); font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--red); display:flex; align-items:center; gap:8px; }
.media-card h3{ font-family:var(--serif); font-size:1.15rem; font-weight:700; color:var(--blue); line-height:1.25; }
.media-card__meta{ margin-top:auto; padding-top:10px; font-size:0.8rem; color:var(--ink-45); }
.creator{ display:flex; align-items:center; gap:14px; border:1px solid var(--mist); border-radius:var(--r-lg); padding:18px; background:#fff; }
.creator__av{ width:52px; height:52px; border-radius:50%; flex:none; background:var(--blue); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:700; font-size:1.3rem; }
.creator h4{ font-family:var(--serif); font-size:1.1rem; font-weight:700; color:var(--blue); }
.creator .m{ font-size:0.8rem; color:var(--ink-45); margin-top:2px; }
