/* ============================================================
   Amparo Peacemaking Project — shared styles
   ============================================================ */
:root{
  --ink:#14253B;          /* deep navy ground */
  --navy:#1F3A5F;         /* brand navy */
  --navy-700:#2C4D78;     /* lighter navy */
  --gold:#B08D2D;         /* brand gold */
  --gold-bright:#CDA94B;  /* highlight gold */
  --paper:#F4F1E9;        /* warm refuge paper */
  --paper-2:#FBFAF5;
  --line-dark:rgba(232,230,223,.16);
  --line-light:rgba(31,58,95,.16);
  --on-dark:#E9E6DD;
  --on-dark-muted:rgba(233,230,221,.66);
  --on-light:#23323F;
  --on-light-muted:#566570;
  --display:'Spectral',Georgia,'Times New Roman',serif;
  --body:'Public Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --maxw:1140px;
  --pad:clamp(1.25rem,5vw,2.5rem);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;font-family:var(--body);color:var(--on-light);background:var(--paper);
  line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.12;margin:0;letter-spacing:-.01em;}
p{margin:0 0 1.1em;}
a{color:inherit;}
img{max-width:100%;display:block;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.narrow{max-width:820px;}

.skip{
  position:absolute;left:-9999px;top:0;z-index:200;background:var(--gold-bright);color:var(--ink);
  padding:.7rem 1.1rem;font-weight:600;font-size:.85rem;border-radius:0 0 3px 0;
}
.skip:focus{left:0;}

.eyebrow{
  font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--navy);margin:0 0 1.4rem;display:flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.9;}
.section--dark .eyebrow,.band .eyebrow,.contact .eyebrow,.page-hero .eyebrow{color:var(--gold-bright);}

/* ---------- Header / nav ---------- */
header{
  position:sticky;top:0;z-index:50;background:rgba(20,37,59,.88);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line-dark);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;position:relative;}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--on-dark);}
.brand .mark{width:32px;height:32px;flex:none;}
.brand .name{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:.04em;line-height:1;}
.brand .name small{display:block;font-family:var(--body);font-weight:500;font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--on-dark-muted);margin-top:.25rem;}
.nav-right{display:flex;align-items:center;gap:1.4rem;}
.nav-links{display:flex;align-items:center;gap:1.7rem;}
.nav-links a{
  text-decoration:none;color:var(--on-dark-muted);font-size:.82rem;font-weight:500;letter-spacing:.02em;
  padding:.4rem 0;position:relative;transition:color .2s ease;white-space:nowrap;
}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--on-dark);}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--gold);transition:right .25s ease;}
.nav-links a:hover::after,.nav-links a:focus-visible::after{right:0;}
.nav-links a[aria-current="page"]{color:var(--on-dark);}
.nav-links a[aria-current="page"]::after{right:0;}
.nav-cta{
  text-decoration:none;font-size:.82rem;font-weight:600;letter-spacing:.02em;color:var(--ink);
  background:var(--gold-bright);padding:.55rem 1.05rem;border-radius:2px;white-space:nowrap;
  transition:background .2s ease;
}
.nav-cta:hover,.nav-cta:focus-visible{background:#dcb85a;}
.nav-toggle{
  display:none;background:none;border:1px solid var(--line-dark);color:var(--on-dark);
  width:42px;height:38px;border-radius:3px;cursor:pointer;align-items:center;justify-content:center;
}
.nav-toggle svg{width:20px;height:20px;}

@media (max-width:880px){
  .nav-toggle{display:inline-flex;}
  .nav-right{gap:.8rem;}
  .nav-links{
    position:absolute;top:68px;left:calc(var(--pad) * -1);right:calc(var(--pad) * -1);
    background:var(--ink);border-bottom:1px solid var(--line-dark);
    flex-direction:column;align-items:stretch;gap:0;padding:.4rem var(--pad) 1.3rem;display:none;
  }
  .nav-links[data-open="true"]{display:flex;}
  .nav-links a{padding:.95rem 0;border-bottom:1px solid var(--line-dark);font-size:1rem;}
  .nav-links a::after{display:none;}
  .nav-links a[aria-current="page"]{color:var(--gold-bright);}
}

/* ---------- Hero (home) ---------- */
.hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden;}
.hero-ripple{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.hero-ripple svg{width:min(140vw,1400px);height:auto;}
.ring{fill:none;stroke-width:1.1;transform-origin:center;}
.ring--g{stroke:var(--gold);}
.ring--n{stroke:#4E78AE;}
@keyframes ripple{0%{transform:scale(.18);opacity:0;}14%{opacity:.5;}100%{transform:scale(1);opacity:0;}}
.hero-ripple .r1{animation:ripple 11s ease-out infinite;}
.hero-ripple .r2{animation:ripple 11s ease-out infinite;animation-delay:2.2s;}
.hero-ripple .r3{animation:ripple 11s ease-out infinite;animation-delay:4.4s;}
.hero-ripple .r4{animation:ripple 11s ease-out infinite;animation-delay:6.6s;}
.hero-ripple .r5{animation:ripple 11s ease-out infinite;animation-delay:8.8s;}
.hero-vignette{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 46%,rgba(20,37,59,.35) 0%,rgba(20,37,59,.82) 70%,var(--ink) 100%);pointer-events:none;}
@media (prefers-reduced-motion:reduce){
  .hero-ripple .r1,.hero-ripple .r2,.hero-ripple .r3,.hero-ripple .r4,.hero-ripple .r5{animation:none;opacity:.22;}
  .hero-ripple .r1{transform:scale(.35);}.hero-ripple .r2{transform:scale(.52);}
  .hero-ripple .r3{transform:scale(.7);}.hero-ripple .r4{transform:scale(.86);}.hero-ripple .r5{transform:scale(1);}
}
.hero-inner{position:relative;z-index:2;padding:clamp(5rem,15vh,9rem) 0 clamp(4.5rem,12vh,7rem);}
.hero-eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-bright);margin:0 0 1.8rem;}
.hero h1{font-size:clamp(2.9rem,8.2vw,5.6rem);font-weight:400;max-width:14ch;letter-spacing:-.02em;}
.hero h1 em{font-style:italic;color:var(--gold-bright);}
.hero-sub{font-size:clamp(1.08rem,2.1vw,1.3rem);color:var(--on-dark);max-width:48ch;margin:1.9rem 0 0;}
.hero-meta{margin-top:2.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:1.4rem;}
.tagline-chip{display:inline-flex;gap:.6rem;align-items:center;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-bright);border:1px solid var(--line-dark);padding:.5rem .95rem;border-radius:2px;}
.tagline-chip span{opacity:.4;}
.hero-note{font-size:.86rem;color:var(--on-dark-muted);max-width:42ch;}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden;}
.page-hero .mini-ripple{position:absolute;right:-6%;top:50%;transform:translateY(-50%);width:min(48vw,520px);opacity:.5;pointer-events:none;}
.page-hero .mini-ripple svg{width:100%;height:auto;}
.page-hero-inner{position:relative;z-index:2;padding:clamp(3.6rem,9vh,5.5rem) 0 clamp(3rem,7vh,4.5rem);max-width:42ch;}
.page-hero h1{font-size:clamp(2.3rem,5.6vw,3.6rem);font-weight:400;letter-spacing:-.02em;}
.page-hero h1 em{font-style:italic;color:var(--gold-bright);}
.page-hero .lead{font-size:clamp(1.05rem,1.9vw,1.25rem);color:var(--on-dark);margin-top:1.3rem;}

/* ---------- Sections ---------- */
.section{padding:clamp(3.6rem,8vw,6.5rem) 0;}
.section--dark{background:var(--ink);color:var(--on-dark);}
.section--paper2{background:var(--paper-2);}
.section-head{max-width:44ch;margin-bottom:clamp(2.2rem,5vw,3.4rem);}
.section--dark .section-head h2,.section--dark p{color:var(--on-dark);}
.section h2{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:500;}
.lead{font-size:clamp(1.08rem,1.7vw,1.28rem);color:var(--on-light);max-width:52ch;}
.section--dark .lead{color:var(--on-dark);}
.muted{color:var(--on-light-muted);}
.section--dark .muted,.page-hero .muted{color:var(--on-dark-muted);}

.prose{max-width:64ch;}
.prose p{font-size:1.075rem;}
.prose h3{font-family:var(--display);font-size:1.4rem;font-weight:500;color:var(--navy);margin:2.2rem 0 .7rem;}
.section--dark .prose h3{color:var(--gold-bright);}

.pullquote{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.5rem,3.4vw,2.2rem);line-height:1.32;letter-spacing:-.01em;
  color:var(--gold-bright);max-width:24ch;margin:0;padding-left:1.4rem;border-left:2px solid var(--gold);
}
.twocol{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
@media (max-width:820px){.twocol{grid-template-columns:1fr;gap:2.4rem;}.pullquote{padding-left:1.1rem;}}

/* Continuum */
.continuum{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:3px;overflow:hidden;}
.step{background:var(--ink);padding:1.9rem 1.5rem;display:flex;flex-direction:column;gap:.7rem;}
.step .num{font-family:var(--display);font-size:1.05rem;color:var(--gold-bright);letter-spacing:.04em;}
.step h3{font-size:1.16rem;font-weight:600;font-family:var(--display);color:var(--on-dark);}
.step p{font-size:.92rem;color:var(--on-dark-muted);margin:0;}
@media (max-width:780px){.continuum{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.continuum{grid-template-columns:1fr;}}

/* Beliefs */
.beliefs{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-light);border:1px solid var(--line-light);border-radius:3px;overflow:hidden;}
.belief{background:var(--paper-2);padding:1.7rem 1.6rem;}
.belief h3{font-size:1.12rem;font-weight:600;font-family:var(--display);color:var(--navy);margin-bottom:.45rem;}
.belief p{font-size:.95rem;color:var(--on-light-muted);margin:0;}
@media (max-width:680px){.beliefs{grid-template-columns:1fr;}}

/* Roots */
.roots{display:grid;grid-template-columns:repeat(2,1fr);gap:1.7rem 3rem;}
.root{display:flex;gap:1rem;align-items:flex-start;}
.root .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);margin-top:.55rem;flex:none;}
.root h3{font-size:1.05rem;font-weight:600;font-family:var(--display);margin-bottom:.25rem;}
.section--dark .root h3{color:var(--on-dark);}
.root p{font-size:.92rem;margin:0;}
.section--dark .root p{color:var(--on-dark-muted);}
@media (max-width:680px){.roots{grid-template-columns:1fr;gap:1.4rem;}}

/* Functions */
.functions{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem;}
.function{border:1px solid var(--line-light);border-radius:4px;padding:1.8rem;background:var(--paper-2);}
.function .fn-num{font-family:var(--display);color:var(--gold);font-size:.95rem;letter-spacing:.05em;}
.function h3{font-size:1.22rem;font-weight:600;font-family:var(--display);color:var(--navy);margin:.5rem 0 .6rem;}
.function p{font-size:.95rem;color:var(--on-light-muted);margin:0;}
@media (max-width:680px){.functions{grid-template-columns:1fr;}}

/* Safeguards */
.safeguards{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.1rem;max-width:64ch;}
.safeguards li{padding-left:1.6rem;position:relative;font-size:1.02rem;}
.safeguards li::before{content:"";position:absolute;left:0;top:.62em;width:10px;height:10px;border:2px solid var(--gold);border-radius:50%;}
.safeguards b{font-family:var(--display);font-weight:600;color:var(--navy);}
.section--dark .safeguards b{color:var(--gold-bright);}

/* Founder */
.founder{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start;}
.founder-card{background:var(--ink);color:var(--on-dark);border-radius:4px;padding:2.2rem;}
.founder-card .role{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);font-weight:600;margin-bottom:1rem;}
.founder-card h3{font-family:var(--display);font-size:1.7rem;font-weight:500;margin-bottom:1.2rem;}
.creds{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-direction:column;gap:.6rem;}
.creds li{font-size:.9rem;color:var(--on-dark-muted);padding-left:1.3rem;position:relative;}
.creds li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:1px;background:var(--gold-bright);}
.founder-note{font-style:italic;font-family:var(--display);color:var(--on-light-muted);border-top:1px solid var(--line-light);padding-top:1.2rem;margin-top:1.6rem;font-size:1rem;}
@media (max-width:820px){.founder{grid-template-columns:1fr;}}

/* Credential / list grid (who-leads) */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem 3rem;}
.fact h3{font-size:1.08rem;font-family:var(--display);font-weight:600;color:var(--navy);margin-bottom:.4rem;}
.section--dark .fact h3{color:var(--gold-bright);}
.fact p{font-size:.96rem;color:var(--on-light-muted);margin:0;}
.section--dark .fact p{color:var(--on-dark-muted);}
@media (max-width:680px){.facts{grid-template-columns:1fr;gap:1.3rem;}}

/* Band */
.band{background:var(--navy);color:var(--on-dark);}
.band .wrap{padding-top:clamp(3.4rem,7vw,5rem);padding-bottom:clamp(3.4rem,7vw,5rem);}
.band h2{font-size:clamp(1.7rem,3.6vw,2.5rem);max-width:20ch;}
.band p{color:var(--on-dark);max-width:54ch;font-size:1.075rem;margin-top:1.2rem;}

/* Ways / get involved */
.ways{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;}
.way{border:1px solid var(--line-light);border-radius:4px;padding:1.8rem;background:var(--paper-2);transition:border-color .2s ease,transform .2s ease;}
.way .wnum{font-family:var(--display);color:var(--gold);font-size:.95rem;letter-spacing:.05em;}
.way h3{font-size:1.2rem;font-weight:600;font-family:var(--display);color:var(--navy);margin:.5rem 0 .55rem;}
.way p{font-size:.95rem;color:var(--on-light-muted);margin:0 0 1rem;}
.way a.way-link{font-size:.85rem;font-weight:600;color:var(--navy);text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:1px;}
.way a.way-link:hover{color:var(--gold);}
.way:hover{border-color:var(--gold);transform:translateY(-2px);}
@media (max-width:680px){.ways{grid-template-columns:1fr;}}

/* Donate stub */
.donate-stub{border:1px dashed var(--gold);border-radius:4px;padding:2rem;background:rgba(176,141,45,.06);max-width:64ch;}
.donate-stub .tag{display:inline-block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--gold);background:rgba(176,141,45,.12);padding:.35rem .7rem;border-radius:2px;margin-bottom:1rem;}
.donate-stub h3{font-family:var(--display);font-size:1.4rem;font-weight:500;color:var(--navy);margin-bottom:.6rem;}
.donate-stub p{font-size:.98rem;color:var(--on-light-muted);margin:0 0 .8rem;}

/* Articles / writing */
.articles{display:flex;flex-direction:column;gap:1px;background:var(--line-light);border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light);}
.article{background:var(--paper-2);padding:1.9rem 1.6rem;display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:baseline;text-decoration:none;color:inherit;transition:background .2s ease;}
.article:hover{background:#fff;}
.article .a-src{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;white-space:nowrap;}
.article h3{font-family:var(--display);font-size:1.3rem;font-weight:500;color:var(--navy);margin:0 0 .35rem;}
.article p{font-size:.95rem;color:var(--on-light-muted);margin:0;}
.article .a-arrow{font-size:1.3rem;color:var(--gold);align-self:center;}
@media (max-width:680px){.article{grid-template-columns:1fr;gap:.6rem;}.article .a-arrow{display:none;}}

/* Contact */
.contact{background:var(--ink);color:var(--on-dark);}
.contact .wrap{padding-top:clamp(4rem,9vw,6.5rem);padding-bottom:clamp(3rem,6vw,4.5rem);}
.contact h2,.contact h1{font-size:clamp(1.9rem,4.4vw,3rem);max-width:18ch;}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:end;margin-top:2.4rem;}
.contact-lines{display:flex;flex-direction:column;gap:1rem;}
.contact-lines a,.contact-lines span{display:flex;align-items:baseline;gap:.9rem;text-decoration:none;color:var(--on-dark);font-size:1.08rem;}
.contact-lines .lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);font-weight:600;min-width:62px;flex:none;}
.contact-lines .val{transition:color .2s ease;border-bottom:1px solid transparent;}
.contact-lines a:hover .val{color:var(--gold-bright);border-color:var(--gold);}
@media (max-width:760px){.contact-grid{grid-template-columns:1fr;align-items:start;}}

/* CTA strip */
.cta-strip{background:var(--paper-2);border-top:1px solid var(--line-light);}
.cta-strip .wrap{padding-top:clamp(3rem,6vw,4.5rem);padding-bottom:clamp(3rem,6vw,4.5rem);display:flex;flex-wrap:wrap;gap:1.5rem 2rem;align-items:center;justify-content:space-between;}
.cta-strip h2{font-size:clamp(1.5rem,3vw,2.1rem);max-width:20ch;}
.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:.92rem;letter-spacing:.02em;padding:.8rem 1.5rem;border-radius:2px;transition:background .2s ease,transform .2s ease;}
.btn-gold{background:var(--gold-bright);color:var(--ink);}
.btn-gold:hover{background:#dcb85a;transform:translateY(-1px);}
.btn-ghost{border:1px solid var(--on-dark-muted);color:var(--on-dark);}
.btn-ghost:hover{border-color:var(--gold-bright);color:var(--gold-bright);}

/* Footer */
footer{background:var(--ink);color:var(--on-dark-muted);border-top:1px solid var(--line-dark);}
footer .wrap{padding-top:2.8rem;padding-bottom:2.8rem;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;}
.foot-brand{display:flex;align-items:center;gap:.7rem;color:var(--on-dark);margin-bottom:1rem;}
.foot-brand .mark{width:26px;height:26px;}
.foot-brand b{font-family:var(--display);font-weight:600;letter-spacing:.04em;font-size:.98rem;}
.foot-note{font-size:.8rem;max-width:40ch;line-height:1.6;}
.foot-col h4{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);font-weight:600;margin:.2rem 0 1rem;}
.foot-col a{display:block;text-decoration:none;color:var(--on-dark-muted);font-size:.9rem;padding:.3rem 0;transition:color .2s ease;}
.foot-col a:hover{color:var(--on-dark);}
.foot-bottom{border-top:1px solid var(--line-dark);}
.foot-bottom .wrap{padding-top:1.3rem;padding-bottom:1.6rem;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;font-size:.78rem;}
@media (max-width:720px){footer .wrap{grid-template-columns:1fr 1fr;}.foot-brand-col{grid-column:1 / -1;}}
@media (max-width:460px){footer .wrap{grid-template-columns:1fr;}}

/* Reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

a:focus-visible,.nav-cta:focus-visible,.btn:focus-visible,.nav-toggle:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px;border-radius:2px;}

.spacer-sm{height:1.4rem;}
.mt-link{display:inline-block;margin-top:1.4rem;font-weight:600;font-size:.9rem;color:var(--navy);text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:1px;}
.section--dark .mt-link{color:var(--gold-bright);}
.mt-link:hover{color:var(--gold);}
