*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  color:#111111;
  background:#ffffff;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3{margin:0;font-family:'Fraunces',Georgia,serif;line-height:1.04;letter-spacing:-.01em}

:root{
  --ink:#111111;
  --muted:#3A3A3A;
  --orange:#F5A000;
  --orange-d:#b86f00;
  --red:#E84A1E;
  --pink:#F7A8D8;
  --lav:#E5E3FA;
  --blue:#CFE0FF;
  --maxw:1200px;
  --pad:24px;
}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;font-weight:600;font-size:15px;
  padding:14px 26px;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  min-height:46px;
}
.btn--primary{background:var(--orange);color:#1a1200;border-color:var(--orange)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 10px 22px -8px rgba(245,160,0,.65)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn--dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
a:focus-visible,button:focus-visible,.chip:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px}

/* Promo bar */
.promobar{background:var(--ink);color:#fff}
.promobar__inner{display:flex;align-items:center;gap:12px;padding-top:9px;padding-bottom:9px;font-size:13px;flex-wrap:wrap}
.promobar__tag{background:var(--orange);color:#1a1200;font-weight:700;padding:3px 9px;border-radius:50px;font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.promobar__txt{color:#cfcfcf}
.promobar__link{color:#fff;font-weight:600;margin-left:auto}
.promobar__link:hover{color:var(--orange)}

/* Header */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid #eee}
.header__inner{display:flex;align-items:center;gap:18px;min-height:72px}
.brand__logo{height:26px;width:auto}
.nav{margin-left:8px}
.nav__list{display:flex;align-items:center;gap:6px}
.nav__list>li>a,.nav__folderbtn{
  display:inline-flex;align-items:center;gap:4px;
  font-size:14px;font-weight:500;color:var(--ink);
  padding:9px 12px;border-radius:8px;background:none;border:none;cursor:pointer;
  font-family:'Inter',sans-serif;white-space:nowrap;
}
.nav__list>li>a:hover,.nav__folderbtn:hover{color:var(--orange-d);background:#fbf5ea}
.nav__list>li>a[aria-current="page"]{color:var(--orange-d)}
.nav__folder{position:relative}
.caret{font-size:10px}
.nav__sub{
  position:absolute;top:calc(100% + 6px);left:0;min-width:190px;
  background:#fff;border:1px solid #eee;border-radius:12px;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.25);
  padding:8px;display:none;
}
.nav__folder.open .nav__sub{display:block}
.nav__sub a{display:block;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500}
.nav__sub a:hover{background:#fbf5ea;color:var(--orange-d)}

.header__right{display:flex;align-items:center;gap:14px;margin-left:auto}
.socials{display:flex;align-items:center;gap:10px}
.socials a{color:var(--ink);transition:color .2s,transform .2s}
.socials a svg{width:18px;height:18px;fill:currentColor}
.socials a:hover{color:var(--orange-d);transform:translateY(-2px)}
.socials--header{margin-right:2px}
.header__cta{padding:11px 18px;min-height:42px;font-size:14px}

.menubtn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;width:42px;height:42px}
.menubtn span{display:block;width:22px;height:2px;background:var(--ink);transition:.25s}
.menubtn[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menubtn[aria-expanded="true"] span:nth-child(2){opacity:0}
.menubtn[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mobilemenu{position:fixed;inset:0;z-index:55;background:#fff;padding:96px 24px 32px;overflow-y:auto}
.mobilemenu__list>li{border-bottom:1px solid #eee}
.mobilemenu__list>li>a,.mobilemenu__grpbtn{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:16px 4px;font-size:18px;font-weight:600;font-family:'Fraunces',serif;
  background:none;border:none;cursor:pointer;color:var(--ink);text-align:left;
}
.mobilemenu__sub{padding:0 0 10px 10px;display:none}
.mobilemenu__group.open .mobilemenu__sub{display:block}
.mobilemenu__group.open .mobilemenu__grpbtn .caret{transform:rotate(180deg)}
.mobilemenu__sub a{display:block;padding:11px 6px;font-size:15px;font-weight:500;color:var(--muted)}
.mobilemenu__cta{margin-top:24px;width:100%}
.mobilemenu__socials{margin-top:26px;gap:20px}
.mobilemenu__socials a svg{width:22px;height:22px}

/* =====================
   HERO — dark editorial
   ===================== */
.hero{
  background:var(--ink);
  overflow:hidden;
  padding:68px 0 76px;
}
.hero__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:52px;
  align-items:center;
}

/* Hero copy — all text on ink bg */
.hero__h1{
  font-size:clamp(2.8rem,6.4vw,5.2rem);
  font-weight:700;
  letter-spacing:-.03em;
  line-height:1.02;
  color:#fff;
  margin:0 0 22px;
}
.hero__sub{
  font-size:clamp(1rem,1.4vw,1.18rem);
  color:#a8a8a8;
  max-width:44ch;
  margin:0 0 32px;
  line-height:1.65;
}
.hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  align-items:center;
}

/* Text-link secondary CTA — breaks the dual-pill pattern */
.hero__textcta{
  font-family:'Inter',sans-serif;
  font-size:15px;
  font-weight:600;
  color:#e0e0e0;
  border-bottom:2px solid rgba(245,160,0,.45);
  padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.hero__textcta:hover{color:var(--orange);border-color:var(--orange)}

/* Stats bar */
.hero__stats{
  display:flex;
  flex-wrap:wrap;
  gap:28px;
  margin-top:46px;
  padding-top:22px;
  border-top:1px solid rgba(255,255,255,.12);
}
.hero__stats li{display:flex;flex-direction:column;min-width:0}
.hero__stats strong{
  font-family:'Fraunces',serif;
  font-size:1.2rem;
  font-weight:600;
  color:#fff;
}
.hero__stats span{font-size:12px;color:#888}

/* Hero media — raw image, no card frame */
.hero__media{
  position:relative;
  min-width:0;
  isolation:isolate;
}
.hero__img{
  width:100%;
  display:block;
  border-radius:14px;
  object-fit:cover;
  object-position:50% 45%;
  aspect-ratio:1/1;
  position:relative;
  z-index:1;
}

/* Decorative blobs sit BEHIND the image */
.blob{
  position:absolute;
  border-radius:50%;
  z-index:0;
  pointer-events:none;
}
.blob--orange{
  width:148px;height:148px;
  background:var(--orange);
  top:-28px;right:-6px;
  opacity:.88;
}
.blob--red{
  width:98px;height:98px;
  background:var(--red);
  bottom:-22px;left:-6px;
  opacity:.86;
}

/* Section headings */
.sec-head{padding-top:78px;padding-bottom:18px;max-width:760px}
.sec-head--row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;max-width:none;flex-wrap:wrap}
.sec-label{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--orange-d);margin:0 0 12px;
  display:inline-flex;align-items:center;gap:8px;
}
.sec-label::before{content:"";width:26px;height:3px;background:var(--orange);border-radius:3px}
.sec-label--light{color:#ffd57a}
.sec-label--light::before{background:#ffd57a}
.sec-title{font-size:clamp(1.9rem,4vw,3rem);font-weight:600;letter-spacing:-.02em}
.reslink{font-weight:600;color:var(--ink);border-bottom:2px solid var(--orange);padding-bottom:3px;white-space:nowrap}
.reslink:hover{color:var(--orange-d)}

/* Spreads */
.spreads{padding-bottom:30px}
.spread{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  align-items:center;
  padding-top:56px;
  padding-bottom:56px;
}
.spread__media{position:relative;min-width:0}
.spread__media img{
  width:100%;
  border-radius:22px;
  box-shadow:0 30px 60px -28px rgba(0,0,0,.28);
}

/* Advocacy now image-RIGHT; both img-right spreads use these orders */
.spread--img-right .spread__body{order:1}
.spread--img-right .spread__media{order:2}

/* Decorative dots on spread images */
.dot{position:absolute;border-radius:50%;z-index:-1}
.dot--lav{width:180px;height:180px;background:var(--lav);top:-28px;left:-28px}
/* dot--pink: left side, safe from right-edge overflow */
.dot--pink{width:170px;height:170px;background:var(--pink);bottom:-26px;left:-26px;opacity:.7}

.spread__body{min-width:0}
.spread__num{
  font-size:12px;font-weight:700;letter-spacing:.1em;
  color:var(--orange-d);text-transform:uppercase;margin:0 0 10px;
}
.spread__title{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:600;margin-bottom:14px}
.spread__lead{font-size:1.08rem;color:var(--muted);max-width:46ch;margin:0 0 22px}

/* Innovations shapes block */
.spread--accent .spread__media--shapes{
  position:relative;aspect-ratio:1/1;border-radius:22px;
  background:linear-gradient(135deg,#fff 0%,var(--lav) 100%);
  overflow:hidden;box-shadow:0 30px 60px -30px rgba(0,0,0,.2);
  display:flex;align-items:center;justify-content:center;
}
.bigblob{position:absolute;border-radius:50%}
.bigblob--orange{width:46%;height:46%;background:var(--orange);top:8%;right:10%;opacity:.92}
.bigblob--red{width:24%;height:24%;background:var(--red);bottom:14%;left:14%}
.bigblob--lav{width:30%;height:30%;background:var(--pink);bottom:-6%;right:-4%;opacity:.85}
.bigblob--blue{width:34%;height:34%;background:var(--blue);top:-6%;left:-4%}
.shapeword{
  position:relative;z-index:2;
  font-family:'Fraunces',serif;font-weight:700;font-size:clamp(1.6rem,4vw,2.4rem);
  color:var(--ink);background:#fff;padding:10px 22px;border-radius:50px;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.25);
}

/* Accordion */
.acc__item{border-top:1px solid #e4e4e4}
.acc__item:last-child{border-bottom:1px solid #e4e4e4}
.acc__btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 4px;background:none;border:none;cursor:pointer;text-align:left;
  font-family:'Inter',sans-serif;font-size:1.02rem;font-weight:600;color:var(--ink);
}
.acc__btn:hover{color:var(--orange-d)}
.acc__icon{position:relative;flex:0 0 auto;width:18px;height:18px}
.acc__icon::before,.acc__icon::after{content:"";position:absolute;background:var(--orange-d);border-radius:2px;transition:transform .25s}
.acc__icon::before{top:8px;left:0;width:18px;height:2px}
.acc__icon::after{top:0;left:8px;width:2px;height:18px}
.acc__btn[aria-expanded="true"] .acc__icon::after{transform:scaleY(0)}
.acc__panel{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc__panel p{margin:0 0 18px;color:var(--muted);max-width:54ch;font-size:.98rem;padding-right:8px}

/* Portfolio / carousel */
.portfolio{background:var(--ink);color:#fff;padding:74px 0 84px;margin-top:40px}
.portfolio__head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.portfolio__title{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:700;margin-bottom:14px}
.portfolio__lead{color:#c9c9c9;max-width:46ch;font-size:1.05rem;margin:0}
.portfolio__controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.carousel__nav{display:flex;gap:8px}
.carousel__btn{
  width:46px;height:46px;border-radius:50%;border:1.5px solid #555;background:transparent;color:#fff;
  font-size:24px;line-height:1;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;
}
.carousel__btn:hover{background:var(--orange);border-color:var(--orange);color:#1a1200}
.carousel__btn:disabled{opacity:.3;cursor:default}
.carousel{margin-top:42px;overflow:hidden}
.carousel__track{display:flex;gap:22px;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}
.case{flex:0 0 auto;width:340px;max-width:84vw}
.case__link{
  display:flex;flex-direction:column;height:100%;min-height:300px;
  background:#1d1d1d;border:1px solid #2c2c2c;border-radius:18px;padding:26px;
  transition:transform .25s,border-color .25s,background .25s;
}
.case__link:hover{transform:translateY(-6px);border-color:var(--orange);background:#222}
.case__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.case__tags span{
  font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  color:#ffd57a;background:rgba(245,160,0,.12);padding:4px 9px;border-radius:50px;
}
.case__title{font-size:1.32rem;font-weight:600;color:#fff;margin:0}
.case__arrow{margin-top:auto;padding-top:22px;font-size:14px;font-weight:600;color:var(--orange);font-family:'Inter',sans-serif}

/* Partners */
.partners{padding:78px 0}
.partners__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.partners__copy{min-width:0}
.partners__title{font-size:clamp(1.9rem,4vw,2.9rem);font-weight:600;margin-bottom:16px}
.partners__lead{font-size:1.1rem;color:var(--muted);max-width:44ch}
.partners__list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.partners__list li{
  background:linear-gradient(135deg,#fff,var(--blue));border:1px solid #dce8ff;
  border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:4px;min-width:0;
}
.partners__list li:nth-child(2){background:linear-gradient(135deg,#fff,var(--lav));border-color:#e0ddf5}
.partners__list li:nth-child(3){background:linear-gradient(135deg,#fff,#ffe9d2);border-color:#ffdcb5}
.partners__list li:nth-child(4){background:linear-gradient(135deg,#fff,var(--pink));border-color:#f5c9e6}
.ct{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;color:var(--ink)}
.partners__list em{font-style:normal;font-size:13px;color:var(--muted)}

/* Resources */
.resources{padding-bottom:60px}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 32px}
.chip{
  font-family:'Inter',sans-serif;font-size:13.5px;font-weight:600;
  padding:9px 16px;border-radius:50px;border:1.5px solid #e0e0e0;background:#fff;color:var(--muted);
  cursor:pointer;transition:.2s;min-height:40px;
}
.chip:hover{border-color:var(--orange);color:var(--orange-d)}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:#fff}
.resgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rescard{
  display:flex;flex-direction:column;min-width:0;
  background:#fff;border:1px solid #ececec;border-radius:18px;padding:26px;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.rescard:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(0,0,0,.28);border-color:#ddd}
.rescard--feat{
  grid-column:span 3;
  background:linear-gradient(135deg,#fff 60%,var(--blue));
  border-color:#d7e6ff;position:relative;
}
.rescard__flag{
  position:absolute;top:22px;right:26px;
  background:var(--orange);color:#1a1200;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:5px 12px;border-radius:50px;
}
.rescard--feat .rescard__title{font-size:clamp(1.5rem,3vw,2.1rem);max-width:24ch}
.rescard--feat .rescard__dek{max-width:80ch}
.rescard__tags{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--orange-d);margin-bottom:12px}
.rescard__title{font-size:1.18rem;font-weight:600;margin-bottom:12px;line-height:1.18}
.rescard__dek{font-size:.95rem;color:var(--muted);margin:0 0 18px;flex:1}
.rescard__more{margin-top:auto;font-weight:600;color:var(--ink);font-size:14px}
.rescard__more:hover{color:var(--orange-d)}
.rescard.is-hidden{display:none}
.resgrid__empty{text-align:center;color:var(--muted);padding:40px 0}

/* CTA band */
.ctaband{background:linear-gradient(135deg,var(--orange) 0%,#ffbf45 100%);padding:74px 0}
.ctaband__inner{text-align:center;max-width:680px;margin:0 auto}
.ctaband__title{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;color:#1a1200}
.ctaband__txt{font-size:1.1rem;color:#3a2800;margin:16px auto 30px;max-width:46ch}
.ctaband__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.ctaband .btn--dark{background:#1a1200;color:#fff;border-color:#1a1200}
.ctaband .btn--dark:hover{background:#000;box-shadow:none}

/* Footer */
.footer{background:#fff;border-top:3px solid var(--ink);padding-top:54px}
.footer__top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:46px}
.footer__brand img{height:clamp(48px,9vw,90px);width:auto}
.footer__cols{display:flex;gap:64px;flex-wrap:wrap}
.footer__col h3{
  font-family:'Inter',sans-serif;font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 16px;
}
.footer__col ul li{margin-bottom:10px}
.footer__col a{font-size:15px;font-weight:500}
.footer__col a:hover{color:var(--orange-d)}

/* Footer bar — clean copyright line, no arbitrary blue box */
.footer__bar{
  border-top:1px solid #eee;
  padding:22px 0 28px;
}
.footer__bar p{margin:0;font-size:13.5px;color:var(--muted)}

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

/* =====================
   RESPONSIVE
   ===================== */
@media (max-width:1080px){
  .nav__list{gap:2px}
  .nav__list>li>a,.nav__folderbtn{padding:9px 9px;font-size:13.5px}
  .header__cta{display:none}
}
@media (max-width:900px){
  .nav,.socials--header{display:none}
  .menubtn{display:flex}
  .header__cta{display:inline-flex}
  .resgrid{grid-template-columns:repeat(2,1fr)}
  .rescard--feat{grid-column:span 2}
}
@media (max-width:760px){
  /* Hero collapses: text above, image below (full bleed) */
  .hero{padding:46px 0 0}
  .hero__grid{grid-template-columns:1fr;gap:0}
  .hero__copy{padding-bottom:42px}
  .hero__media{
    margin-left:calc(-1 * var(--pad));
    margin-right:calc(-1 * var(--pad));
    width:calc(100% + 2 * var(--pad));
    margin-top:0;
  }
  .hero__img{border-radius:0;aspect-ratio:4/3}
  .blob--orange{width:90px;height:90px;top:-16px;right:4px}
  .blob--red{width:65px;height:65px;bottom:-16px;left:4px}

  /* Spreads stack */
  .spread{grid-template-columns:1fr;gap:30px;padding-top:44px;padding-bottom:44px}
  .spread--img-right .spread__body{order:1}
  .spread--img-right .spread__media{order:2}
  .partners__grid{grid-template-columns:1fr;gap:30px}
  .sec-head{padding-top:54px}
  .portfolio__head{align-items:flex-start}
}
@media (max-width:620px){
  .resgrid{grid-template-columns:1fr}
  .rescard--feat{grid-column:span 1}
  .partners__list{grid-template-columns:1fr}
  .header__cta{padding:10px 14px;font-size:13px}
  .case{width:280px}
  .footer__cols{gap:40px}
  .promobar__txt{display:none}
}
@media (max-width:380px){
  :root{--pad:18px}
  .brand__logo{height:22px}
  .header__cta{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}