/* Nexa Women Foundation – Custom Styles */
:root{
  --primary:#5B21B6;
  --primary-600:#6D28D9;
  --primary-50:#EDE9FE;
  --gold:#F59E0B;
  --navy:#0F172A;
  --bg:#FFFFFF;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--navy);background:#fff;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.font-display{font-family:'Playfair Display',serif;letter-spacing:-.01em}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;border-radius:9999px;font-weight:600;font-size:.95rem;transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s;will-change:transform}
.btn-primary{background:#5B21B6;color:#fff;box-shadow:0 10px 30px -10px rgba(91,33,182,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(91,33,182,.7),0 0 0 4px rgba(245,158,11,.15)}
.btn-gold{background:#F59E0B;color:#1F2937;box-shadow:0 10px 30px -10px rgba(245,158,11,.55)}
.btn-gold:hover{transform:translateY(-2px)}
.btn-outline{border:1.5px solid rgba(255,255,255,.7);color:#fff;backdrop-filter:blur(8px);background:rgba(255,255,255,.08)}
.btn-outline:hover{background:rgba(255,255,255,.18)}
.btn-ghost{border:1.5px solid #E5E7EB;color:var(--navy);background:#fff}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}

/* Glass */
.glass{background:rgba(255,255,255,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.5)}
.glass-dark{background:rgba(15,23,42,.55);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08)}

/* Navbar */
.nav-link{position:relative;font-weight:500;color:#1F2937;padding:.5rem 0;transition:color .2s}
.nav-link:hover{color:var(--primary)}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:#5B21B6;transition:width .3s ease}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.navbar-scrolled{background:rgba(255,255,255,.85)!important;backdrop-filter:blur(14px);box-shadow:0 4px 20px -8px rgba(15,23,42,.12)}

/* Hero */
.hero-grad{background:#0F172A}
.hero-shape{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;animation:float 8s ease-in-out infinite}

/* Animations */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.4)}50%{box-shadow:0 0 0 14px rgba(245,158,11,0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.glow{animation:glowPulse 2.4s infinite}

/* Cards */
.card{background:#fff;border-radius:1.25rem;border:1px solid #EEF0F4;transition:transform .35s ease, box-shadow .35s ease;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -25px rgba(91,33,182,.25)}
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:9999px;font-size:.72rem;font-weight:600;letter-spacing:.02em}
.badge-gold{background:#FEF3C7;color:#92400E}
.badge-purple{background:var(--primary-50);color:var(--primary)}
.badge-red{background:#FEE2E2;color:#991B1B}

/* Progress */
.progress{height:8px;background:#EDE9FE;border-radius:9999px;overflow:hidden}
.progress>span{display:block;height:100%;background:#5B21B6;border-radius:9999px;width:0;transition:width 1.4s ease}

/* Skeleton */
.skeleton{background:#EDE9FE;border-radius:.75rem}

/* Carousel dots */
.dot{width:8px;height:8px;border-radius:9999px;background:#CBD5E1;transition:all .3s}
.dot.active{width:24px;background:var(--primary)}

/* Image hover */
.zoom img{transition:transform .8s ease}
.zoom:hover img{transform:scale(1.08)}

/* Forms */
.input{width:100%;padding:.85rem 1rem;border:1.5px solid #E5E7EB;border-radius:.75rem;background:#fff;transition:border-color .2s, box-shadow .2s;font-size:.95rem}
.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(91,33,182,.12)}
.label{font-size:.85rem;font-weight:600;color:#374151;margin-bottom:.4rem;display:block}

/* Section */
.section{padding:5rem 0}
@media (max-width:768px){.section{padding:3.5rem 0}}

/* FAQ */
.faq summary{cursor:pointer;list-style:none;padding:1.25rem 1.5rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--primary);transition:transform .3s}
.faq[open] summary::after{content:"−"}
.faq{border:1px solid #E5E7EB;border-radius:1rem;background:#fff;overflow:hidden}
.faq[open]{box-shadow:0 10px 30px -15px rgba(91,33,182,.2)}
.faq p{padding:0 1.5rem 1.25rem;color:#475569;line-height:1.7}

/* Scrollbar */
::selection{background:var(--primary);color:#fff}
