
:root{
  --bg:#ffffff;
  --surface:#ffffff;
  --card:#ffffff;

  --text:#0b1416;
  --muted:rgba(11,20,22,.70);
  --muted2:rgba(11,20,22,.55);
  --line:rgba(11,20,22,.12);

  --primary:#24ca68;
  --primary2:#1aa85a;
  --accent:#2f7bd9;

  --radius:18px;
  --shadow:0 12px 40px rgba(0,0,0,.10);

  --container:1120px;
  --font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans","Liberation Sans",sans-serif;
}

*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(36,202,104,.10), transparent 55%),
    radial-gradient(1200px 600px at 90% 0%, rgba(47,123,217,.10), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, #f7fbff 55%, #ffffff 100%);
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(var(--container),calc(100% - 40px));margin:0 auto}
.muted{color:var(--muted)}
.fineprint{color:var(--muted2);font-size:.92rem;line-height:1.55}
.w-100{width:100%}

.btn{
  border:1px solid transparent;
  background:transparent;
  color:var(--text);
  padding:12px 14px;
  border-radius:999px;
  font-weight:650;
  letter-spacing:.2px;
  cursor:pointer;
  transition:transform .08s ease,background .18s ease,border-color .18s ease,opacity .18s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(180deg,var(--primary),var(--primary2));
  border-color:rgba(255,255,255,.06);
  box-shadow:0 10px 22px rgba(36,202,104,.18);
}
.btn-primary:hover{opacity:.95;text-decoration:none}
.btn-outline{
  border-color:#e5e7eb;
  background:#ffffff;
}
.btn-outline:hover{background:#f3f4f6;text-decoration:none}

.btn-ghost{
  border-color:#e5e7eb;
  background:transparent;
}
.btn-ghost:hover{background:#f3f4f6;text-decoration:none}

.btn-ghost:hover{background:rgba(255,255,255,.06);text-decoration:none}

.site-header{
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,.85);
  border-bottom:1px solid var(--line);
  box-shadow: 0 4px 12px rgba(0,0,0,.04);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:20px 0; /* antes era 14px */
}

.brand{display:flex;align-items:center;gap:10px}
.brand-mark{font-size:22px}
.brand-text strong{display:block;font-size:1rem;line-height:1.1}
.brand-text small{display:block;font-size:.82rem;color:var(--muted);margin-top:2px}

.nav{display:flex;align-items:center;gap:12px}
.nav-link{
  color:var(--muted);
  font-weight:600;
  padding:10px 10px;
  border-radius:999px;
}
.nav-link:hover{background:rgba(255,255,255,.05);color:var(--text);text-decoration:none}
.nav-donate{margin-left:6px}

.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:12px;
  border:1px solid #e5e7eb;
  background:#ffffff;
  cursor:pointer;
}

.nav-toggle span{
  display:block;
  height:2px;
  margin:7px 10px;
  background:#0b1416; /* linhas escuras para aparecer no branco */
  border-radius:2px
}

.mobile-menu{
  border-top:1px solid #e5e7eb;
  background:linear-gradient(180deg,#ffffff,#f9fafb);
}
.mobile-menu-inner{padding:14px 0 18px;display:grid;gap:10px}
.mobile-link{
  padding:12px 14px;
  border-radius:14px;
  background:#ffffff;
  border:1px solid #e5e7eb;
  color:#0b1416;
}
.mobile-link:hover{
  background:#f3f4f6;
  text-decoration:none
}
.mobile-link:hover{background:rgba(255,255,255,.06);text-decoration:none}

.hero{padding:64px 0 26px}
.hero-grid{
  display:grid;
  grid-template-columns:1.25fr .9fr;
  gap:22px;
  align-items:stretch;
}
.hero-card{
  border: 1px solid #e5e7eb;
  background: linear-gradient(
    180deg,
    #ffffff,
    #f3f4f6
  );
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  padding: 22px;
}
.hero h1{margin:0 0 10px;font-size:clamp(1.9rem,2.8vw,3rem);line-height:1.12}
.hero p{margin:0 0 16px;color:var(--muted);font-size:1.05rem;line-height:1.6}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px}

.hero-highlights{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:18px;
}
.kpi{
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
}
.kpi strong{display:block;font-size:1.05rem}
.kpi span{display:block;font-size:.85rem;color:var(--muted);margin-top:2px}

.visual{display:flex;flex-direction:column;gap:12px}
.image-ph{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(500px 250px at 30% 30%, rgba(36,202,104,.22), transparent 55%),
    radial-gradient(500px 250px at 70% 70%, rgba(47,123,217,.22), transparent 55%),
    rgba(255,255,255,.03);
  min-height:220px;
  position:relative;
  overflow:hidden;
}
.ph-tag{
  position:absolute;top:14px;left:14px;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.12);
  font-weight:650;
  color:rgba(255,255,255,.92);
}
.box{
  border-radius: var(--radius);
  border: 1px solid #e5e7eb;
  background: #ffffff;
  padding: 16px;
}
.progress{display:grid;gap:10px}
.progress-top{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.progress-top strong{font-size:1.1rem}
.bar{
  height:12px;
  background:#e5e7eb;          /* trilho cinza claro */
  border-radius:999px;
  overflow:hidden;
}

.bar > div{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,var(--primary),var(--primary2)); /* verde */
  border-radius:999px;
  transition:width .6s ease;
}

.section{padding:26px 0}
.section h2{font-size:1.6rem;margin:0 0 10px}
.section p{margin:0 0 10px;color:var(--muted);line-height:1.65}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}

.card{
  border-radius: var(--radius);
  border: 1px solid #e5e7eb;
  background: linear-gradient(
    180deg,
    #ffffff,
    #f9fafb
  );
  padding: 16px;
}
.card h3{margin:0 0 6px;font-size:1.05rem}
.card p{margin:0;color:var(--muted)}

.amount-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.amount-card strong{display:block;font-size:1.05rem}
.amount-card p{margin:6px 0 0}

.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-top:12px}
.g{
  aspect-ratio:1/1;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  position:relative;
  overflow:hidden;
}

.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.quote{
  border-radius: var(--radius);
  border: 1px solid #e5e7eb;
  background: #ffffff;
  padding: 16px;
}
.quote p{margin:0 0 10px;color:#0b1416;line-height:1.65}
.who{color:var(--muted);font-weight:650}

.faq{margin-top:10px;display:grid;gap:10px}
details{
  border-radius:var(--radius);
  border:1px solid #e5e7eb;
  background:#ffffff;
  padding:12px 14px;
}
summary{
  cursor:pointer;
  font-weight:750;
  color:#0b1416;
  list-style:none;
}
summary::-webkit-details-marker{display:none}
details p{margin:10px 0 0}

.site-footer{
  border-top:1px solid var(--line);
  background:rgba(255,255,255,.70);
}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:16px}
.footer-brand{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.footer-links{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:8px}
.footer-links a{color:var(--muted)}
.footer-links a:hover{color:var(--text)}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.badge{font-size:.78rem;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--muted)}
.footer-bottom{padding-top:14px;margin-top:14px;border-top:1px solid rgba(255,255,255,.08)}

.sticky-donate{position:fixed;left:14px;right:14px;bottom:14px;z-index:60;display:none}

.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:80}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.62)}
.modal-card{
  position:relative;
  width:min(920px,calc(100% - 28px));
  margin:6vh auto 0;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(16,35,39,.92),rgba(16,35,39,.75));
  box-shadow:var(--shadow);
  padding:18px;
}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.92);
  cursor:pointer;
  font-size:22px;
  line-height:1;
}
.modal-title{margin:6px 0 6px;font-size:1.45rem}
.label{font-weight:750;display:block;margin-bottom:6px;color:rgba(255,255,255,.9)}

.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.amt{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.95);
  padding:12px;
  font-weight:850;
  cursor:pointer;
}
.amt:hover{background:rgba(255,255,255,.06)}
.chip{
  display:inline-block;margin-left:8px;
  padding:5px 8px;border-radius:999px;
  font-size:.72rem;
  background:rgba(36,202,104,.16);
  border:1px solid rgba(36,202,104,.28);
}

.custom-amount{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.10)}
.custom-row{display:flex;gap:10px;align-items:center}
.currency{font-weight:900;color:rgba(255,255,255,.92)}
#customAmount{
  flex:1;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.92);
  outline:none;
}
#customAmount:focus{border-color:rgba(36,202,104,.55)}
.share-row{margin-top:12px}

.pix-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}
.pix-amount{padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10)}
.pix-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
.qr-box{
  width:100%;
  min-height:240px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.qr-box img{width:220px;height:220px}
.pix-code textarea{
  width:100%;
  resize:none;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.92);
  outline:none;
}
.pix-rec{
  margin-top:12px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}
.pix-rec .title{margin:0 0 10px;font-weight:800}
.rec-row{display:flex;justify-content:space-between;gap:10px;margin-top:8px;color:var(--muted)}
.rec-row strong{color:rgba(255,255,255,.92)}

.toast{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:78px;
  background:rgba(0,0,0,.65);
  border:1px solid rgba(255,255,255,.14);
  padding:10px 12px;
  border-radius:999px;
  box-shadow:var(--shadow);
  z-index:90;
}

.page{padding:34px 0 18px}
.page h1{margin:0 0 10px;font-size:2rem}
.page h2{margin:18px 0 8px;font-size:1.25rem}
.page p{margin:0 0 10px;color:var(--muted);line-height:1.7}
.form{
  display:grid;gap:10px;margin-top:10px;
}
.input, .textarea{
  width:100%;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.92);
  outline:none;
}
.textarea{min-height:130px;resize:vertical}
.input:focus,.textarea:focus{border-color:rgba(47,123,217,.55)}

@media (max-width: 960px){
  .hero-grid{grid-template-columns:1fr;gap:14px}
  .grid-3{grid-template-columns:1fr}
  .amount-cards{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .nav{display:none}
  .nav-toggle{display:block}
  .sticky-donate{display:block}
  .pix-grid{grid-template-columns:1fr}
}



/* ==== Media (Fotos reais) ==== */
.hero-visual{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}
.hero-visual .hv{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 16px 40px rgba(0,0,0,.28);
  min-height: 220px;
}
.hero-visual .hv img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-visual .hv::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.45) 100%);
  pointer-events:none;
}
@media (min-width: 860px){
  .hero-visual{ grid-template-columns: 1fr; }
  .hero-visual .hv--primary{ min-height: 420px; }
  .hero-visual .hv--secondary{ min-height: 220px; }
}

/* ==== Galeria com imagens ==== */
.gallery .g{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.gallery .g img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.gallery .g::after{ display:none; }

/* ==== Imagem de destaque nas páginas ==== */
.page-hero{
  margin: 6px 0 22px;
}
.page-hero__media{
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  aspect-ratio: 16 / 7;
}
.page-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
@media (max-width: 640px){
  .page-hero__media{ aspect-ratio: 16 / 10; }
}

/* ===== LOGO (controle de tamanho) ===== */

.brand-logo{
  height: 52px;   /* antes 44px */
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
}

/* em telas menores, diminui */
@media (max-width: 960px){
  .brand-logo{
    height: 44px;      /* antes 36px */
    max-width: 170px;
  }
}

/* ===== Cards arrastáveis no mobile ===== */
@media (max-width: 960px){
  .cards-scroll{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 85%;
    gap: 12px;

    overflow-x: auto;
    padding-bottom: 10px;

    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .cards-scroll > .card{
    scroll-snap-align: start;
  }

  /* barra de rolagem discreta (opcional) */
  .cards-scroll::-webkit-scrollbar{
    height: 6px;
  }
  .cards-scroll::-webkit-scrollbar-thumb{
    background: rgba(0,0,0,.2);
    border-radius: 999px;
  }
}

/* ===== Stack de valores (mobile) ===== */
@media (max-width: 960px){
  .amount-stack{
    position: relative;
    cursor: pointer;
  }

  /* cards ficam empilhados (um em cima do outro) no estado fechado */
  .amount-stack:not(.is-open){
    display: block;              /* sobrescreve o grid no mobile */
    max-height: 190px;           /* mostra só a altura do 1º card */
    overflow: hidden;
    padding-bottom: 14px;
  }

  /* todos os cards viram "camadas" */
  .amount-stack:not(.is-open) .amount-card{
    position: relative;
  }

  /* 1º card: fica na frente e com sombra forte (efeito "clique aqui") */
  .amount-stack:not(.is-open) .amount-card:first-child{
    z-index: 5;
    box-shadow: 0 18px 40px rgba(0,0,0,.16);
    transform: translateY(0);
  }

  /* 2º e 3º: aparecem "atrás", deslocados pra baixo e com sombra menor */
  .amount-stack:not(.is-open) .amount-card:nth-child(2){
    margin-top: -120px;          /* puxa para trás do 1º */
    z-index: 4;
    transform: translateY(14px) scale(.985);
    opacity: .96;
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
  }

  .amount-stack:not(.is-open) .amount-card:nth-child(3){
    margin-top: -120px;          /* mantém o empilhamento */
    z-index: 3;
    transform: translateY(28px) scale(.975);
    opacity: .92;
    box-shadow: 0 6px 18px rgba(0,0,0,.06);
  }

  /* do 4º em diante: escondidos totalmente no estado fechado */
  .amount-stack:not(.is-open) .amount-card:nth-child(n+4){
    display: none;
  }

  /* brilho/sombra extra no 1º card para induzir clique */
  .amount-stack:not(.is-open) .amount-card:first-child::after{
    content:"";
    position:absolute;
    inset:-1px;
    border-radius: var(--radius);
    pointer-events:none;
    box-shadow:
      0 0 0 1px rgba(36,202,104,.18) inset,   /* brilho interno */
      0 24px 48px rgba(36,202,104,.12);       /* glow externo */
    opacity: .9;
  }

  /* gradiente embaixo indicando que tem mais */
  .amount-stack:not(.is-open)::after{
    content:"";
    position:absolute;
    left:0; right:0; bottom:0;
    height: 70px;
    background: linear-gradient(180deg, rgba(255,255,255,0), #ffffff);
    pointer-events:none;
    z-index: 6;
  }

  .stack-hint{
    display: inline-block;
    margin-top: 8px;
    font-size: .85rem;
    color: var(--muted);
    font-weight: 650;
  }

  /* ABERTO: volta para lista normal */
  .amount-stack.is-open{
    display: grid;                 /* volta ao grid */
    grid-template-columns: 1fr;    /* no mobile, 1 coluna */
    gap: 12px;
    max-height: none;
    overflow: visible;
    padding-bottom: 0;
  }

  .amount-stack.is-open .amount-card{
    position: static;
    margin-top: 0;
    transform: none;
    opacity: 1;
    box-shadow: none;              /* ou mantenha o padrão do .card */
    display: block;
  }

  .amount-stack.is-open::after{
    display:none;
  }
}

/* ===== Carrossel da Galeria (drag/swipe + “peek” das próximas) ===== */
.gallery-carousel{
  margin-top: 12px;
  position: relative;
}

/* trilho */
.gallery-track{
  display: grid;
  grid-auto-flow: column;
  gap: 12px;

  overflow-x: auto;
  padding: 6px 18px 12px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;

  scrollbar-width: none;
}
.gallery-track::-webkit-scrollbar{ display:none; }

/* cada item — largura menor que 100% pra “aparecer o próximo” */
.gallery-track .g{
  scroll-snap-align: start;
  width: min(82vw, 420px);
  aspect-ratio: 16 / 10;

  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 14px 30px rgba(0,0,0,.10);
}

.gallery-track .g img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* gradientes nas bordas pra reforçar “tem mais” */
.gallery-carousel::before,
.gallery-carousel::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width: 22px; /* 🔽 menor */
  pointer-events:none;
  z-index: 2;
}

.gallery-carousel::before{
  left:0;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.85),
    rgba(255,255,255,0)
  );
}

.gallery-carousel::after{
  right:0;
  background: linear-gradient(
    270deg,
    rgba(255,255,255,.85),
    rgba(255,255,255,0)
  );
}


@media (min-width: 960px){
  .gallery-track .g{
    width: min(32vw, 360px);
    aspect-ratio: 16 / 9;
  }
}

/* ===== Indicador visual de mais fotos (seta) ===== */
.gallery-arrow{
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;

  width: 42px;
  height: 42px;
  border-radius: 999px;

  background: rgba(0,0,0,.55);
  color: #fff;

  display: flex;
  align-items: center;
  justify-content: center;

  font-size: 22px;
  font-weight: 800;

  pointer-events: none; /* não atrapalha o swipe */
  animation: arrowPulse 1.8s ease-in-out infinite;
}

@keyframes arrowPulse{
  0%{ transform: translate(0,-50%); opacity:.6; }
  50%{ transform: translate(6px,-50%); opacity:1; }
  100%{ transform: translate(0,-50%); opacity:.6; }
}
