/* =================================================================
   INSTITUTO NEXUS — FOLHA DE ESTILOS (MOBILE-FIRST)

   COMO FUNCIONA:
   - O estilo BASE (sem media query) é o do CELULAR.
   - Os ajustes para telas maiores entram nos blocos:
       @media (min-width: 768px)  -> tablet
       @media (min-width: 992px)  -> desktop
     que ficam no FINAL do arquivo (seções 13 e 14).

   ÍNDICE:
     1. Variáveis e base
     2. Componentes reutilizáveis (eyebrow, botões)
     3. Navbar + menu mobile
     4. Hero
     5. Sobre
     6. Pilares
     7. Programas
     8. Metodologia
     9. Doação (Colabore conosco)
    10. Parceiros (CTA)
    11. FAQ
    12. Footer
    13. Animação de revelar ao rolar
    14. Responsivo TABLET (min-width:768px)
    15. Responsivo DESKTOP (min-width:992px)
   ================================================================= */

/* ============================================================= */
/* 1. VARIÁVEIS E BASE                                           */
/* ============================================================= */
:root{
  --ink:#0A1F44;        /* tinta naval profunda */
  --blue:#1B43E0;       /* azul cobalto principal */
  --azure:#2E6BFF;      /* azul acento mais claro */
  --sky:#EAF0FF;        /* lavagem azul clara */
  --sky-2:#F5F8FF;      /* lavagem ainda mais clara */
  --mist:#DCE6FF;
  --white:#FFFFFF;
  --warm:#FF6A3D;       /* acento quente (uso pontual) */
  --slate:#5A6B8C;      /* texto secundário */
  --line:#E4EAFB;       /* bordas */
  --shadow:0 24px 60px -24px rgba(10,31,68,.28);
  --shadow-sm:0 12px 30px -16px rgba(10,31,68,.30);
  --radius:22px;
  --display:'Bricolage Grotesque', system-ui, sans-serif;
  --body:'Manrope', system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);letter-spacing:-.02em;line-height:1.06}
p{color:var(--slate);line-height:1.7}
a{text-decoration:none}
::selection{background:var(--blue);color:#fff}

/* container central padrão (mobile) */
.container-x{max-width:1160px;margin-inline:auto;padding-inline:20px}

/* base de seção (mobile) */
section{position:relative}
.sec{padding:60px 0}
.sec-head{max-width:660px;margin-bottom:38px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(1.8rem,7vw,2.9rem);font-weight:800;margin:16px 0 14px}
.sec-head p{font-size:1.02rem}


/* ============================================================= */
/* 2. COMPONENTES REUTILIZÁVEIS (eyebrow + botões)              */
/* ============================================================= */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--blue);background:var(--sky);padding:8px 16px;border-radius:100px;border:1px solid var(--mist)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 4px rgba(27,67,224,.15)}
/* variação clara (sobre fundo azul) */
.eyebrow-light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}
.eyebrow-light .dot{background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.2)}

.btn-nx{font-family:var(--body);font-weight:700;border-radius:100px;padding:14px 26px;border:0;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:.96rem}
.btn-primary-nx{background:var(--blue);color:#fff;box-shadow:0 16px 30px -12px rgba(27,67,224,.6)}
.btn-primary-nx:hover{background:var(--ink);color:#fff;transform:translateY(-3px)}
.btn-ghost-nx{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost-nx:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-3px)}
.btn-nx svg{transition:transform .25s}
.btn-nx:hover svg{transform:translateX(4px)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{background:var(--sky);transform:translateY(-3px)}
.btn-outline-w{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn-outline-w:hover{border-color:#fff;transform:translateY(-3px)}

.hl{color:var(--blue)} /* destaque de texto em azul */


/* ============================================================= */
/* 3. NAVBAR + MENU MOBILE                                       */
/*    Base (mobile): links escondidos, hambúrguer visível.       */
/* ============================================================= */
.nx-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:14px 0;transition:all .35s ease}
.nx-nav.scrolled{padding:9px 0;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line);box-shadow:0 8px 30px -20px rgba(10,31,68,.3)}
.nx-nav .inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:800;font-size:1.18rem;color:var(--ink)}
.brand svg{width:34px;height:34px}

.nav-links{display:none} /* escondido no mobile */
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-cta .btn-nx{display:none} /* botão de doação só aparece no desktop */

/* botão hambúrguer (mobile) */
.burger{display:flex;background:none;border:0;cursor:pointer;width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink)}
.burger span::before{top:-7px}
.burger span::after{top:7px}

/* drawer mobile */
.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;justify-content:center;gap:16px;padding:32px;transform:translateY(-100%);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:var(--display);font-size:1.6rem;font-weight:700;color:var(--ink)}
.mobile-menu .mm-cta{color:var(--blue)}


/* ============================================================= */
/* 4. HERO                                                       */
/* ============================================================= */
.hero{position:relative;padding:120px 0 50px;overflow:hidden}
#nexus-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0} /* rede animada (index.js) */
.hero-bg{position:absolute;inset:0;z-index:-1;
  background:radial-gradient(900px 600px at 80% -5%, rgba(46,107,255,.16), transparent 60%),
    radial-gradient(700px 500px at 5% 20%, rgba(27,67,224,.10), transparent 55%),
    linear-gradient(180deg,#fff 0%, var(--sky-2) 100%)}
.hero .container-x{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1fr;gap:36px;align-items:center}
.hero h1{font-size:clamp(2.2rem,9vw,4.4rem);font-weight:800;margin:18px 0 0}
.hero h1 .grad{background:linear-gradient(105deg,var(--blue),var(--azure) 60%,var(--ink));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:1.08rem;max-width:520px;margin:20px 0 30px}
.hero-actions{display:flex;flex-direction:column;gap:12px}
.hero-actions .btn-nx{width:100%} /* botões full width no mobile */

/* card visual do hero */
.hero-card{position:relative;background:#fff;border-radius:var(--radius);padding:8px;box-shadow:var(--shadow);border:1px solid var(--line);max-width:460px;margin-inline:auto}
.hero-card .frame{border-radius:16px;overflow:hidden;height:320px;position:relative;background:linear-gradient(160deg,var(--ink),var(--blue))}
.hero-card .frame .glow{position:absolute;inset:0;background:radial-gradient(400px 300px at 30% 20%, rgba(255,255,255,.22),transparent 60%)}
.people-net{position:absolute;inset:0}
.pn-node{position:absolute;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.14);
  border:1.5px solid rgba(255,255,255,.5);display:grid;place-items:center;color:#fff;backdrop-filter:blur(4px)}
.float-badge{position:absolute;background:#fff;border-radius:100px;padding:10px 16px;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);display:flex;align-items:center;gap:9px;font-weight:700;font-size:.85rem;color:var(--ink)}
.float-badge .d{width:9px;height:9px;border-radius:50%;background:var(--blue)}
.fb-1{top:18px;left:-10px;animation:float 6s ease-in-out infinite}
.fb-2{bottom:20px;right:-10px;animation:float 6s ease-in-out infinite .8s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}


/* ============================================================= */
/* 5. SOBRE                                                      */
/* ============================================================= */
.sobre-grid{display:grid;grid-template-columns:1fr;gap:36px;align-items:center}
.sobre-title{font-size:clamp(1.7rem,6vw,2.7rem);font-weight:800;margin:16px 0 14px}
.sobre-visual{position:relative;border-radius:var(--radius);overflow:hidden;min-height:340px;
  background:linear-gradient(150deg,var(--sky),#fff);border:1px solid var(--line);box-shadow:var(--shadow-sm);display:grid;place-items:center;padding:24px}
.ring{position:absolute;border-radius:50%;border:1.5px solid var(--mist)}
.r1{width:320px;height:320px}.r2{width:220px;height:220px}.r3{width:130px;height:130px}
.core-badge{position:relative;z-index:2;background:var(--blue);color:#fff;width:112px;height:112px;border-radius:50%;
  display:grid;place-items:center;text-align:center;font-family:var(--display);font-weight:800;font-size:.88rem;box-shadow:0 20px 40px -16px rgba(27,67,224,.7)}
.orbit-chip{position:absolute;background:#fff;border:1px solid var(--line);border-radius:100px;padding:7px 13px;
  font-weight:700;font-size:.78rem;color:var(--ink);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:7px}
.orbit-chip .d{width:7px;height:7px;border-radius:50%;background:var(--blue)}
.oc1{top:24px;left:16px}.oc2{top:48px;right:12px}.oc3{bottom:44px;left:28px}.oc4{bottom:24px;right:26px}
.sobre-list{list-style:none;padding:0;margin:24px 0 0}
.sobre-list li{display:flex;gap:13px;margin-bottom:15px;align-items:flex-start}
.sobre-list .chk{flex:0 0 auto;width:26px;height:26px;border-radius:8px;background:var(--sky);color:var(--blue);display:grid;place-items:center;margin-top:2px}
.sobre-list b{color:var(--ink)}


/* ============================================================= */
/* 6. PILARES                                                    */
/* ============================================================= */
.pilares{background:linear-gradient(180deg,#fff,var(--sky-2))}
.cards-4{display:grid;grid-template-columns:1fr;gap:18px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;
  transition:transform .35s,box-shadow .35s,border-color .35s;position:relative;overflow:hidden}
.pcard::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,var(--blue),var(--azure));opacity:0;transition:.35s}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.pcard:hover::before{opacity:1}
.pcard:hover *{color:#fff !important;position:relative;z-index:2}
.pcard:hover .picon{background:rgba(255,255,255,.2)}
.picon{width:54px;height:54px;border-radius:16px;background:var(--sky);color:var(--blue);display:grid;place-items:center;margin-bottom:18px;transition:.35s}
.pcard h3{font-size:1.24rem;font-weight:700;margin-bottom:10px}
.pcard p{font-size:.95rem;margin:0}


/* ============================================================= */
/* 7. PROGRAMAS                                                  */
/* ============================================================= */
.prog-grid{display:grid;grid-template-columns:1fr;gap:18px}
.prog{border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:#fff;
  transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.prog:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.prog .pic{flex:0 0 auto;width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,var(--blue),var(--ink))}
/* gradiente diferente por card (visual) */
.prog:nth-child(2) .pic{background:linear-gradient(150deg,var(--azure),var(--blue))}
.prog:nth-child(3) .pic{background:linear-gradient(150deg,var(--ink),#16306b)}
.prog:nth-child(4) .pic{background:linear-gradient(150deg,#16306b,var(--azure))}
.prog h3{font-size:1.2rem;font-weight:700;margin-bottom:8px}
.prog p{font-size:.94rem;margin:0}


/* ============================================================= */
/* 8. METODOLOGIA                                                */
/* ============================================================= */
.metodo{background:linear-gradient(180deg,var(--sky-2),#fff)}
.steps{display:grid;grid-template-columns:1fr;gap:22px}
.step{padding-top:22px}
.step .bar{height:4px;border-radius:100px;background:var(--mist);margin-bottom:18px;position:relative;overflow:hidden}
.step .bar i{position:absolute;left:0;top:0;bottom:0;background:var(--blue);border-radius:100px}
.step .nstep{font-family:var(--display);font-weight:800;color:var(--blue);font-size:1.05rem;margin-bottom:8px}
.step h3{font-size:1.16rem;font-weight:700;margin-bottom:8px}
.step p{font-size:.92rem;margin:0}


/* ============================================================= */
/* 9. DOAÇÃO (Colabore conosco)                                  */
/* ============================================================= */
.donate-grid{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.donate-title{font-size:clamp(1.7rem,6vw,2.7rem);font-weight:800;margin:16px 0 14px}
.donate-list{list-style:none;padding:0;margin:22px 0 0}
.donate-list li{display:flex;gap:12px;margin-bottom:13px;align-items:flex-start;color:var(--ink);font-weight:600;font-size:.96rem}
.donate-list .chk{flex:0 0 auto;width:24px;height:24px;border-radius:7px;background:var(--sky);color:var(--blue);display:grid;place-items:center}

/* card de doação */
.donate-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow)}
.donate-card-title{font-size:1.15rem;font-weight:700;margin:0 0 18px}

/* botões de valor */
.amount-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
.amount-btn{font-family:var(--body);font-weight:700;font-size:1rem;color:var(--ink);background:var(--sky-2);
  border:1.5px solid var(--line);border-radius:14px;padding:14px 0;cursor:pointer;transition:.2s}
.amount-btn:hover{border-color:var(--blue);color:var(--blue)}
.amount-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 10px 22px -10px rgba(27,67,224,.6)}

/* campo de valor personalizado (escondido até clicar em "Outro") */
.amount-input{display:none;width:100%;border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;
  font-family:var(--body);font-size:1rem;outline:none;margin-bottom:12px;transition:.2s}
.amount-input.show{display:block}
.amount-input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(27,67,224,.12)}

.donate-btn{width:100%;margin-top:4px}

/* divisor "ou doe via PIX" */
.donate-divider{display:flex;align-items:center;gap:12px;margin:22px 0 16px;color:var(--slate);font-size:.85rem;font-weight:600}
.donate-divider::before,.donate-divider::after{content:"";flex:1;height:1px;background:var(--line)}

/* área PIX */
.pix-box{border:1.5px dashed var(--mist);border-radius:16px;padding:16px;background:var(--sky-2)}
.pix-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.pix-info{display:flex;flex-direction:column}
.pix-label{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--slate)}
.pix-key{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1rem;word-break:break-all}
.pix-copy{flex:0 0 auto;background:var(--blue);color:#fff;border:0;border-radius:10px;padding:9px 16px;font-family:var(--body);font-weight:700;font-size:.85rem;cursor:pointer;transition:.2s}
.pix-copy:hover{background:var(--ink)}
.pix-copy.copied{background:#1aa179}
.qr-box{margin-top:14px;border:1.5px solid var(--line);border-radius:12px;background:#fff;min-height:120px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--slate);font-weight:600;font-size:.9rem;text-align:center;padding:16px}
.qr-box small{font-weight:500;font-size:.78rem;opacity:.8}
.qr-box canvas{border-radius:8px;max-width:200px;height:auto}
.pix-cc-copy{background:#fff;border:1.5px solid var(--line);color:var(--blue);border-radius:10px;padding:9px 16px;
  font-family:var(--body);font-weight:700;font-size:.82rem;cursor:pointer;transition:.2s}
.pix-cc-copy:hover{border-color:var(--blue);background:var(--sky-2)}
.pix-cc-copy.copied{background:#1aa179;color:#fff;border-color:#1aa179}

.donate-note{margin:14px 0 0;font-size:.82rem;color:var(--slate);text-align:center}


/* ============================================================= */
/* 10. PARCEIROS (CTA)                                           */
/* ============================================================= */
.partner-box{background:linear-gradient(140deg,var(--blue),var(--ink));border-radius:28px;color:#fff;padding:40px 26px;
  display:grid;grid-template-columns:1fr;gap:30px;align-items:center;position:relative;overflow:hidden}
.partner-box::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;border:40px solid rgba(255,255,255,.06)}
.partner-box .partner-title{color:#fff;font-size:clamp(1.7rem,6vw,2.6rem);font-weight:800;margin:16px 0 12px}
.partner-box p{color:rgba(255,255,255,.8);font-size:1.02rem;max-width:520px}
.partner-box .acts{display:flex;flex-direction:column;gap:12px;position:relative;z-index:2}


/* ============================================================= */
/* 11. FAQ                                                       */
/* ============================================================= */
.faq-sec{background:linear-gradient(180deg,#fff,var(--sky-2))}
.faq-grid{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
.faq-title{font-size:clamp(1.7rem,6vw,2.7rem);font-weight:800;margin:16px 0 14px}
.accordion-item{border:1px solid var(--line) !important;border-radius:16px !important;margin-bottom:12px;overflow:hidden}
.accordion-button{font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.02rem;padding:20px 22px;background:#fff}
.accordion-button:not(.collapsed){color:var(--blue);background:var(--sky-2);box-shadow:none}
.accordion-button:focus{box-shadow:none;border-color:var(--line)}
.accordion-button::after{background-image:none;content:"+";font-size:1.6rem;width:auto;height:auto;font-family:var(--body);font-weight:400;transform:none}
.accordion-button:not(.collapsed)::after{content:"–"}
.accordion-body{padding:4px 22px 22px;color:var(--slate);line-height:1.7}


/* ============================================================= */
/* 12. FOOTER                                                    */
/* ============================================================= */
footer{background:var(--ink);color:#fff;padding:56px 0 26px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:34px}
.foot-grid h4{font-family:var(--display);font-size:.88rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:16px;font-weight:700}
.foot-grid a,.foot-grid p{color:rgba(255,255,255,.78);display:block;margin-bottom:11px;font-size:.94rem;transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:800;font-size:1.3rem;margin-bottom:16px}
.foot-about{max-width:320px}
.foot-cta{color:#fff;font-weight:700}
.foot-socials{display:flex;gap:12px;margin-top:18px}
.foot-socials a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;margin:0}
.foot-socials a:hover{background:var(--blue)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;display:flex;flex-direction:column;gap:10px}
.foot-bottom p{color:rgba(255,255,255,.5);font-size:.83rem;margin:0}


/* ============================================================= */
/* 13. ANIMAÇÃO DE REVELAR AO ROLAR                              */
/* (classe .reveal é ativada pelo IntersectionObserver no JS)    */
/* ============================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}


/* ============================================================= */
/* 14. RESPONSIVO — TABLET (min-width: 768px)                    */
/* ============================================================= */
@media (min-width:768px){
  .container-x{padding-inline:24px}
  .sec{padding:80px 0}
  .sec-head{margin-bottom:48px}

  .hero-actions{flex-direction:row}
  .hero-actions .btn-nx{width:auto}

  .cards-4{grid-template-columns:repeat(2,1fr);gap:22px}
  .prog-grid{grid-template-columns:repeat(2,1fr);gap:22px}
  .prog{flex-direction:row;gap:20px;align-items:flex-start}
  .steps{grid-template-columns:repeat(2,1fr);gap:24px}
  .amount-grid{grid-template-columns:repeat(4,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-bottom{flex-direction:row;justify-content:space-between;flex-wrap:wrap;gap:14px}
}


/* ============================================================= */
/* 15. RESPONSIVO — DESKTOP (min-width: 992px)                   */
/* ============================================================= */
@media (min-width:992px){
  .sec{padding:90px 0}
  .nx-nav{padding:18px 0}
  .brand{font-size:1.35rem}
  .brand svg{width:40px;height:40px}

  /* menu desktop aparece, hambúrguer some */
  .nav-links{display:flex;align-items:center;gap:32px;list-style:none;margin:0;padding:0}
  .nav-links a{color:var(--ink);font-weight:600;font-size:.96rem;position:relative;opacity:.85;transition:opacity .2s}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--blue);transition:width .3s}
  .nav-links a:hover{opacity:1}
  .nav-links a:hover::after{width:100%}
  .nav-cta .btn-nx{display:inline-flex}
  .burger{display:none}

  .hero{padding:160px 0 90px}
  .hero-grid{grid-template-columns:1.1fr .9fr;gap:56px}
  .hero-card{max-width:none;margin-inline:0}
  .hero-card .frame{height:400px}
  .pn-node{width:54px;height:54px}
  .fb-1{left:-22px;top:26px}
  .fb-2{right:-22px;bottom:30px}

  .sobre-grid{grid-template-columns:1fr 1fr;gap:60px}
  .sobre-visual{min-height:420px;padding:30px}
  .r1{width:400px;height:400px}.r2{width:280px;height:280px}.r3{width:160px;height:160px}
  .core-badge{width:128px;height:128px;font-size:.95rem}
  .orbit-chip{padding:9px 16px;font-size:.85rem}
  .oc1{top:40px;left:30px}.oc2{top:64px;right:24px}.oc3{bottom:56px;left:46px}.oc4{bottom:36px;right:40px}

  .cards-4{grid-template-columns:repeat(4,1fr);gap:24px}
  .prog-grid{gap:24px}
  .prog{padding:32px}
  .steps{grid-template-columns:repeat(4,1fr)}

  .donate-grid{grid-template-columns:1fr 1fr;gap:48px}
  .donate-card{padding:34px}

  .partner-box{grid-template-columns:1.3fr .7fr;gap:40px;padding:64px 56px;border-radius:34px}

  .faq-grid{grid-template-columns:.8fr 1.2fr;gap:54px}
  .accordion-button{font-size:1.06rem;padding:22px 24px}

  .foot-grid{grid-template-columns:1.6fr 1fr 1fr;gap:40px}
}
