/* styles.css (rewritten + cleaned) */
:root{
  --gold:#F4C15D;
  --gold-600:#E0AA3E;
  --blush:#F5D1D8;
  --rose:#EFAEC2;
  --aka-green:#007F5F;
  --aka-green-700:#005c44;
  --cream:#FFFBF6;
  --stone:#F3F2EF;
  --ink:#1E1B16;
  --muted:#6B655E;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius-xl: 22px;
  --radius-lg: 16px;
  --radius-md: 12px;
}

/* Base */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: var(--cream);
  color: var(--ink);
  line-height:1.5;
  overflow-x:hidden; /* prevent accidental horizontal scroll */
}
img{max-width:100%;display:block;height:auto}
a{color:var(--aka-green);text-decoration:none}
:focus-visible{outline:3px solid var(--rose);outline-offset:2px}

/* Utilities */
.container{width:min(1100px, 92vw);margin-inline:auto}
.grid{display:grid;gap:1.25rem}
.row{display:flex;gap:.75rem;flex-wrap:wrap}
.gap-4{gap:.4rem}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  border:none;
  border-radius:999px;
  padding:.9rem 1.1rem;
  font-weight:600;
  cursor:pointer;
}
.btn-primary{background:var(--aka-green);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--aka-green-700)}
.btn-ghost{background:transparent;color:var(--aka-green);border:2px solid var(--aka-green)}

.tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600;font-size:.9rem;color:#2f2a24;
  background:var(--blush);
  border-radius:999px;
  padding:.45rem .8rem;
}

.card{
  background:#fff;
  border:1px solid #F0ECE6;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
}

.help{font-size:.95rem;color:var(--muted)}
.m-0{margin:0}
.mt-075{margin-top:.75rem}

/* =========================
   HEADER + NAV (FINAL)
   ========================= */
header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.8);
  backdrop-filter:blur(8px);
  border-bottom:1px solid #eee;
}

/* Shell contains top row + dropdown */
.nav.nav-shell{
  position:relative;
  padding:.8rem 0;
}

/* Top row wrapper from your HTML */
#navbar-content{
  display:flex;
  align-items:center;
  gap:.75rem;
  width:100%;
}

/* Logo */
.brand{display:flex;align-items:center;gap:.8rem;min-width:0}
.brand-left{flex:0 0 auto}
.logo{
  width:40px;height:40px;border-radius:50%;
  /* background: radial-gradient(closest-side, var(--gold), var(--gold-600)); */
  background-image: url("./img/sunflower-favicon.svg");
  position:relative;
  /* box-shadow: 0 6px 14px rgba(244,193,93,.35); */
  flex:0 0 auto
}

/* Brand name */
.brand-name{flex:1 1 auto;min-width:0;display:block}
.nav-brand-title{
  margin:0;
  font:700 1.15rem/1.1 "Playfair Display", serif;
  letter-spacing:.2px;
  color:var(--aka-green-700);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Menu button */
.nav-toggle{
  flex:0 0 auto;
  border:1px solid #E7E4DE;
  background:#fff;
  border-radius:999px;
  padding:.55rem .85rem;
  font-size:1.05rem;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-left: auto;
}

/* Dropdown panel (animated) */
.nav-dropdown{
  position:absolute;
  left:0;
  right:0;
  top:100%;
  z-index:30;

  pointer-events:none;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transform:translateY(-10px);
  transition: max-height .32s ease, transform .32s ease, opacity .22s ease;
}

.nav-dropdown-inner{
  margin-top:.6rem;
  background: rgba(255,255,255,.97);
  border: 1px solid #EEE7DD;
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: .9rem;
}

/* Donate inside menu ONLY */
.dropdown-donate{
  width:100%;
  margin-bottom:.6rem;
}

/* Menu list inside dropdown */
.nav-menu ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:.25rem;
}

.nav-menu a{
  display:block;
  padding:.75rem .9rem;
  border-radius:14px;
  white-space:nowrap;
}
.nav-menu a:hover{background:var(--stone)}

/* Open state */
.nav-shell.open .nav-dropdown{
  pointer-events:auto;
  max-height:520px;
  opacity:1;
  transform:translateY(0);
}

/* Mobile clamp for long name */
@media (max-width: 768px){
  .nav-brand-title{
    white-space:normal;
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:2;
    overflow:hidden;
    line-height:1.15;
    font-size:1.05rem;
  }
}

/* Desktop behavior: show links horizontally (optional) */
@media (min-width: 769px){
  /* still keep the dropdown, but make it feel like standard nav */
  .nav-dropdown{
    position:static;
    max-height:none;
    opacity:1;
    transform:none;
    overflow:visible;
    pointer-events:auto;
  }
  .nav-dropdown-inner{
    margin-top:0;
    background:transparent;
    border:0;
    box-shadow:none;
    padding:0;
  }
  .dropdown-donate{
    width:auto;
    margin:0 0 0 auto;
    display:none; /* hide dropdown donate on desktop unless you want it */
  }
  .nav-menu ul{
    display:flex;
    gap:.4rem;
    justify-content:flex-end;
  }
  .nav-menu a{
    padding:.5rem .75rem;
    border-radius:999px;
  }
}

/* =========================
   HERO
   ========================= */
.hero{
  position:relative;
  padding: 5rem 0 3rem;
  background-image: url("./img/sunFlower2.png");
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center center;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.45),
    rgba(0, 0, 0, 0.18),
    rgba(0, 0, 0, 0)
  );
  z-index:1;
}

.hero-inner{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  align-items:center;
  gap:3rem;
}

.hero-inner > div:first-child{
  background: rgba(255, 251, 246, 0.60);
  backdrop-filter: blur(12px);
  border-radius: 24px;
  padding: 1.75rem 2.25rem;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.22);
}

.hero .tag.eyebrow{
  background: rgba(255, 255, 255, 0.85);
  padding: 0.35rem 0.9rem;
}

.hero h2{
  margin:.9rem 0 .75rem;
  font:700 clamp(1.8rem, 4vw, 3rem)/1.1 "Playfair Display", serif;
  color: rgba(0, 90, 70, 0.95);
  letter-spacing:-0.03em;
}

.hero-cta{
  margin-top:1.6rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.hero-media{display:flex;justify-content:center}
.hero-card{
  position:relative;
  border-radius:28px;
  border:5px solid #fff;
  overflow:hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  background:#fff;
  transition: transform .25s ease, box-shadow .25s ease;
  max-width:420px;
  width:100%;
}
.hero-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 26px 70px rgba(0,0,0,.30);
}

.hero-badge {
  position: absolute;
  top: .75rem;
  left: .75rem;

  padding: .35rem .9rem;
  border-radius: 999px;
  background: #ffb84d;
  color: #3e1b0a;
  font-weight: 600;
  font-size: .9rem;
  box-shadow: 0 8px 18px rgba(0,0,0,.18);

  z-index: 3;
  top: -0.5rem;
  left: -0.5rem;
  backdrop-filter: blur(2px);
  border: 2px solid rgba(255,255,255,.5);
}

@media (max-width: 768px){
  .hero{padding:3.25rem 0 2.5rem}
  .hero-inner{grid-template-columns:1fr;gap:1.75rem}
  .hero-inner > div:first-child{padding:1.25rem 1.5rem}
  .hero h2{font-size:1.9rem;line-height:1.15}
  .hero-cta{flex-direction:column}
}

/* =========================
   STRIP
   ========================= */
.strip{
  background:linear-gradient(90deg, var(--gold), #fff);
  padding:.65rem 0;
  border-top:1px dashed #F0D7DE;
  border-bottom:1px dashed #F0D7DE;
}

.strip .chip{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;

  width:100%;
  min-height:72px;          /* key: same height */
  padding:.9rem 1.1rem;
  border-radius:999px;

  text-align:center;
  white-space:normal;       /* allow wrapping */
  line-height:1.15;

  background: rgba(255,255,255,.9);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
}

.strip .chip .emoji,
.strip .chip i,
.strip .chip span:first-child{
  width: 1.4em;            /* consistent icon slot */
  display:inline-flex;
  justify-content:center;
}



/* === STRIP: make chips look intentional === */
.strip .row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: stretch;
  max-width: 900px;
  margin: 0 auto;
  padding: 1rem;
}

@media (max-width: 520px){
  .strip .row{
    grid-template-columns: 1fr;
  }
}


/* Mobile: 2-column grid so it doesn't look like a staircase */
@media (max-width: 600px){
  .strip .row{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:.75rem;
    justify-items:center;
  }
  .strip .chip{
    width:100%;
    justify-content:center;
    text-align:center;
  }
}


/* =========================
   SECTIONS
   ========================= */
.section{padding: clamp(2rem, 6vw, 4rem) 0}
.section-header{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.25rem;
  flex-wrap:wrap;
}
.section h3{font:700 1.6rem/1.2 "Playfair Display", serif;margin:0}

#programs{
  background: linear-gradient(160deg, var(--blush) 0%, var(--blush) 35%, var(--cream) 100%);
}

/* Programs */
.programs{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:1rem;
}
.program-card{
  display:grid;
  grid-template-columns: 84px 1fr;
  gap:1rem;
  padding:1rem;
  cursor:pointer;
  position:relative;
}
.program-icon{
  width:44px;height:44px;border-radius:20px;
  background:var(--stone);
  display:grid;place-items:center;
  font-size:1.2rem;
}
.program-title{margin:.2rem 0 .35rem;font-weight:700}
.program-desc{color:var(--muted)}

/* Accordion behavior */
.program-card .program-desc{
  max-height:0;
  overflow:hidden;
  opacity:0;
  margin-top:0;
  transition:max-height .25s ease, opacity .25s ease, margin-top .25s ease;
}
.program-card.expanded .program-desc{
  max-height:200px;
  opacity:1;
  margin-top:.25rem;
}
.program-card::after{
  content:"▾";
  position:absolute;
  right:1rem;
  top:50%;
  transform:translateY(-50%) rotate(-90deg);
  font-size:.8rem;
  color:var(--muted);
  transition: transform .2s ease;
}
.program-card.expanded::after{
  transform:translateY(-50%) rotate(0deg);
}

/* Interest form layout */
#interest{background: var(--cream)}
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
form{display:grid;gap:.75rem}
label{font-weight:600}
input, select, textarea{
  width:100%;
  padding:.9rem .95rem;
  border:1px solid #E7E4DE;
  border-radius:12px;
  background:#fff;
  font:inherit;
}
textarea{min-height:120px}

/* Mailchimp form */
#interest .program-interest-form{
  max-width:480px;
  margin:0 auto;
  padding:1.25rem 1.5rem;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  display:grid;
  gap:.6rem;
}
#interest .program-interest-form input[type="text"],
#interest .program-interest-form input[type="tel"],
#interest .program-interest-form input[type="email"],
#interest .program-interest-form textarea{
  padding:.7rem .9rem;
  border-radius:999px;
  font-size:.9rem;
}
#interest .program-interest-form textarea{
  border-radius:1rem;
  min-height:90px;
  resize:vertical;
}
#interest .programs-group{
  border:none;
  padding:0;
  margin-top:.4rem;
  display:flex;
  flex-direction:column;
  gap:.3rem;
}
#interest .programs-group label{
  font-weight:400;
  display:flex;
  align-items:center;
  gap:.4rem;
  font-size:.9rem;
}
#interest .programs-group input[type="checkbox"]{
  width:16px;height:16px;
}

/* Mission/About sections */
#mission{background: var(--aka-green)}
#mission .card{background: var(--cream);color: var(--ink);backdrop-filter: blur(8px)}
#about{background: var(--cream)}
.about-grid{grid-template-columns:1.1fr .9fr;align-items:center}
.story-copy p{font-size:1.05rem;max-width:40rem}
.story-media{margin:0;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}

/* Donate CTA */
#donate{background: var(--cream)}
.donate-cta{
  padding:1.25rem;
  display:grid;
  grid-template-columns: 1fr auto;
  gap:1rem;
  align-items:center;
  border-radius:var(--radius-lg);
}
.donate-cta h3{
  font:700 clamp(1.25rem, 3.5vw, 2rem)/1.15 "Playfair Display", serif;
  margin:0 0 .15rem 0;
  max-width:28ch;
}
.donate-cta .btn{justify-self:end;white-space:nowrap}

/* Footer */
footer{background: var(--stone);color: var(--ink);padding:2.25rem 0;margin-top:2rem}
footer a{color: var(--ink)}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem}
.foot h4{margin:.2rem 0 1rem;font:700 1.1rem/1.1 Inter}
.newsletter{display:flex;gap:.5rem}
.newsletter input{
  flex:1;
  border-radius:999px;
  border:1px solid var(--ink);
  background:#fff;
  color: var(--ink);
}

/* Responsive */
@media (max-width: 920px){
  .hero-inner{grid-template-columns:1fr}
  .form-wrap{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr}
  .program-card{grid-template-columns:72px 1fr}
}

@media (max-width: 600px){
  .programs{grid-template-columns:1fr}
  .section-header{align-items:flex-start}
  .btn{width:100%}
  .donate-cta{grid-template-columns:1fr;gap:.75rem}
  .donate-cta .btn{justify-self:stretch;width:100%;padding:1rem 1.1rem}
  .about-grid{grid-template-columns:1fr}
  .story-media{order:-1}
  #interest .program-interest-form{
    padding:1rem 1.1rem;
    box-shadow:none;
    border-radius:0;
    background:transparent;
  }
}
/* =========================
   NAV: Desktop vs Mobile (single source of truth)
   Desktop: name left, links right
   Mobile: hamburger + dropdown
   ========================= */

/* Desktop nav hidden by default (mobile-first) */
.nav-desktop{ display:none; }

/* Mobile behavior (<= 768px): show hamburger + dropdown, hide desktop links */
@media (max-width: 768px){
  .nav-toggle{ display:inline-flex; }
  .nav-dropdown{ display:block; }   /* dropdown panel exists; JS controls open state */
  .nav-desktop{ display:none; }
}

/* Desktop behavior (>= 769px): show links right, hide hamburger + dropdown */
@media (min-width: 769px){
  /* show desktop links */
  .nav-desktop{
    display:block;
    margin-left:auto;
  }

  .nav-desktop ul{
    display:flex;
    gap:.4rem;
    list-style:none;
    margin:0;
    padding:0;
    align-items:center;
  }

  .nav-desktop a{
    padding:.5rem .75rem;
    border-radius:999px;
    white-space:nowrap;
    display:block;
  }

  .nav-desktop a:hover{
    background: var(--stone);
  }

  /* hide mobile-only ui */
  .nav-toggle,
  .nav-dropdown{
    display:none !important;
  }
}

/* ===== FINAL NAV BEHAVIOR ===== */

/* Layout */
#navbar-content{
  display:flex;
  align-items:center;
  width:100%;
  gap:.75rem;
}

.brand-name{
  flex:1;
  min-width:0;
}

.nav-toggle{
  margin-left:auto;
}

/* Desktop nav hidden by default (mobile-first) */
.nav-desktop{
  display:none;
}

/* MOBILE */
@media (max-width: 768px){
  .nav-toggle{ display:inline-flex; }
  .nav-dropdown{ display:block; }
}

/* DESKTOP */
@media (min-width: 769px){
  .nav-desktop{
    display:block;
    margin-left:auto;
  }

  .nav-desktop ul{
    display:flex;
    gap:.4rem;
    list-style:none;
    margin:0;
    padding:0;
  }

  .nav-desktop a{
    padding:.5rem .75rem;
    border-radius:999px;
  }

  .nav-desktop a:hover{
    background:var(--stone);
  }

  /* Hide mobile UI */
  .nav-toggle,
  .nav-dropdown{
    display:none !important;
  }
}
