/* ============================================================
   Alliance for a Secure Jewish Future (ASJF)
   "Frontline Care" — clean white / grey / olive design system.
   Global, token-driven. One stylesheet for the whole site.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..600;1,9..144,300..500&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --paper:      #ffffff;
  --paper-2:    #f7f7f4;   /* soft section */
  --bone:       #f1f1ec;   /* panels */
  --line:       #e4e5df;   /* hairlines */
  --line-2:     #d4d6cd;

  --ink:        #1b1e16;   /* near-black, olive-tinted */
  --grey:       #5f6358;   /* body secondary */
  --grey-soft:  #8c9082;   /* tertiary / captions */

  --olive:      #5c6b3d;   /* primary accent (moss) */
  --olive-deep: #3a4527;   /* dark sections */
  --olive-mid:  #76864f;   /* hover / bright */
  --olive-soft: #aab68a;   /* tints */
  --olive-wash: #eef0e6;   /* faint olive fill */

  --f-serif: 'Fraunces', Georgia, serif;
  --f-sans:  'Manrope', system-ui, sans-serif;

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 72px);
  --ease: cubic-bezier(.22,.78,.3,1);
  --shadow-soft: 0 24px 60px -28px rgba(40,48,28,.35);
  --shadow-card: 0 30px 70px -30px rgba(40,48,28,.45);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font-family:inherit}
ul{list-style:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);position:relative}
.section{padding-block:clamp(72px,11vw,150px);position:relative}

/* ---------- Shared type ---------- */
.eyebrow{
  font-family:var(--f-sans);font-weight:600;font-size:.72rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--olive);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--olive);display:inline-block}
.eyebrow.center{justify-content:center}
.display{
  font-family:var(--f-serif);font-weight:340;font-optical-sizing:auto;
  line-height:1.02;letter-spacing:-.015em;color:var(--ink);
  font-size:clamp(2.5rem,6.4vw,5.2rem);
}
.display em{font-style:italic;color:var(--olive)}
.lede{font-size:clamp(1.05rem,1.5vw,1.32rem);color:var(--grey);line-height:1.6;max-width:54ch}

.s-head{max-width:60ch;margin-bottom:clamp(34px,5vw,64px)}
.s-head.center{margin-inline:auto;text-align:center}
.s-head h2{font-family:var(--f-serif);font-weight:340;font-size:clamp(2rem,4.6vw,3.5rem);
  line-height:1.03;letter-spacing:-.015em;margin:.5rem 0 .9rem}
.s-head h2 em{font-style:italic;color:var(--olive)}
.s-head p{color:var(--grey);font-size:clamp(1rem,1.3vw,1.15rem);max-width:56ch}
.s-head.center p{margin-inline:auto}

/* Clean reusable section heading (left-column sections) */
.h-sec{font-family:var(--f-serif);font-weight:340;font-size:clamp(2rem,4.6vw,3.4rem);
  line-height:1.04;letter-spacing:-.015em;color:var(--ink);margin:.6rem 0 1.1rem}
.h-sec em{font-style:italic;color:var(--olive)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  padding:.95em 1.55em;border-radius:999px;border:1px solid transparent;
  background:var(--olive);color:#fbfdf5;cursor:pointer;
  transition:transform .3s var(--ease),background .3s,box-shadow .3s,color .3s,border-color .3s;
}
.btn:hover{background:var(--olive-deep);transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(58,69,39,.7)}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{background:var(--olive-wash);border-color:var(--olive);color:var(--olive-deep);box-shadow:none}
.btn--light{background:#fbfdf5;color:var(--olive-deep)}
.btn--light:hover{background:#fff;color:var(--olive-deep)}
.btn--lg{padding:1.1em 1.9em;font-size:1rem}

/* ============================================================
   NAV
   ============================================================ */
header.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .4s,box-shadow .4s,border-color .4s}
header.nav.scrolled{background:rgba(255,255,255,.86);backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line);box-shadow:0 8px 30px -24px rgba(40,48,28,.5)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:18px;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand .mark{width:34px;height:34px;flex-shrink:0}
.brand b{font-family:var(--f-serif);font-weight:400;font-size:1.32rem;letter-spacing:-.01em;line-height:1}
.brand span{display:block;font-size:.58rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--olive);margin-top:3px}
.menu{display:flex;align-items:center;gap:.35rem}
.menu a:not(.btn){font-weight:500;font-size:.92rem;color:var(--grey);padding:.55em .85em;border-radius:999px;
  transition:color .25s,background .25s}
.menu a:not(.btn):hover,.menu a:not(.btn).active{color:var(--ink);background:var(--olive-wash)}
.menu .btn{color:#fbfdf5}
.menu .btn{margin-left:.6rem;padding:.7em 1.3em}
.burger{display:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:50%;
  background:#fff;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer}
.burger span{width:18px;height:1.5px;background:var(--ink);transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding-top:clamp(120px,16vh,180px);padding-bottom:clamp(40px,6vw,80px);overflow:hidden}
.hero::before{ /* soft olive light wash */
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(1200px 600px at 78% -8%, var(--olive-wash), transparent 60%),
    radial-gradient(900px 500px at 0% 100%, #f3f5ec, transparent 55%);
}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center}
.hero-copy{max-width:620px}
.hero h1{margin:1.1rem 0 1.4rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2rem;align-items:center}
.hero-trust{margin-top:2.6rem;display:flex;gap:2rem;flex-wrap:wrap;align-items:center;
  border-top:1px solid var(--line);padding-top:1.6rem}
.hero-trust .t b{font-family:var(--f-serif);font-weight:400;font-size:1.6rem;color:var(--olive-deep);display:block;line-height:1}
.hero-trust .t span{font-size:.78rem;color:var(--grey-soft);letter-spacing:.02em}

/* Floating hero media + stat card */
.hero-media{position:relative;aspect-ratio:1/1;border-radius:26px;overflow:visible;
  transform-style:preserve-3d;perspective:1200px}
.hero-media .art{position:absolute;inset:0;border-radius:26px;overflow:hidden;
  background:linear-gradient(160deg,#f3f5ec,var(--olive-wash));border:1px solid var(--line);
  box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:center;
  will-change:transform}
.hero-media .art svg{width:78%;height:auto;filter:drop-shadow(0 26px 40px rgba(58,69,39,.22))}
.hero-media .grain{position:absolute;inset:0;border-radius:26px;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E")}
/* organic olive blobs behind hero art */
.blob{position:absolute;border-radius:50%;filter:blur(46px);z-index:-1;opacity:.55}
.blob.b1{width:46%;height:46%;top:-8%;right:2%;background:var(--olive-soft)}
.blob.b2{width:40%;height:40%;bottom:-6%;left:-4%;background:#cdd7b0}
.float-card{position:absolute;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow-card);
  will-change:transform}
.float-card .k{font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--olive)}
.float-card .v{font-family:var(--f-serif);font-weight:400;font-size:1.9rem;line-height:1;margin-top:.3rem;color:var(--ink)}
.float-card .s{font-size:.78rem;color:var(--grey);margin-top:.3rem}
.float-card.fc1{top:7%;left:-6%}
.float-card.fc2{bottom:9%;right:-7%}
.float-card .spark{display:flex;align-items:flex-end;gap:3px;height:26px;margin-top:.5rem}
.float-card .spark i{width:5px;background:var(--olive-soft);border-radius:2px;display:block}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{background:var(--olive-deep);color:#eef0e6}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
.stat .n{font-family:var(--f-serif);font-weight:340;font-size:clamp(2.6rem,5vw,4rem);line-height:1;color:#fff}
.stat .n .suf{color:var(--olive-soft)}
.stat .l{margin-top:.7rem;font-size:.86rem;letter-spacing:.04em;color:#c4cbb0;max-width:22ch}
.stat{padding-left:clamp(14px,2vw,22px);border-left:1px solid rgba(255,255,255,.16)}

/* ============================================================
   THE CORPS  (image + copy, parallax)
   ============================================================ */
.corps .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,72px);align-items:center}
.corps .frame{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:5/6}
.corps .frame{background:var(--olive-wash)}
.corps .frame svg,.corps .frame img{width:100%;height:100%;display:block;object-fit:cover}
.corps .frame figcaption{position:absolute;left:16px;bottom:14px;background:rgba(27,30,22,.6);color:#fff;
  font-size:.74rem;letter-spacing:.04em;padding:.5em .8em;border-radius:8px;backdrop-filter:blur(4px)}
.corps ul{margin-top:1.6rem;display:grid;gap:.5rem}
.corps li{display:flex;gap:.7rem;align-items:flex-start;color:var(--grey)}
.corps li svg{flex-shrink:0;margin-top:3px;color:var(--olive)}

/* ============================================================
   MEDIC BAGS  (floating tilted cards)
   ============================================================ */
.bags{background:var(--paper-2)}
.bags-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.bag-photo{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:4/3}
.bag-photo{background:linear-gradient(160deg,#f3f5ec,var(--olive-wash))}
.bag-photo svg,.bag-photo img{width:100%;height:100%;display:block}
.bag-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;perspective:1400px}
.kit{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-soft);
  transition:transform .5s var(--ease),box-shadow .5s;transform-style:preserve-3d;will-change:transform}
.kit:hover{transform:translateY(-4px) rotateX(3deg) rotateY(-3deg);box-shadow:var(--shadow-card)}
.kit .ic{width:42px;height:42px;border-radius:11px;background:var(--olive-wash);color:var(--olive-deep);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.kit h4{font-family:var(--f-serif);font-weight:420;font-size:1.18rem;margin-bottom:.3rem}
.kit p{font-size:.9rem;color:var(--grey)}

/* ============================================================
   NODE DIAGRAM  ("how your gift reaches the front")
   ============================================================ */
.network{background:#fff;overflow:hidden}
.net-stage{position:relative;margin-top:clamp(20px,4vw,40px)}
.net-stage svg{width:100%;height:auto;display:block;overflow:visible}
.net-line{fill:none;stroke:var(--olive-soft);stroke-width:1.5;
  stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 1.3s var(--ease)}
.net-stage.in .net-line{stroke-dashoffset:0}
.net-node circle{fill:#fff;stroke:var(--olive);stroke-width:1.5}
.net-node .core{fill:var(--olive)}
.net-node text{font-family:var(--f-sans);font-size:13px;font-weight:600;fill:var(--ink)}
.net-node .sub{font-size:11px;font-weight:500;fill:var(--grey-soft)}
.net-node{opacity:0;transform:translateY(8px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.net-stage.in .net-node{opacity:1;transform:none}
.net-stage.in .net-node:nth-child(2){transition-delay:.15s}
.net-stage.in .net-node:nth-child(3){transition-delay:.3s}
.net-stage.in .net-node:nth-child(4){transition-delay:.45s}
.net-stage.in .net-node:nth-child(5){transition-delay:.6s}

/* ============================================================
   ADOPT A MEDIC  +  INTAKE  (forms)
   ============================================================ */
.adopt{background:var(--olive-wash)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.tiers{display:grid;gap:12px;margin-top:1.4rem}
.tier{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:14px 18px;cursor:pointer;transition:border-color .25s,box-shadow .25s,transform .25s}
.tier:hover{border-color:var(--olive);box-shadow:var(--shadow-soft);transform:translateX(3px)}
.tier b{font-family:var(--f-serif);font-weight:440;font-size:1.15rem}
.tier span{font-size:.84rem;color:var(--grey)}
.tier .amt{font-weight:700;color:var(--olive-deep)}

.card-form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:clamp(24px,3vw,40px);
  box-shadow:var(--shadow-soft)}
.field{display:grid;gap:6px;margin-bottom:16px}
.field.row{grid-template-columns:1fr 1fr;gap:16px}
.field label{font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--grey);text-transform:uppercase}
.field input,.field select,.field textarea{
  background:var(--paper-2);border:1px solid var(--line);border-radius:11px;padding:.85em 1em;
  font-size:.96rem;color:var(--ink);transition:border-color .25s,background .25s,box-shadow .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--olive);
  background:#fff;box-shadow:0 0 0 4px var(--olive-wash)}
.field textarea{resize:vertical;min-height:96px}
.form-note{font-size:.82rem;color:var(--grey-soft);margin-top:.4rem}
.form-ok{margin-top:1rem;font-weight:600;color:var(--olive-deep);background:var(--olive-wash);
  border:1px solid var(--olive-soft);border-radius:11px;padding:.8em 1em;font-size:.9rem}

.intake{background:var(--paper-2)}

/* ============================================================
   DONATE  (dark olive)
   ============================================================ */
.donate{position:relative;background:var(--olive-deep);color:#eef0e6;overflow:hidden}
.donate::before{content:"";position:absolute;inset:0;opacity:.4;
  background:url('../images/topo.svg') center/cover}
.donate .wrap{position:relative;text-align:center;max-width:880px}
.donate h2{font-family:var(--f-serif);font-weight:340;font-size:clamp(2.2rem,5.2vw,4rem);line-height:1.02;color:#fff}
.donate h2 em{font-style:italic;color:var(--olive-soft)}
.donate p{color:#c4cbb0;margin:1.3rem auto 2.2rem;max-width:50ch;font-size:1.05rem}
.donate .ways{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:2rem;
  font-size:.82rem;color:#aab68a;letter-spacing:.04em}
.donate .ways span{border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.45em 1em}

/* ============================================================
   CONTACT + FOOTER
   ============================================================ */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:start}
.contact .lines{display:grid;gap:1.1rem;margin-top:1.6rem}
.contact .line{display:flex;gap:1rem;align-items:flex-start}
.contact .line .ic{width:42px;height:42px;flex-shrink:0;border-radius:11px;background:var(--olive-wash);
  color:var(--olive-deep);display:flex;align-items:center;justify-content:center}
.contact .line b{display:block;font-weight:600}
.contact .line span,.contact .line a{color:var(--grey)}
.contact .line a:hover{color:var(--olive-deep)}

footer.site{background:var(--ink);color:#cdd0c4;padding-block:clamp(48px,6vw,72px) 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:clamp(28px,5vw,60px)}
.foot-brand .brand b{color:#fff}
.foot-brand p{color:#9a9d90;max-width:38ch;margin-top:1.1rem;font-size:.92rem}
.foot-col h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#84887b;margin-bottom:1rem}
.foot-col a{display:block;padding:.3em 0;color:#b9bcb0;font-size:.93rem;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-base{max-width:var(--maxw);margin:clamp(34px,5vw,52px) auto 0;padding:22px var(--gut) 0;
  border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.8rem;color:#84887b}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr}
  .hero-media{max-width:460px;margin:0 auto;aspect-ratio:4/4}
  .stats .grid{grid-template-columns:1fr 1fr;gap:34px}
  .corps .wrap,.bags-layout,.form-grid,.contact .wrap{grid-template-columns:1fr}
  .corps .frame,.bag-photo{max-width:520px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
  .menu{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;flex-direction:column;
    align-items:stretch;justify-content:center;gap:.4rem;padding:2rem;transform:translateX(100%);
    transition:transform .4s var(--ease);box-shadow:-20px 0 50px -30px rgba(0,0,0,.4)}
  .menu.open{transform:none}
  .menu a{padding:.9em 1em;font-size:1.05rem}
  .menu .btn{margin:.6rem 0 0;justify-content:center}
  .burger{display:flex;z-index:70}
  .float-card.fc1{left:0}.float-card.fc2{right:0}
}
@media(max-width:560px){
  .stats .grid{grid-template-columns:1fr}
  .bag-cards{grid-template-columns:1fr}
  .field.row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001ms!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
