/* InvestAwareHub — consolidated component stylesheet
   Paste into Elementor > Site Settings > Custom CSS (Elementor Pro).
   Loads brand fonts + every component class used across the page prototypes.
   With this loaded, build sections as native Containers and apply the
   matching CSS class (e.g. section, wrap, hero, pillar, feature, calc). */

:root{
    --paper:#FFFFFF;
    --ink:#16223A;
    --navy:#111844;
    --brand:#1591DC;
    --cta:#0E6CB6;
    --mist:#F7FAFC;
    --line:#E3E9F2;
    --line-strong:#CDD8E8;
    --muted:#4C566B;
    --brand-tint:#EAF5FC;
    --navy-line:rgba(255,255,255,.14);
    --navy-soft:rgba(255,255,255,.62);

    --display:'Fraunces',Georgia,'Times New Roman',serif;
    --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    --mono:'IBM Plex Mono',ui-monospace,Menlo,Consolas,monospace;

    --wrap:1200px;
    --pad-x:clamp(1.15rem,4vw,2.5rem);
    --sec-y:clamp(4rem,7.5vw,7.5rem);
    --radius:12px;
    --header-h:74px;
  }

  *{box-sizing:border-box}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{
    margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
    font-size:17px;line-height:1.62;font-weight:400;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  h1,h2,h3,h4{font-family:var(--display);color:var(--navy);font-weight:540;line-height:1.07;letter-spacing:-.015em;margin:0}
  p{margin:0}
  .wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad-x)}

  /* ---- shared bits ---- */
  .eyebrow{
    font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.16em;
    text-transform:uppercase;color:var(--brand);display:inline-flex;align-items:center;gap:.6rem;
  }
  .eyebrow::before{content:"";width:26px;height:1px;background:var(--brand);opacity:.7}
  .eyebrow.center{justify-content:center}
  .lead{color:var(--muted);font-size:1.075rem;line-height:1.6}
  .sec-head{max-width:64ch}
  .sec-head h2{font-size:clamp(1.85rem,3.4vw,2.85rem);margin:1.1rem 0 0}
  .sec-head p{margin-top:1rem}

  .btn{
    display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);
    font-weight:600;font-size:.95rem;letter-spacing:.005em;border-radius:8px;
    padding:.85rem 1.5rem;cursor:pointer;border:1px solid transparent;
    transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease;
    line-height:1;white-space:nowrap;
  }
  .btn .arr{transition:transform .18s ease}
  .btn:hover .arr{transform:translateX(3px)}
  .btn-primary{background:var(--cta);color:#fff}
  .btn-primary:hover{background:#0a5a99;transform:translateY(-1px)}
  .btn-ghost{background:transparent;color:var(--navy);border-color:var(--line-strong)}
  .btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
  .btn-white{background:#fff;color:var(--navy)}
  .btn-white:hover{background:#eef6fd;transform:translateY(-1px)}
  .link-arr{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cta);font-weight:500;display:inline-flex;gap:.4rem;align-items:center}
  .link-arr .arr{transition:transform .18s ease}
  .link-arr:hover .arr{transform:translateX(4px)}

  :focus-visible{outline:2px solid var(--cta);outline-offset:3px;border-radius:4px}

  /* ====== TOP UTILITY BAR ====== */
  .util{background:var(--navy);color:var(--navy-soft);font-family:var(--mono);font-size:.72rem;letter-spacing:.04em}
  .util .wrap{display:flex;justify-content:space-between;align-items:center;height:34px;gap:1rem}
  .util a{color:#fff}
  .util .util-r{display:flex;gap:1.4rem}
  @media(max-width:760px){.util .util-l{display:none}.util .wrap{justify-content:center}}

  /* ====== HEADER ====== */
  .head{position:sticky;top:0;z-index:60;background:var(--navy);border-bottom:3px solid var(--brand);transition:box-shadow .25s ease,background .25s ease}
  .head.scrolled{box-shadow:0 8px 30px rgba(17,24,68,.16)}
  .head .wrap{display:flex;align-items:center;gap:1.5rem;height:var(--header-h)}
  .brand{display:flex;align-items:center;gap:.65rem;color:#fff;font-family:var(--display);font-weight:600;font-size:1.32rem;letter-spacing:-.02em}
  .brand .mark{width:34px;height:34px;border-radius:7px;background:#fff;display:grid;place-items:center;color:var(--brand);font-family:var(--mono);font-weight:500;font-size:.95rem;flex:none}
  .brand small{display:block;font-family:var(--mono);font-size:.56rem;letter-spacing:.22em;color:rgba(255,255,255,.8);font-weight:400;margin-top:2px;text-transform:uppercase}

  .nav{margin-left:auto;display:flex;align-items:center;gap:.25rem}
  .nav > ul{display:flex;list-style:none;margin:0;padding:0;gap:.15rem}
  .nav > ul > li{position:relative}
  .nav > ul > li > a,.nav .navbtn{
    display:inline-flex;align-items:center;gap:.35rem;color:#fff;font-weight:500;font-size:.95rem;
    padding:.6rem .8rem;border-radius:7px;background:none;border:0;font-family:var(--sans);cursor:pointer;
  }
  .nav > ul > li > a:hover,.nav .navbtn:hover,.nav li.open > .navbtn{background:rgba(255,255,255,.14)}
  .nav .caret{width:8px;height:8px;border-right:1.6px solid #fff;border-bottom:1.6px solid #fff;transform:rotate(45deg) translateY(-2px);transition:transform .2s ease}
  .nav li.open .caret{transform:rotate(-135deg) translateY(-1px)}
  .head-cta{margin-left:.7rem}

  /* dropdowns */
  .drop{
    position:absolute;top:calc(100% + 10px);left:0;min-width:260px;background:#fff;border:1px solid var(--line);
    border-radius:var(--radius);box-shadow:0 20px 50px rgba(17,24,68,.16);padding:.5rem;
    opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s ease;
  }
  .nav li.open .drop{opacity:1;visibility:visible;transform:translateY(0)}
  .drop a{display:block;padding:.6rem .8rem;border-radius:8px;color:var(--navy);font-size:.92rem;font-weight:450}
  .drop a:hover{background:var(--mist);color:var(--cta)}
  .drop .dh{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:.6rem .8rem .2rem}

  /* mega */
  .mega{
    position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
    width:min(900px,92vw);background:#fff;border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:0 26px 60px rgba(17,24,68,.18);padding:1.6rem;
    display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
    opacity:0;visibility:hidden;transition:.2s ease;
  }
  .nav li.open .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .mega .col h4{font-size:1rem;color:var(--navy);margin-bottom:.5rem}
  .mega .col .dh{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);display:block;margin-bottom:.7rem}
  .mega .col a{display:block;padding:.4rem 0;font-size:.9rem;color:var(--muted);font-weight:450;border-bottom:1px solid transparent}
  .mega .col a:hover{color:var(--cta)}

  /* mobile nav */
  .burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;width:42px;height:42px;border-radius:8px}
  .burger span{display:block;width:22px;height:2px;background:#fff;margin:5px auto;transition:.25s}
  .burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.active span:nth-child(2){opacity:0}
  .burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* ====== HERO ====== */
  .hero{background:linear-gradient(180deg,#fff 0%,var(--mist) 100%);border-bottom:1px solid var(--line);overflow:hidden}
  .hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;padding-top:clamp(3.5rem,6vw,6rem);padding-bottom:clamp(3.5rem,6vw,6rem)}
  .hero h1{font-size:clamp(2.55rem,5.4vw,4.4rem);font-weight:460;margin:1.4rem 0 0;max-width:14ch}
  .hero h1 em{font-style:italic;color:var(--brand)}
  .hero .lead{margin-top:1.5rem;max-width:46ch;font-size:1.13rem}
  .hero .cta-row{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2.1rem}
  .creds{margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1.2rem 2rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.03em;color:var(--muted)}
  .creds b{color:var(--navy);font-weight:500}

  /* hero research card */
  .deskcard{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px rgba(17,24,68,.10);overflow:hidden}
  .deskcard .dc-top{display:flex;justify-content:space-between;align-items:center;padding:.95rem 1.2rem;border-bottom:1px solid var(--line);background:var(--navy)}
  .deskcard .dc-top .lbl{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#fff}
  .deskcard .dc-top .dt{font-family:var(--mono);font-size:.66rem;color:var(--navy-soft)}
  .deskcard .dc-body{padding:.4rem 1.2rem}
  .qrow{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.78rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
  .qrow:last-child{border-bottom:0}
  .qrow .nm{color:var(--navy);font-weight:500}
  .qrow .px{font-family:var(--mono);font-size:.9rem;color:var(--navy)}
  .qrow .ch{font-family:var(--mono);font-size:.82rem;text-align:right;min-width:64px}
  .qrow .up{color:#0f8a4f}
  .qrow .dn{color:#c0392b}
  .deskcard .dc-foot{padding:.95rem 1.2rem;border-top:1px solid var(--line);background:var(--mist);display:flex;justify-content:space-between;align-items:center}
  .deskcard .dc-foot .note{font-family:var(--mono);font-size:.62rem;color:var(--muted);letter-spacing:.04em}

  /* ====== TRUST BAR ====== */
  .trust{border-bottom:1px solid var(--line);background:#fff}
  .trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
  .trust .ti{padding:2.2rem clamp(1rem,2vw,1.8rem);border-right:1px solid var(--line)}
  .trust .ti:last-child{border-right:0}
  .trust .ti .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-bottom:.55rem}
  .trust .ti .v{font-family:var(--display);font-size:1.18rem;color:var(--navy);font-weight:540;line-height:1.25}
  @media(max-width:860px){.trust .wrap{grid-template-columns:repeat(2,1fr)}.trust .ti:nth-child(2){border-right:0}.trust .ti:nth-child(1),.trust .ti:nth-child(2){border-bottom:1px solid var(--line)}}

  /* ====== generic section ====== */
  .section{padding-block:var(--sec-y)}
  .section.mist{background:var(--mist);border-block:1px solid var(--line)}

  /* who we help — dual track */
  .tracks{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:2.6rem}
  .track{border:1px solid var(--line);border-radius:var(--radius);padding:2rem;background:#fff;transition:border-color .2s,transform .2s}
  .track:hover{border-color:var(--brand);transform:translateY(-3px)}
  .track .tlabel{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
  .track h3{font-size:1.5rem;margin:.8rem 0 .7rem}
  .track ul{list-style:none;margin:1.2rem 0 0;padding:0}
  .track li{padding:.55rem 0;border-top:1px solid var(--line);color:var(--muted);font-size:.95rem;display:flex;gap:.6rem;align-items:baseline}
  .track li::before{content:"—";color:var(--brand);font-family:var(--mono)}
  .track .tcta{margin-top:1.4rem}

  /* services pillars */
  .pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
  .pillar{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s,transform .2s}
  .pillar:hover{border-color:var(--brand);box-shadow:0 18px 44px rgba(17,24,68,.09);transform:translateY(-3px)}
  .pillar .pnum{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:var(--muted)}
  .pillar h3{font-size:1.3rem;margin:.7rem 0 .9rem}
  .pillar ul{list-style:none;margin:0 0 1.4rem;padding:0;flex:1}
  .pillar li{padding:.5rem 0;border-top:1px solid var(--line);font-size:.92rem;color:var(--muted)}
  .pillar li:first-child{border-top:0;padding-top:0}

  /* institutional — navy surface */
  .inst{background:var(--navy);color:#fff}
  .inst h2,.inst h3{color:#fff}
  .inst .eyebrow{color:#7cc6f2}
  .inst .eyebrow::before{background:#7cc6f2}
  .inst .lead{color:var(--navy-soft)}
  .inst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
  .inst-card{border:1px solid var(--navy-line);border-radius:var(--radius);padding:1.9rem;background:rgba(255,255,255,.03);transition:background .2s,border-color .2s,transform .2s}
  .inst-card:hover{background:rgba(255,255,255,.06);border-color:rgba(124,198,242,.5);transform:translateY(-3px)}
  .inst-card .ic-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#7cc6f2}
  .inst-card h3{font-size:1.28rem;margin:.8rem 0 .7rem}
  .inst-card p{color:var(--navy-soft);font-size:.94rem}
  .served{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--navy-line)}
  .served .sh{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--navy-soft);margin-bottom:1.1rem}
  .chips{display:flex;flex-wrap:wrap;gap:.7rem}
  .chip{border:1px solid var(--navy-line);border-radius:30px;padding:.5rem 1.05rem;font-size:.85rem;color:#fff;font-family:var(--sans)}

  /* tools grid */
  .tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.6rem}
  .tool{display:flex;align-items:center;gap:1rem;border:1px solid var(--line);border-radius:10px;padding:1.1rem 1.25rem;background:#fff;transition:border-color .2s,transform .2s}
  .tool:hover{border-color:var(--brand);transform:translateY(-2px)}
  .tool .tn{font-family:var(--mono);font-size:.78rem;color:var(--brand);font-weight:500;flex:none;width:30px}
  .tool .tt{font-weight:500;color:var(--navy);font-size:.96rem}
  .tools-note{margin-top:1.4rem;font-family:var(--mono);font-size:.74rem;color:var(--muted);letter-spacing:.04em}

  /* research index */
  .rindex{margin-top:2.4rem;border-top:1px solid var(--line-strong)}
  .ritem{display:grid;grid-template-columns:120px 1fr auto;gap:1.5rem;align-items:center;padding:1.35rem .4rem;border-bottom:1px solid var(--line);transition:background .18s,padding .18s}
  .ritem:hover{background:#fff;padding-left:1rem}
  .ritem .cad{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brand)}
  .ritem .rt{font-family:var(--display);font-size:1.22rem;color:var(--navy);font-weight:540}
  .ritem .rd{color:var(--muted);font-size:.9rem;margin-top:.25rem}
  .ritem .rarr{font-family:var(--mono);color:var(--cta);font-size:1.1rem;transition:transform .18s}
  .ritem:hover .rarr{transform:translateX(5px)}
  @media(max-width:700px){.ritem{grid-template-columns:1fr;gap:.35rem;align-items:start}.ritem .rarr{display:none}}

  /* why */
  .why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem 3rem;margin-top:2.6rem}
  .why{display:flex;gap:1.1rem}
  .why .wn{font-family:var(--mono);font-size:.78rem;color:var(--brand);font-weight:500;padding-top:.3rem}
  .why h3{font-size:1.2rem;margin-bottom:.5rem}
  .why p{color:var(--muted);font-size:.96rem}

  /* testimonials */
  .quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:2.6rem}
  .quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem}
  .quote .qm{font-family:var(--display);font-size:2.4rem;color:var(--brand);line-height:0;display:block;height:1rem}
  .quote p{font-family:var(--display);font-size:1.18rem;color:var(--navy);font-weight:460;line-height:1.45;margin:1.2rem 0}
  .quote .qby{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}

  /* articles */
  .arts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
  .art{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column}
  .art:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:0 18px 40px rgba(17,24,68,.09)}
  .art .thumb{height:150px;background:linear-gradient(135deg,var(--navy),var(--cta));position:relative}
  .art .thumb .cat{position:absolute;left:1rem;bottom:1rem;font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.25);padding:.3rem .65rem;border-radius:20px}
  .art .ab{padding:1.4rem;display:flex;flex-direction:column;flex:1}
  .art .adate{font-family:var(--mono);font-size:.68rem;color:var(--muted);letter-spacing:.04em}
  .art h3{font-size:1.18rem;margin:.6rem 0 .8rem;line-height:1.25}
  .art .ar{margin-top:auto}

  /* consultation CTA */
  .consult{background:var(--cta);color:#fff;border-radius:18px;padding:clamp(2.4rem,5vw,4rem);text-align:center;position:relative;overflow:hidden}
  .consult h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.8rem);max-width:20ch;margin-inline:auto}
  .consult p{color:rgba(255,255,255,.86);max-width:48ch;margin:1.1rem auto 0}
  .consult .cr{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}
  .consult .wa{background:#25D366;color:#fff}
  .consult .wa:hover{background:#1eb558;transform:translateY(-1px)}

  /* ====== FOOTER ====== */
  .foot{background:var(--navy);color:#fff;border-top:3px solid var(--brand);padding-top:clamp(3rem,5vw,4.5rem)}
  .foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.4fr;gap:2rem}
  .foot .fb{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-size:1.3rem;font-weight:600}
  .foot .fb .mark{width:32px;height:32px;border-radius:7px;background:#fff;color:var(--brand);display:grid;place-items:center;font-family:var(--mono);font-size:.9rem}
  .foot .fabout{color:rgba(255,255,255,.82);font-size:.92rem;margin-top:1rem;max-width:34ch}
  .foot h4{color:#fff;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;margin-bottom:1rem}
  .foot ul{list-style:none;margin:0;padding:0}
  .foot li{margin-bottom:.6rem}
  .foot a{color:rgba(255,255,255,.86);font-size:.92rem}
  .foot a:hover{color:#fff;text-decoration:underline}
  .news p{color:rgba(255,255,255,.82);font-size:.9rem;margin-bottom:1rem}
  .news .nf{display:flex;gap:.5rem}
  .news input{flex:1;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.1);color:#fff;border-radius:8px;padding:.7rem .9rem;font-family:var(--sans);font-size:.9rem}
  .news input::placeholder{color:rgba(255,255,255,.7)}
  .news button{background:#fff;color:var(--brand);border:0;border-radius:8px;padding:.7rem 1.1rem;font-weight:600;cursor:pointer;font-family:var(--sans)}
  .fcontact{list-style:none;margin:1.1rem 0 0;padding:0}
  .fcontact li{display:flex;gap:.6rem;align-items:flex-start;color:rgba(255,255,255,.86);font-size:.9rem;margin-bottom:.55rem;line-height:1.5}
  .fcontact li svg{width:15px;height:15px;flex:none;margin-top:.28rem;fill:var(--brand)}
  .fcontact a{color:rgba(255,255,255,.86)}
  .fcontact a:hover{color:#fff}
  .fsocial{display:flex;gap:.6rem;margin-top:1.3rem}
  .fsocial a{width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;transition:background .2s,border-color .2s}
  .fsocial a:hover{background:var(--brand);border-color:var(--brand)}
  .fsocial svg{width:17px;height:17px;fill:#fff}
  .foot-bottom{margin-top:3rem;border-top:1px solid rgba(255,255,255,.2);padding:1.6rem 0 2rem}
  .foot-bottom .disc{font-size:.78rem;color:rgba(255,255,255,.78);line-height:1.6;max-width:90ch}
  .foot-bottom .row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:1.2rem;font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.8);letter-spacing:.03em}

  /* floating whatsapp */
  .wafloat{position:fixed;right:18px;bottom:18px;z-index:70;width:56px;height:56px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 10px 30px rgba(37,211,102,.4);transition:transform .2s}
  .wafloat:hover{transform:scale(1.06)}
  .wafloat svg{width:30px;height:30px}

  /* reveal */
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* ===== responsive ===== */
  @media(max-width:980px){
    .hero .wrap{grid-template-columns:1fr}
    .deskcard{max-width:440px}
    .pillars,.inst-grid,.arts{grid-template-columns:1fr}
    .tools-grid{grid-template-columns:repeat(2,1fr)}
    .why-grid,.quotes,.tracks{grid-template-columns:1fr}
    .foot-top{grid-template-columns:1fr 1fr;gap:2rem 1.5rem}
    .foot .fc-brand{grid-column:1/-1}
    .news{grid-column:1/-1}
  }
  @media(max-width:760px){
    .nav{position:fixed;inset:var(--header-h) 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;
      padding:1rem var(--pad-x) 1.5rem;border-bottom:1px solid var(--line);box-shadow:0 20px 40px rgba(17,24,68,.14);
      transform:translateY(-130%);transition:transform .3s ease;max-height:calc(100vh - var(--header-h));overflow:auto}
    .nav.open{transform:translateY(0)}
    .nav > ul{flex-direction:column;gap:0;width:100%}
    .nav > ul > li{border-bottom:1px solid var(--line)}
    .nav > ul > li > a,.nav .navbtn{color:var(--navy);width:100%;justify-content:space-between;padding:1rem .2rem;font-size:1rem}
    .nav > ul > li > a:hover,.nav .navbtn:hover,.nav li.open > .navbtn{background:none;color:var(--cta)}
    .drop,.mega{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 .8rem;
      display:none;width:auto;grid-template-columns:1fr;min-width:0}
    .nav li.open .drop,.nav li.open .mega{display:grid}
    .head-cta{margin:1rem 0 0;width:100%;justify-content:center}
    .burger{display:block}
    .trust .wrap{grid-template-columns:1fr 1fr}
    .tools-grid{grid-template-columns:1fr}
  }
  @media(prefers-reduced-motion:reduce){
    *{scroll-behavior:auto!important}
    .reveal{opacity:1;transform:none;transition:none}
    .btn,.tool,.pillar,.track,.art,.inst-card{transition:none}
  }
/* ===== page-template additions ===== */
  .crumb{border-bottom:1px solid var(--line);background:#fff}
  .crumb .wrap{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding-block:.85rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--muted)}
  .crumb a{color:var(--muted)} .crumb a:hover{color:var(--cta)}
  .crumb .sep{opacity:.45} .crumb .cur{color:var(--navy)}

  .phero{background:linear-gradient(180deg,#fff,var(--mist));border-bottom:1px solid var(--line)}
  .phero .wrap{padding-block:clamp(2.6rem,5.5vw,4.6rem)}
  .phero h1{font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:460;margin:1rem 0 0;max-width:18ch}
  .phero .lead{margin-top:1.2rem;max-width:54ch;font-size:1.12rem}
  .phero .cta-row{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.9rem}
  .pmeta{margin-top:1.9rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted);display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
  .pmeta .dot{opacity:.5}
  .phero.navy{background:var(--navy);border-bottom:3px solid var(--brand)}
  .phero.navy h1{color:#fff}
  .phero.navy .lead{color:var(--navy-soft)}
  .phero.navy .eyebrow{color:#7cc6f2}.phero.navy .eyebrow::before{background:#7cc6f2}
  .phero.navy .pmeta{color:var(--navy-soft)}
  .phero.navy .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
  .phero.navy .btn-ghost:hover{border-color:#7cc6f2;color:#7cc6f2}

  .intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem}
  .intro-grid h3{font-size:1.28rem}
  .intro-grid p{color:var(--muted);margin-top:.6rem}
  @media(max-width:820px){.intro-grid{grid-template-columns:1fr;gap:1.8rem}}

  .feat{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.5rem}
  .fi{border:1px solid var(--line);border-radius:var(--radius);padding:1.55rem;background:#fff;transition:border-color .2s,transform .2s}
  .fi:hover{border-color:var(--brand);transform:translateY(-3px)}
  .fi h3{font-size:1.08rem;margin-bottom:.45rem;display:flex;align-items:baseline;gap:.55rem}
  .fi h3::before{content:"";width:7px;height:7px;background:var(--brand);border-radius:2px;flex:none}
  .fi p{color:var(--muted);font-size:.92rem}
  @media(max-width:820px){.feat{grid-template-columns:1fr}}

  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;margin-top:2.5rem}
  .step{padding-top:1.4rem;border-top:2px solid var(--line-strong)}
  .step .sn{font-family:var(--mono);font-size:.82rem;color:var(--brand);font-weight:500}
  .step h3{font-size:1.1rem;margin:.5rem 0 .4rem}
  .step p{color:var(--muted);font-size:.9rem}
  @media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.steps{grid-template-columns:1fr}}

  .chips-l{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
  .chip-l{border:1px solid var(--line-strong);border-radius:30px;padding:.5rem 1.05rem;font-size:.88rem;color:var(--navy);background:#fff}

  .gov{background:var(--navy);color:#fff;border-radius:18px;padding:clamp(2rem,4vw,3.2rem)}
  .gov .eyebrow{color:#7cc6f2}.gov .eyebrow::before{background:#7cc6f2}
  .gov h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin-top:.9rem}
  .gov .lead{color:var(--navy-soft)}
  .gov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2rem}
  .gov-card{border:1px solid var(--navy-line);border-radius:var(--radius);padding:1.6rem;background:rgba(255,255,255,.03)}
  .gov-card h3{color:#fff;font-size:1.12rem;margin-bottom:.5rem}
  .gov-card p{color:var(--navy-soft);font-size:.92rem}
  @media(max-width:820px){.gov-grid{grid-template-columns:1fr}}

  .casebox{border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:0 var(--radius) var(--radius) 0;background:#fff;padding:1.8rem 2rem;margin-top:2.4rem;max-width:82ch}
  .casebox .ck{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:.7rem}
  .casebox p{color:var(--ink);font-size:1rem}

  .faq{margin-top:2.3rem;border-top:1px solid var(--line)}
  .faq details{border-bottom:1px solid var(--line)}
  .faq summary{cursor:pointer;list-style:none;padding:1.2rem .2rem;display:flex;justify-content:space-between;gap:1rem;align-items:center;font-family:var(--display);font-size:1.12rem;color:var(--navy);font-weight:540}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary .ico{font-family:var(--mono);color:var(--brand);font-size:1.3rem;transition:transform .2s;flex:none}
  .faq details[open] summary .ico{transform:rotate(45deg)}
  .faq .ans{padding:0 .2rem 1.35rem;color:var(--muted);font-size:.96rem;max-width:72ch}

  .relgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.5rem}
  .relcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;background:#fff;transition:border-color .2s,transform .2s,box-shadow .2s}
  .relcard:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:0 16px 38px rgba(17,24,68,.08)}
  .relcard .rk{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
  .relcard h3{font-size:1.18rem;margin:.55rem 0 .55rem}
  .relcard p{color:var(--muted);font-size:.92rem;flex:1}
  .relcard .rl{margin-top:1.1rem}
  @media(max-width:820px){.relgrid{grid-template-columns:1fr}}

/* ===== research / blog / article ===== */
  .ftabs{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
  .ftab{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:.55rem 1rem;border:1px solid var(--line-strong);border-radius:30px;color:var(--muted);background:#fff;cursor:pointer;transition:.2s;text-decoration:none}
  .ftab:hover{border-color:var(--brand);color:var(--cta)}
  .ftab.active{background:var(--navy);border-color:var(--navy);color:#fff}

  .feature{display:grid;grid-template-columns:1.45fr 1fr;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:2.4rem;background:#fff}
  .feature .fmain{padding:clamp(1.8rem,3vw,2.6rem);display:flex;flex-direction:column;justify-content:center}
  .feature .ftag{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand)}
  .feature h3{font-size:clamp(1.5rem,2.6vw,2rem);margin:.7rem 0 .8rem;line-height:1.14}
  .feature p{color:var(--muted)}
  .feature .farr{margin-top:1.5rem}
  .feature .fside{background:var(--navy);color:#fff;padding:clamp(1.8rem,3vw,2.4rem);display:flex;flex-direction:column;justify-content:center;gap:.2rem}
  .feature .fside .ds{font-family:var(--mono);font-size:.7rem;color:var(--navy-soft);letter-spacing:.04em;margin-bottom:.7rem}
  .feature .fside .ln{display:flex;justify-content:space-between;border-bottom:1px solid var(--navy-line);padding:.6rem 0;font-size:.92rem}
  .feature .fside .ln:last-child{border-bottom:0}
  .feature .fside .ln em{font-family:var(--mono);font-style:normal;color:#7cc6f2}
  @media(max-width:820px){.feature{grid-template-columns:1fr}}

  .cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:1.6rem}
  .pcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:border-color .2s,transform .2s,box-shadow .2s}
  .pcard:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:0 16px 38px rgba(17,24,68,.08)}
  .pcard .pthumb{height:140px;background:linear-gradient(135deg,var(--navy),var(--cta));position:relative}
  .pcard .pthumb .pc{position:absolute;left:.9rem;bottom:.9rem;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.3);padding:.3rem .6rem;border-radius:20px}
  .pcard .pbody{padding:1.3rem;display:flex;flex-direction:column;flex:1}
  .pcard .pmetar{font-family:var(--mono);font-size:.64rem;color:var(--muted);letter-spacing:.05em;display:flex;gap:.6rem;flex-wrap:wrap}
  .pcard h3{font-size:1.1rem;margin:.55rem 0 .55rem;line-height:1.25}
  .pcard p{color:var(--muted);font-size:.89rem;flex:1}
  .pcard .pl{margin-top:1rem}
  @media(max-width:980px){.cardgrid{grid-template-columns:1fr 1fr}}
  @media(max-width:640px){.cardgrid{grid-template-columns:1fr}}

  .pagination{display:flex;justify-content:center;gap:.5rem;margin-top:2.8rem}
  .pagination a,.pagination span{min-width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--line-strong);border-radius:8px;font-family:var(--mono);font-size:.84rem;color:var(--navy);background:#fff;padding:0 .7rem;text-decoration:none}
  .pagination a:hover{border-color:var(--brand);color:var(--cta)}
  .pagination .cur{background:var(--navy);border-color:var(--navy);color:#fff}
  .pagination .dis{opacity:.4}

  .subscribe{background:var(--mist);border:1px solid var(--line);border-radius:16px;padding:clamp(1.8rem,3.5vw,2.8rem);text-align:center}
  .subscribe h2{font-size:clamp(1.5rem,2.6vw,2rem)}
  .subscribe p{color:var(--muted);max-width:48ch;margin:.9rem auto 0}
  .subscribe .sf{display:flex;gap:.5rem;max-width:440px;margin:1.6rem auto 0}
  .subscribe input{flex:1;border:1px solid var(--line-strong);border-radius:8px;padding:.8rem 1rem;font-family:var(--sans);font-size:.95rem;background:#fff}
  .subscribe button{background:var(--cta);color:#fff;border:0;border-radius:8px;padding:.8rem 1.4rem;font-weight:600;cursor:pointer;font-family:var(--sans)}
  @media(max-width:520px){.subscribe .sf{flex-direction:column}}

  .artwrap{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:3rem;align-items:start}
  @media(max-width:920px){.artwrap{grid-template-columns:1fr}}
  .artmeta{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--brand);display:flex;gap:.7rem;flex-wrap:wrap;text-transform:uppercase}
  .arthead h1{font-size:clamp(2rem,4vw,3rem);font-weight:460;margin:1rem 0 0;max-width:26ch}
  .artlede{color:var(--muted);font-size:1.18rem;margin-top:1.1rem;max-width:62ch;line-height:1.55}
  .artfig{height:clamp(220px,38vw,420px);border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--cta));margin:2.2rem 0}
  .prose{max-width:68ch}
  .prose h2{font-size:1.55rem;margin:2.3rem 0 .8rem}
  .prose h3{font-size:1.22rem;margin:1.8rem 0 .6rem}
  .prose p{margin:1.05rem 0;color:var(--ink);font-size:1.04rem}
  .prose ul{margin:1.05rem 0;padding-left:1.2rem;color:var(--ink)}
  .prose li{margin:.5rem 0}
  .prose blockquote{border-left:3px solid var(--brand);margin:1.7rem 0;padding:.4rem 0 .4rem 1.4rem;font-family:var(--display);font-size:1.32rem;color:var(--navy);font-style:italic}
  .prose a{color:var(--cta);text-decoration:underline;text-underline-offset:3px}
  .authorbox{display:flex;gap:1rem;align-items:center;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;margin-top:2.6rem;background:var(--mist)}
  .authorbox .av{width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--mono);font-weight:500;flex:none}
  .authorbox .an{font-weight:600;color:var(--navy)}
  .authorbox .ar{font-size:.88rem;color:var(--muted)}
  .share{display:flex;gap:.6rem;align-items:center;margin-top:2rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
  .share a{width:34px;height:34px;border-radius:8px;border:1px solid var(--line-strong);display:grid;place-items:center}
  .share a:hover{border-color:var(--brand)}
  .share a svg{width:15px;height:15px;fill:var(--navy)}
  .sidebar{position:sticky;top:96px;display:flex;flex-direction:column;gap:1.4rem}
  .swidget{border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;background:#fff}
  .swidget h4{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-bottom:1rem}
  .swidget ul{list-style:none;margin:0;padding:0}
  .swidget li{padding:.6rem 0;border-top:1px solid var(--line);font-size:.92rem}
  .swidget li:first-child{border-top:0}
  .swidget a{color:var(--navy)}.swidget a:hover{color:var(--cta)}
  .swidget .sd{font-family:var(--mono);font-size:.62rem;color:var(--muted);display:block;margin-bottom:.2rem}
  .swidget .sbtn{display:block;text-align:center;background:var(--cta);color:#fff;border-radius:8px;padding:.7rem;font-weight:600;margin-top:.3rem}
  .swidget input{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:.7rem .9rem;font-family:var(--sans);font-size:.9rem;margin-bottom:.5rem}
  @media(max-width:920px){.sidebar{position:static}}

/* ===== about / contact / tool ===== */
  .founder{display:grid;grid-template-columns:200px 1fr;gap:2.4rem;align-items:start;margin-top:2.4rem}
  .founder .fphoto{aspect-ratio:1/1;border-radius:16px;background:linear-gradient(135deg,var(--navy),var(--cta));display:grid;place-items:center;color:#fff;font-family:var(--mono);font-size:2.2rem;letter-spacing:.05em}
  .founder h3{font-size:1.55rem}
  .founder .frole{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--brand);margin:.4rem 0 1.1rem}
  .founder p{color:var(--muted);margin-bottom:.9rem}
  .founder .fcreds{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
  @media(max-width:680px){.founder{grid-template-columns:1fr}.founder .fphoto{max-width:150px}}

  .contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:2.6rem;align-items:start}
  @media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
  .form{border:1px solid var(--line);border-radius:14px;padding:clamp(1.6rem,3vw,2.2rem);background:#fff}
  .field{margin-bottom:1.1rem}
  .field label{display:block;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:.4rem}
  .field input,.field select,.field textarea{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:.8rem .9rem;font-family:var(--sans);font-size:.95rem;background:#fff;color:var(--ink)}
  .field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--cta);outline-offset:1px;border-color:var(--cta)}
  .field textarea{min-height:120px;resize:vertical}
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
  @media(max-width:520px){.field-row{grid-template-columns:1fr}}
  .consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;color:var(--muted);margin-bottom:1.2rem}
  .consent input{width:auto;margin-top:.25rem}
  .form .btn{width:100%;justify-content:center}
  .form .ok{display:none;margin-top:1rem;padding:.9rem 1rem;border-radius:8px;background:var(--brand-tint);color:var(--cta);font-size:.9rem;font-weight:500}
  .cinfo{display:flex;flex-direction:column;gap:1rem}
  .ci{display:flex;gap:.9rem;border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;background:#fff}
  .ci svg{width:20px;height:20px;fill:var(--brand);flex:none;margin-top:.15rem}
  .ci .ck{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
  .ci .cv{color:var(--navy);font-size:.96rem;line-height:1.5}
  .ci a{color:var(--cta)}
  .csocial{display:flex;gap:.6rem;margin-top:.2rem}
  .csocial a{width:40px;height:40px;border:1px solid var(--line-strong);border-radius:8px;display:grid;place-items:center}
  .csocial a:hover{border-color:var(--brand)}
  .csocial svg{width:17px;height:17px;fill:var(--navy)}
  .cmap{height:240px;border:1px solid var(--line);border-radius:14px;background:var(--mist);display:grid;place-items:center;font-family:var(--mono);font-size:.74rem;color:var(--muted);text-align:center;padding:1rem}

  .calc{display:grid;grid-template-columns:.92fr 1.08fr;gap:1.8rem;margin-top:2.4rem;align-items:start}
  @media(max-width:880px){.calc{grid-template-columns:1fr}}
  .calc-card{border:1px solid var(--line);border-radius:14px;padding:clamp(1.5rem,3vw,2rem);background:#fff}
  .cinput{margin-bottom:1.6rem}
  .cinput:last-child{margin-bottom:0}
  .cinput .cl{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.55rem}
  .cinput .cl label{font-size:.9rem;font-weight:600;color:var(--navy)}
  .cinput .cl .cval{font-family:var(--mono);font-size:1rem;color:var(--cta);font-weight:500}
  .cinput input[type=range]{width:100%;accent-color:var(--brand);cursor:pointer}
  .cinput .crange{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.66rem;color:var(--muted);margin-top:.3rem}
  .cmetrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.9rem}
  @media(max-width:520px){.cmetrics{grid-template-columns:1fr}}
  .cmetric{border:1px solid var(--line);border-radius:var(--radius);padding:1.05rem;background:var(--mist)}
  .cmetric .mk{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
  .cmetric .mv{font-family:var(--display);font-size:1.3rem;color:var(--navy);font-weight:540;margin-top:.3rem;line-height:1.1}
  .cmetric.hl{background:var(--navy)}
  .cmetric.hl .mk{color:var(--navy-soft)}
  .cmetric.hl .mv{color:#fff}
  .cbar{display:flex;height:14px;border-radius:8px;overflow:hidden;margin:1.7rem 0 .7rem;border:1px solid var(--line)}
  .cbar .b1{background:var(--brand)}.cbar .b2{background:var(--navy)}
  .cbar-leg{display:flex;gap:1.4rem;font-family:var(--mono);font-size:.7rem;color:var(--muted)}
  .cbar-leg span{display:flex;align-items:center;gap:.4rem}
  .cbar-leg i{width:10px;height:10px;border-radius:2px;display:inline-block}
  .cchart{margin-top:1.7rem}
  .cchart svg{width:100%;height:auto;display:block}
  .cnote{font-family:var(--mono);font-size:.66rem;color:var(--muted);margin-top:1.1rem;letter-spacing:.03em;line-height:1.5}

