:root{
  --bg:#f6fafc;
  --bg-soft:#eef5f8;
  --bg-tint:#e6eff4;
  --surface:#ffffff;
  --surface-2:#fbfdff;
  --surface-3:#f1f7fa;
  --surface-4:#eaf2f6;

  --ink:#163242;
  --ink-2:#355362;
  --ink-3:#4d6976;
  --muted:#6c8692;
  --muted-2:#8ca0aa;

  --line:#d8e4eb;
  --line-strong:#c5d5de;
  --line-soft:rgba(197,213,222,.62);
  --line-coral:#f3c0be;

  --blue:#8fb9cc;
  --blue-deep:#6f9fb7;
  --blue-rich:#567f96;
  --blue-soft:#dcebf2;

  --coral:#ff6a75;
  --coral-deep:#ef5763;
  --coral-soft:#ffd7d4;

  --shadow-xs:0 6px 16px rgba(27,57,72,.05);
  --shadow-sm:0 12px 28px rgba(27,57,72,.07);
  --shadow-md:0 20px 48px rgba(27,57,72,.09);
  --shadow-lg:0 30px 80px rgba(27,57,72,.11);
  --shadow-xl:0 44px 120px rgba(27,57,72,.14);

  --radius:20px;
  --radius-md:26px;
  --radius-lg:34px;
  --pill:999px;
  --max:1280px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  line-height:1.58;
  background:
    radial-gradient(1120px 580px at 0% 0%, rgba(143,185,204,.22), transparent 60%),
    radial-gradient(840px 540px at 100% 8%, rgba(255,106,117,.12), transparent 58%),
    linear-gradient(180deg, #fbfdff 0%, var(--bg) 32%, var(--bg-soft) 100%);
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.35) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.28) 1px, transparent 1px);
  background-size:34px 34px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,0));
  opacity:.22;
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  display:block;
  max-width:100%;
}

p{
  margin:0 0 14px;
}

ul{
  margin:0;
  padding-left:18px;
}

li{
  margin:6px 0;
}

.wrap{
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
}

.skip{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

.skip:focus{
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  background:#fff;
  color:var(--ink);
  border:1px solid var(--line-strong);
  border-radius:12px;
  padding:10px 12px;
  z-index:9999;
  box-shadow:var(--shadow-md);
}

.sr{
  position:absolute;
  left:-9999px;
}

/* topbar */

.topbar{
  position:sticky;
  top:0;
  z-index:70;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(197,213,222,.82);
  box-shadow:0 1px 0 rgba(255,255,255,.55);
}

.topbar__inner{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand{
  display:flex;
  align-items:center;
  min-width:0;
}

.brand--logo{
  flex:0 0 auto;
}

.brand__logoimg{
  width:auto;
  height:86px;
  max-width:none;
  object-fit:contain;
  filter:drop-shadow(0 10px 22px rgba(22,50,66,.10));
}

.nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
  flex:1 1 auto;
  min-width:0;
}

.nav a{
  color:var(--ink-2);
  font-size:14px;
  font-weight:800;
  letter-spacing:.01em;
  padding:11px 14px;
  border-radius:14px;
  transition:background .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.nav a:hover{
  background:rgba(143,185,204,.11);
  color:var(--ink);
  transform:translateY(-1px);
}

.nav .pill{
  background:linear-gradient(135deg, var(--coral), #ff8c88);
  color:#ffffff !important;
  box-shadow:0 18px 38px rgba(255,106,117,.28);
  padding-inline:18px !important;
}

.nav .pill:hover{
  background:linear-gradient(135deg, var(--coral-deep), var(--coral));
  color:#ffffff !important;
  box-shadow:0 22px 42px rgba(255,106,117,.30);
}

.navbtn{
  display:none;
  border:1px solid var(--line);
  background:#fff;
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
  box-shadow:var(--shadow-xs);
}

.navbtn__bar{
  display:block;
  width:18px;
  height:2px;
  background:var(--ink);
  margin:4px 0;
  border-radius:999px;
}

/* hero */

.hero{
  position:relative;
  padding:44px 0 48px;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(760px 460px at 8% 18%, rgba(143,185,204,.22), transparent 70%),
    radial-gradient(680px 420px at 92% 14%, rgba(255,106,117,.14), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,.54), rgba(255,255,255,0));
}

.hero::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:88px;
  background:linear-gradient(180deg, rgba(246,250,252,0), rgba(230,239,244,.34));
  pointer-events:none;
}

.hero__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1fr) 336px;
  gap:10px;
  align-items:start;
}

.hero__copy{
  padding-top:0;
  align-self:start;
  min-width:0;
  max-width:none;
  overflow:visible;
  padding-right:0;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.90);
  color:var(--blue-rich);
  box-shadow:var(--shadow-xs);
  border-radius:var(--pill);
  padding:10px 14px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.h1{
  margin:18px 0 18px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  font-size:58px;
  line-height:.94;
  letter-spacing:-.05em;
  color:var(--ink);
  max-width:none;
  overflow:visible;
}

.h1 .line{
  display:block;
  width:max-content;
  max-width:none;
  white-space:nowrap;
  overflow:visible;
  flex:0 0 auto;
}

.h1 .accent{
  background:linear-gradient(135deg, var(--blue-deep) 0%, #86b4ca 48%, #b8bccd 78%, var(--coral) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  padding-right:.18em;
}

.lead{
  font-size:18px;
  line-height:1.78;
  color:var(--ink-2);
  max-width:35ch;
}

.cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:26px 0 18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:13px 18px;
  border-radius:var(--pill);
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font-size:15px;
  font-weight:900;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
  box-shadow:var(--shadow-sm);
}

.btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}

.btn--primary{
  background:linear-gradient(135deg, var(--coral), #ff8f8a);
  border-color:transparent;
  color:#fff;
  box-shadow:0 20px 38px rgba(255,106,117,.28);
}

.btn--primary:hover{
  background:linear-gradient(135deg, var(--coral-deep), var(--coral));
  color:#fff;
}

.btn--ghost{
  background:rgba(255,255,255,.88);
  color:var(--ink);
}

.btn--ghost:hover{
  border-color:var(--blue);
  background:#fff;
}

.btn--small{
  min-height:44px;
  padding:10px 14px;
  font-size:14px;
}

.trustrow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:6px;
}

.chip{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:9px 12px;
  border-radius:var(--pill);
  border:1px solid var(--line);
  background:rgba(255,255,255,.86);
  color:var(--ink-2);
  font-size:13px;
  font-weight:800;
  box-shadow:var(--shadow-xs);
}

.minirow{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:22px;
  max-width:920px;
}

.stat{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,253,.98));
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px 16px;
  box-shadow:var(--shadow-md);
  position:relative;
  overflow:hidden;
}

.stat::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--blue) 0%, #9ebacd 50%, var(--coral) 100%);
}

.stat__k{
  font-size:12px;
  font-weight:900;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.08em;
}

.stat__v{
  margin-top:10px;
  font-size:20px;
  line-height:1.28;
  font-weight:900;
  color:var(--ink);
}

.micro{
  font-size:12.5px;
  line-height:1.55;
  color:var(--muted);
  margin-top:14px;
}

.hero__card{
  align-self:start;
  justify-self:start;
  width:100%;
  max-width:336px;
  margin-top:-4px;
  margin-left:0;
  border-radius:32px;
  border:1px solid rgba(197,213,222,.9);
  background:
    radial-gradient(520px 260px at 0% 0%, rgba(143,185,204,.19), transparent 72%),
    radial-gradient(420px 260px at 100% 100%, rgba(255,106,117,.12), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,247,250,.98));
  box-shadow:var(--shadow-xl);
  overflow:hidden;
}

.cardglass{
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.cardglass__top{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.label{
  font-size:23px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.03em;
  color:var(--ink);
}

.stack{
  display:grid;
  gap:12px;
}

.step{
  display:flex;
  gap:12px;
  align-items:flex-start;
  background:rgba(255,255,255,.88);
  border:1px solid var(--line);
  border-radius:20px;
  padding:13px;
  box-shadow:var(--shadow-xs);
}

.step__num{
  width:38px;
  height:38px;
  flex:0 0 38px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(143,185,204,.18), rgba(255,106,117,.16));
  color:var(--ink);
  font-weight:900;
  border:1px solid rgba(197,213,222,.9);
}

.step__body{
  min-width:0;
}

.step__title{
  font-size:16px;
  line-height:1.2;
  font-weight:900;
  color:var(--ink);
}

.step__text{
  margin-top:6px;
  font-size:13px;
  line-height:1.45;
  color:var(--ink-2);
}

.cardglass__cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.badge{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.badge__pill{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 11px;
  border-radius:var(--pill);
  background:rgba(143,185,204,.11);
  border:1px solid rgba(197,213,222,.94);
  color:var(--ink-2);
  font-size:12px;
  font-weight:900;
}

/* sections */

.section{
  position:relative;
  padding:104px 0;
}

.section::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(197,213,222,.72), transparent);
}

.section--alt{
  background:
    linear-gradient(180deg, rgba(235,244,248,.86), rgba(247,250,252,.92));
  border-top:1px solid rgba(216,228,235,.76);
  border-bottom:1px solid rgba(216,228,235,.76);
}

.section__head{
  max-width:900px;
  margin-bottom:38px;
}

.section__eyebrow{
  display:inline-flex;
  align-items:center;
  margin-bottom:12px;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--blue-rich);
}

.h2{
  margin:0 0 12px;
  font-size:clamp(36px, 4vw, 54px);
  line-height:1.02;
  letter-spacing:-.04em;
  color:var(--ink);
}

.sub{
  margin:0;
  font-size:17px;
  line-height:1.78;
  color:var(--ink-2);
  max-width:74ch;
}

.grid3{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:22px;
}

.grid2{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:22px;
}

.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:18px;
}

.tile,
.panel,
.contactcard,
.form,
.compliance{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,253,.98));
  box-shadow:var(--shadow-lg);
}

.tile,
.panel{
  padding:26px;
}

.tile::before,
.panel::before,
.contactcard::before,
.form::before,
.compliance::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(320px 190px at 0% 0%, rgba(143,185,204,.09), transparent 72%);
}

.tile--soft{
  background:
    radial-gradient(360px 180px at 0% 0%, rgba(143,185,204,.13), transparent 74%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,253,.98));
}

.panel--resource{
  background:
    radial-gradient(340px 180px at 100% 0%, rgba(255,106,117,.11), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,253,.98));
}

.h3{
  position:relative;
  margin:0 0 10px;
  font-size:25px;
  line-height:1.16;
  letter-spacing:-.03em;
  color:var(--ink);
}

.tile p,
.panel p,
.callout__text,
.contactline,
.note,
.tiny,
.compliance p{
  position:relative;
  color:var(--ink-2);
}

.bullets{
  margin-top:12px;
  color:var(--muted);
  font-size:14px;
  line-height:1.68;
}

.panel__tag{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:7px 11px;
  margin-bottom:12px;
  border-radius:var(--pill);
  border:1px solid var(--line);
  background:rgba(143,185,204,.10);
  color:var(--blue-rich);
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
}

.panel__tag--accent{
  background:rgba(255,106,117,.10);
  border-color:var(--line-coral);
  color:var(--coral-deep);
}

.meta{
  position:relative;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:14px 0 4px;
}

.meta span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 11px;
  border-radius:var(--pill);
  border:1px solid var(--line);
  background:rgba(255,255,255,.88);
  color:var(--ink-2);
  font-size:12.5px;
  font-weight:800;
}

.link{
  display:inline-flex;
  margin-top:12px;
  color:var(--coral-deep);
  font-weight:900;
}

.check,
.xlist{
  margin-top:12px;
}

.check li,
.xlist li{
  list-style:none;
  margin-left:-18px;
  padding-left:24px;
  position:relative;
}

.check li,
.xlist li{
  color:var(--ink-2);
}

.check li::before,
.xlist li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:10px;
  height:10px;
  border-radius:4px;
}

.check li::before{
  background:var(--blue);
}

.xlist li::before{
  background:var(--coral);
}

.callout{
  margin-top:24px;
  padding:24px;
  border-radius:26px;
  border:1px solid rgba(197,213,222,.95);
  background:linear-gradient(180deg, rgba(232,242,247,.78), rgba(255,255,255,.94));
  box-shadow:var(--shadow-md);
}

.callout--edge{
  border-color:rgba(243,192,190,.96);
  background:linear-gradient(180deg, rgba(255,218,215,.46), rgba(255,255,255,.94));
}

.callout__title{
  font-size:19px;
  line-height:1.2;
  font-weight:900;
  color:var(--ink);
  margin-bottom:6px;
}

.callout__text{
  color:var(--ink-2);
}

.resourcebar,
.quick,
.form__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.qbtn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  padding:10px 13px;
  border-radius:var(--pill);
  cursor:pointer;
  font-size:13px;
  font-weight:900;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
  box-shadow:var(--shadow-xs);
}

.qbtn:hover{
  transform:translateY(-1px);
  border-color:var(--blue);
  background:#fff;
  box-shadow:var(--shadow-sm);
}

.qout{
  margin-top:14px;
  min-height:54px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.90);
  border-radius:18px;
  padding:14px;
  color:var(--ink-2);
}

.compliance{
  margin-top:24px;
  padding:26px;
}

#audiences .tile,
#founder .panel,
#partners .panel,
#method .panel,
#program .tile{
  min-height:100%;
}

/* contact */

.contactgrid{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:22px;
  align-items:start;
}

.contactcard,
.form{
  padding:26px;
}

.contactcard__title{
  position:relative;
  font-size:24px;
  line-height:1.15;
  font-weight:900;
  color:var(--ink);
  margin-bottom:12px;
}

.contactline{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(216,228,235,.94);
}

.contactline span:first-child{
  color:var(--muted);
  font-weight:800;
}

.note{
  margin-top:14px;
  padding:12px;
  border:1px dashed var(--line-strong);
  border-radius:16px;
  font-size:12.5px;
  color:var(--ink-2);
  background:rgba(255,255,255,.72);
}

.tiny{
  margin-top:12px;
  font-size:12.5px;
  line-height:1.65;
  color:var(--muted);
}

.form label:not(.consent){
  display:block;
  margin-bottom:8px;
  color:var(--ink);
  font-size:13px;
  font-weight:900;
}

input,
select,
textarea{
  width:100%;
  margin-top:0;
  border:1px solid var(--line);
  border-radius:16px;
  background:#ffffff;
  color:var(--ink);
  padding:13px 14px;
  outline:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65);
}

input::placeholder,
textarea::placeholder{
  color:var(--muted-2);
}

input:focus,
select:focus,
textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(143,185,204,.18);
}

.row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:4px;
}

.row > div{
  min-width:0;
}

.form .micro{
  margin-top:6px;
  margin-bottom:12px;
  font-size:12px;
  line-height:1.45;
}

#nameError,
#emailError,
#topicError,
#messageError{
  color:#bf4f58;
  min-height:16px;
}

.form > label[for="topic"],
.form > label[for="message"]{
  margin-top:6px;
}

.consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin-top:6px;
  margin-bottom:14px;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.84);
  color:var(--ink-2);
  font-size:13px;
  line-height:1.55;
}

.consent input{
  width:auto;
  margin:2px 0 0;
  flex:0 0 auto;
}

.form__status{
  margin-top:10px;
  font-size:13px;
  color:var(--ink-2);
}

/* footer */

.footer{
  border-top:1px solid rgba(216,228,235,.94);
  background:
    radial-gradient(560px 240px at 0% 0%, rgba(143,185,204,.13), transparent 72%),
    linear-gradient(180deg, #eef5f8 0%, #e7f0f4 100%);
  padding:48px 0 36px;
}

.footer__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr 1fr;
  gap:24px;
  align-items:start;
}

.footer__logoimg{
  width:auto;
  height:60px;
  max-width:100%;
  object-fit:contain;
  margin-bottom:14px;
}

.footer__links{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px 14px;
  align-content:start;
}

.footer__links a{
  color:var(--ink-2);
  font-weight:800;
}

.footer__links a:hover{
  color:var(--coral-deep);
}

.footer__small{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.7;
}

/* misc */

.toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  max-width:min(720px, calc(100% - 28px));
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 14px;
  color:var(--ink);
  box-shadow:var(--shadow-lg);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:90;
}

.toast.is-on{
  opacity:1;
  transform:translateX(-50%) translateY(-2px);
}

.reveal{
  opacity:0;
  transform:translateY(10px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.is-in{
  opacity:1;
  transform:translateY(0);
}

/* responsive */

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn,
  .qbtn,
  .toast,
  .reveal,
  .nav a{
    transition:none;
  }
}

@media (max-width:1260px){
  .hero__grid{
    grid-template-columns:minmax(0, 1fr) 324px;
    gap:10px;
  }

  .hero__copy{
    max-width:none;
  }

  .h1{
    font-size:54px;
  }

  .lead{
    max-width:34ch;
  }

  .hero__card{
    max-width:324px;
    margin-top:-2px;
  }
}

@media (max-width:1140px){
  .nav{
    gap:4px;
  }

  .nav a{
    padding:10px 10px;
    font-size:13px;
  }

  .hero__grid{
    grid-template-columns:minmax(0, 1fr) 288px;
    gap:10px;
  }

  .hero__copy{
    max-width:none;
  }

  .h1{
    font-size:48px;
  }

  .lead{
    max-width:33ch;
  }

  .hero__card{
    max-width:288px;
    margin-top:-2px;
  }

  .cardglass{
    padding:20px;
  }

  .step{
    padding:12px;
  }

  .step__title{
    font-size:15px;
  }

  .step__text{
    font-size:12.5px;
  }
}

@media (max-width:700px){
  .hero{
    padding:34px 0 64px;
  }

  .hero__grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .grid3,
  .grid2,
  .split,
  .contactgrid,
  .footer__grid,
  .row,
  .minirow{
    grid-template-columns:1fr;
  }

  .hero__copy{
    padding-top:10px;
    max-width:none;
    padding-right:0;
  }

  .lead{
    max-width:none;
    font-size:18px;
  }

  .h1{
    font-size:clamp(44px, 9vw, 62px);
    max-width:none;
  }

  .h1 .line{
    display:block;
    width:auto;
    white-space:normal;
  }

  .hero__card{
    margin-top:10px;
    margin-left:0;
    justify-self:stretch;
    max-width:none;
  }

  .section{
    padding:82px 0;
  }

  .brand__logoimg{
    height:72px;
  }

  .footer__logoimg{
    height:48px;
  }
}

@media (max-width:760px){
  .topbar__inner{
    min-height:80px;
  }

  .navbtn{
    display:inline-flex;
  }

  .nav{
    display:none;
    position:absolute;
    right:20px;
    top:78px;
    width:min(320px, calc(100% - 40px));
    flex-direction:column;
    align-items:stretch;
    background:#ffffff;
    border:1px solid var(--line);
    border-radius:18px;
    padding:10px;
    box-shadow:var(--shadow-lg);
  }

  .nav.is-open{
    display:flex;
  }

  .nav a{
    font-size:14px;
    padding:11px 12px;
  }

  .h1{
    font-size:clamp(40px, 12vw, 56px);
    line-height:.98;
  }

  .cta,
  .cardglass__cta,
  .resourcebar,
  .quick,
  .form__actions{
    flex-direction:column;
    align-items:stretch;
  }

  .wrap{
    width:min(var(--max), calc(100% - 24px));
  }

  .brand__logoimg{
    height:58px;
  }

  .footer__logoimg{
    height:42px;
  }

  .tile,
  .panel,
  .contactcard,
  .form,
  .compliance,
  .hero__card{
    border-radius:24px;
  }

  .cardglass{
    padding:22px;
  }
}