/* ==========================================================================
   LEMON-AIDE CO. — Sparkly community styling
   Fonts: Fraunces (display, soft + bouncy) + Plus Jakarta Sans (body)
   ========================================================================== */

:root{
  /* Cape Cod citrus + seaglass — distinct from lemonadio's pure-yellow direction */
  --lemon:        #FFC83D;       /* warmer marigold */
  --lemon-deep:   #E89A1F;
  --lemon-soft:   #FFEFCC;
  --rind:         #1F6F4A;       /* deeper bay-pine green */
  --rind-soft:    #B6DCC4;
  --sea:          #2E8C8A;       /* primary — seaglass teal */
  --sea-deep:     #1A5C5B;
  --sea-soft:     #CFE8E5;
  --sky:          #6BC1D9;       /* cape cod ocean */
  --sky-deep:     #2879A0;
  --coral:        #E8553D;       /* sunset coral pop */
  --coral-soft:   #FBD7CE;
  --plum:         #20283A;       /* deep navy-slate text */
  --cream:        #FBF6EA;       /* sand */
  --paper:        #FAF4E4;       /* warm dune */
  --ink:          #1A2030;
  --ink-soft:     #50586B;
  --line:         #E4DCC8;

  --shadow-sm: 0 2px 6px rgba(42,26,61,.08);
  --shadow-md: 0 8px 24px rgba(42,26,61,.10);
  --shadow-lg: 0 18px 48px rgba(42,26,61,.14);

  --radius-sm: 10px;
  --radius:    18px;
  --radius-lg: 28px;

  --max:       1200px;
  --header-h:  84px;

  --font-display: "Fraunces", "Recoleta", "Playfair Display", Georgia, serif;
  --font-body:    "Plus Jakarta Sans", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:color .2s ease;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit;}

.container{max-width:var(--max);margin:0 auto;padding:0 28px;}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,253,247,.92);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
  height:var(--header-h);
  padding-top:env(safe-area-inset-top);
}
.header-inner{
  max-width:var(--max);margin:0 auto;height:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
  padding-left:max(28px, env(safe-area-inset-left));
  padding-right:max(28px, env(safe-area-inset-right));
}
.site-logo a{display:flex;align-items:center;gap:14px;}
.site-logo img{height:46px;width:auto;}
.site-logo .brand-mark{
  font-family:var(--font-display);
  font-weight:900;font-size:1.35rem;letter-spacing:-.01em;
  color:var(--plum);line-height:1;
}
.site-logo .brand-mark em{font-style:italic;color:var(--lemon-deep);}

.nav-menu{display:flex;align-items:center;gap:6px;}
.nav-menu a{
  display:inline-block;padding:10px 16px;border-radius:999px;
  font-weight:600;font-size:.95rem;color:var(--ink-soft);
  position:relative;
}
.nav-menu a:hover{color:var(--plum);background:var(--lemon-soft);}
.nav-menu a.active{color:var(--plum);background:var(--lemon);}

.nav-cta{
  margin-left:8px;padding:11px 22px;border-radius:999px;
  background:var(--plum);color:var(--cream)!important;
  font-weight:700;font-size:.92rem;
}
.nav-cta:hover{background:var(--coral);transform:translateY(-1px);}

.mobile-menu-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;padding:10px;
  background:transparent;border:0;cursor:pointer;
  border-radius:10px;
}
.mobile-menu-toggle:hover{background:var(--lemon-soft);}
.mobile-menu-toggle span{width:24px;height:3px;background:var(--plum);border-radius:2px;transition:.25s ease;display:block;}
.mobile-menu-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.mobile-menu-toggle.active span:nth-child(2){opacity:0;}
.mobile-menu-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;border-radius:999px;
  font-weight:700;font-size:.97rem;letter-spacing:.01em;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  border:2px solid transparent;cursor:pointer;
}
.btn svg{width:18px;height:18px;}
.btn-primary{background:var(--sea);color:#fff;}
.btn-primary:hover{background:var(--sea-deep);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 6px 0 0 #B5402C;}
.btn-coral:hover{transform:translateY(-2px);box-shadow:0 8px 0 0 #B5402C;}
.btn-coral:active{transform:translateY(2px);box-shadow:0 2px 0 0 #B5402C;}
.btn-sea{background:var(--sea);color:#fff;box-shadow:0 6px 0 0 var(--sea-deep);}
.btn-sea:hover{transform:translateY(-2px);box-shadow:0 8px 0 0 var(--sea-deep);}
.btn-sea:active{transform:translateY(2px);box-shadow:0 2px 0 0 var(--sea-deep);}
.btn-lemon{background:var(--lemon);color:var(--plum);box-shadow:0 6px 0 0 var(--lemon-deep);}
.btn-lemon:hover{transform:translateY(-2px);box-shadow:0 8px 0 0 var(--lemon-deep);}
.btn-lemon:active{transform:translateY(2px);box-shadow:0 2px 0 0 var(--lemon-deep);}
.btn-outline{background:transparent;color:var(--plum);border-color:var(--plum);}
.btn-outline:hover{background:var(--plum);color:var(--cream);}
.btn-ghost-light{background:transparent;color:var(--cream);border-color:rgba(255,255,255,.55);}
.btn-ghost-light:hover{background:var(--cream);color:var(--plum);border-color:var(--cream);}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  padding:120px 28px 140px;
  background:
    radial-gradient(ellipse at 85% 10%, rgba(255,210,63,.55), transparent 55%),
    radial-gradient(ellipse at 5% 95%, rgba(79,195,247,.35), transparent 55%),
    var(--paper);
}
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;
  color:var(--rind);margin-bottom:24px;
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--lemon);box-shadow:0 0 0 4px var(--lemon-soft);}
.hero h1{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(2.6rem,5.6vw,5rem);
  line-height:1.02;letter-spacing:-.025em;color:var(--plum);
  margin-bottom:24px;
  text-wrap:balance;
}
.hero h1 em{
  font-style:italic;font-weight:500;
  background:linear-gradient(180deg, transparent 60%, var(--lemon) 60%);
  padding:0 .12em;
}
.hero h1 .squiggle{
  display:inline-block;position:relative;
}
.hero h1 .squiggle::after{
  content:"";position:absolute;left:0;right:0;bottom:-.1em;height:.18em;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 12' preserveAspectRatio='none'><path d='M2 8 Q 15 1, 30 6 T 60 6 T 90 6 T 118 6' stroke='%23FF6F61' stroke-width='3' fill='none' stroke-linecap='round'/></svg>") center/100% 100% no-repeat;
}
.hero p.lede{font-size:1.18rem;color:var(--ink-soft);max-width:540px;margin-bottom:32px;text-wrap:pretty;}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;}

.hero-art{position:relative;aspect-ratio:1/1.05;}
.hero-art .photo{
  position:absolute;inset:0;border-radius:var(--radius-lg);
  overflow:hidden;background:var(--lemon-soft);
  box-shadow:var(--shadow-lg);
  transform:rotate(-2deg);
}
.hero-art .photo img{width:100%;height:100%;object-fit:cover;}
.hero-art .badge{
  position:absolute;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-md);padding:14px 18px;
  font-weight:700;color:var(--plum);font-size:.92rem;
  display:flex;align-items:center;gap:10px;
}
.hero-art .badge .ico{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;}
.hero-art .badge.b1{top:8%;left:-6%;transform:rotate(-4deg);}
.hero-art .badge.b1 .ico{background:var(--lemon);}
.hero-art .badge.b2{bottom:14%;right:-8%;transform:rotate(3deg);}
.hero-art .badge.b2 .ico{background:var(--rind-soft);color:var(--rind);}
.hero-art .badge.b3{top:62%;left:-10%;transform:rotate(-3deg);}
.hero-art .badge.b3 .ico{background:var(--sea-soft);color:var(--sea-deep);}

.hero-art .sparkle{
  position:absolute;color:var(--lemon-deep);
  font-size:32px;animation:twinkle 2.6s ease-in-out infinite;
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.04));
}
.hero-art .s1{top:-6%;right:18%;animation-delay:.0s;}
.hero-art .s2{bottom:-2%;left:34%;animation-delay:.7s;color:var(--coral);}
.hero-art .s3{top:30%;right:-3%;animation-delay:1.3s;color:var(--sky-deep);font-size:22px;}
@keyframes twinkle{
  0%,100%{transform:scale(1) rotate(0);opacity:.95;}
  50%{transform:scale(1.25) rotate(15deg);opacity:1;}
}

/* Wave divider */
.wave-divider{display:block;width:100%;height:80px;margin-bottom:-1px;}

/* ==========================================================================
   Sections
   ========================================================================== */
.section{padding:96px 28px;}
.section-cream{background:var(--cream);}
.section-lemon{background:var(--lemon-soft);position:relative;}
.section-sea{background:var(--sea-soft);position:relative;}
.section-coral{background:var(--coral-soft);position:relative;}
.section-plum{background:var(--plum);color:var(--cream);}
.section-paper{background:var(--paper);}

.eyebrow{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  color:var(--rind);margin-bottom:18px;
}
.section-lemon .eyebrow{background:#fff;}
.section-sea .eyebrow{background:#fff;color:var(--sea-deep);}
.section-coral .eyebrow{background:#fff;color:var(--coral);}
.section-plum .eyebrow{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:var(--lemon);}

h2.h-display, .h-display{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.05;letter-spacing:-.02em;
  color:var(--plum);margin-bottom:18px;text-wrap:balance;
}
.section-plum .h-display{color:var(--cream);}
.h-display em{font-style:italic;font-weight:500;color:var(--lemon-deep);}
.section-plum .h-display em{color:var(--lemon);}

.lede{font-size:1.08rem;color:var(--ink-soft);max-width:680px;text-wrap:pretty;}
.section-plum .lede{color:rgba(255,253,242,.8);}

.section-head{max-width:var(--max);margin:0 auto 56px;}
.section-head.center{text-align:center;}
.section-head.center .lede{margin:0 auto;}

/* ==========================================================================
   Two column
   ========================================================================== */
.two-col{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.two-col.flip > :first-child{order:2;}
.col-content{padding:8px;}
.col-image{position:relative;}
.col-image .frame{
  border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;
  background:var(--lemon-soft);box-shadow:var(--shadow-lg);
  transform:rotate(-1.5deg);
}
.col-image .frame img{width:100%;height:100%;object-fit:cover;}
.col-image .sticker{
  position:absolute;top:-22px;right:-22px;
  width:120px;height:120px;border-radius:50%;
  background:var(--coral);color:#fff;
  display:grid;place-items:center;text-align:center;
  font-family:var(--font-display);font-style:italic;font-weight:700;
  font-size:1rem;line-height:1.1;padding:14px;
  box-shadow:var(--shadow-md);
  animation:spin 18s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ==========================================================================
   Pillars / Info cards
   ========================================================================== */
.pillars{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;
}
.pillar{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:32px 26px 28px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent;}
.pillar .ico{
  width:56px;height:56px;border-radius:18px;
  display:grid;place-items:center;margin-bottom:18px;
  background:var(--lemon);color:var(--plum);
  box-shadow:0 6px 0 0 var(--lemon-deep);
}
.pillar:nth-child(2) .ico{background:var(--rind-soft);color:var(--rind);box-shadow:0 6px 0 0 #94c98a;}
.pillar:nth-child(3) .ico{background:var(--sea-soft);color:var(--sea-deep);box-shadow:0 6px 0 0 #6FAFAD;}
.pillar:nth-child(4) .ico{background:var(--coral-soft);color:var(--coral);box-shadow:0 6px 0 0 #C28177;}
.pillar:nth-child(5) .ico{background:var(--lemon-soft);color:var(--lemon-deep);box-shadow:0 6px 0 0 #E0BD3C;}
.pillar .ico svg{width:28px;height:28px;}
.pillar h3{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--plum);margin-bottom:8px;}
.pillar h3 a{color:inherit;}
.pillar h3 a:hover{color:var(--coral);}
.pillar p{color:var(--ink-soft);font-size:.97rem;line-height:1.6;}
.pillar .ext-link{
  display:inline-flex;align-items:center;gap:6px;margin-top:14px;
  font-weight:700;font-size:.85rem;color:var(--rind);
}
.pillar .ext-link:hover{color:var(--coral);}

/* ==========================================================================
   Stats strip
   ========================================================================== */
.stats{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.stat{
  background:#fff;border-radius:var(--radius);padding:28px 24px;
  border:1px solid var(--line);text-align:left;
}
.stat .num{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2.2rem,3.4vw,3rem);line-height:1;color:var(--plum);
  margin-bottom:6px;letter-spacing:-.02em;
}
.stat .num em{font-style:normal;color:var(--lemon-deep);}
.stat .label{font-size:.95rem;color:var(--ink-soft);font-weight:500;}

/* ==========================================================================
   Board / Team
   ========================================================================== */
.board-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;
}
.board-card{
  background:#fff;border-radius:var(--radius);padding:28px 24px;
  border:1px solid var(--line);text-align:center;
  transition:transform .25s ease, box-shadow .25s ease;
}
.board-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.board-photo{
  width:140px;height:140px;border-radius:50%;
  margin:0 auto 18px;
  background:var(--lemon-soft);
  border:5px solid var(--lemon);
  overflow:hidden;
  position:relative;
}
.board-photo img{width:100%;height:100%;object-fit:cover;}
.board-photo.placeholder{
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:900;font-size:2.4rem;
  color:var(--plum);background:var(--lemon);
}
.board-name{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--plum);margin-bottom:4px;}
.board-role{
  display:inline-block;padding:4px 12px;border-radius:999px;
  background:var(--lemon-soft);color:var(--rind);
  font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:14px;
}
.board-bio{color:var(--ink-soft);font-size:.93rem;line-height:1.6;text-wrap:pretty;}

/* ==========================================================================
   Image cards (3-up gallery)
   ========================================================================== */
.gallery{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;
}
.gallery .card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;flex-direction:column;
}
.gallery .card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.gallery .card-img{aspect-ratio:16/11;overflow:hidden;}
.gallery .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.gallery .card:hover .card-img img{transform:scale(1.05);}
.gallery .card-body{padding:24px;flex:1;display:flex;flex-direction:column;}
.gallery .tag{
  display:inline-block;padding:4px 12px;border-radius:999px;
  background:var(--lemon);color:var(--plum);
  font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:12px;align-self:flex-start;
}
.gallery h3{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--plum);margin-bottom:8px;line-height:1.25;}
.gallery p{color:var(--ink-soft);font-size:.95rem;margin-bottom:16px;flex:1;}
.gallery .meta-row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--ink-soft);margin-bottom:10px;}

/* ==========================================================================
   Testimonials
   ========================================================================== */
.testimonial-wrap{max-width:880px;margin:0 auto;text-align:center;}
.testimonial{
  background:#fff;border-radius:var(--radius-lg);
  padding:56px 48px;box-shadow:var(--shadow-md);
  border:1px solid var(--line);position:relative;
}
.testimonial::before{
  content:"“";position:absolute;top:-30px;left:36px;
  font-family:var(--font-display);font-size:120px;font-weight:900;
  color:var(--lemon);line-height:1;
}
.testimonial-text{
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(1.2rem,2vw,1.6rem);
  color:var(--plum);line-height:1.4;margin-bottom:28px;text-wrap:pretty;
}
.testimonial-author{display:flex;align-items:center;justify-content:center;gap:14px;}
.testimonial-author-img{width:54px;height:54px;border-radius:50%;overflow:hidden;border:3px solid var(--lemon);}
.testimonial-author-img img{width:100%;height:100%;object-fit:cover;}
.testimonial-author-name{font-weight:700;color:var(--plum);}
.testimonial-author-title{font-size:.85rem;color:var(--ink-soft);}
.slider-dots{display:flex;gap:10px;justify-content:center;margin-top:28px;}
.slider-dot{width:10px;height:10px;border-radius:50%;background:#D9D2BF;transition:.25s;}
.slider-dot.active{background:var(--lemon-deep);width:30px;border-radius:5px;}

/* ==========================================================================
   CTA
   ========================================================================== */
.cta{
  position:relative;overflow:hidden;
  background:var(--plum);color:var(--cream);
  padding:88px 28px;text-align:center;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 12% 20%, rgba(255,210,63,.18), transparent 40%),
    radial-gradient(circle at 88% 80%, rgba(79,195,247,.16), transparent 40%);
  pointer-events:none;
}
.cta-inner{position:relative;max-width:780px;margin:0 auto;}
.cta-eyebrow{
  display:inline-block;padding:6px 16px;border-radius:999px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:var(--lemon);font-weight:700;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;
}
.cta h2{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2rem,4vw,3rem);line-height:1.1;letter-spacing:-.02em;
  margin-bottom:28px;text-wrap:balance;
}
.cta h2 em{font-style:italic;color:var(--lemon);}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{
  background:#1A0F2B;color:#CFC6E0;padding:64px 28px 28px;
}
.footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
}
.footer-brand p{color:#9B8FB8;font-size:.95rem;margin-top:14px;max-width:300px;}
.footer-brand .brand-mark{font-family:var(--font-display);font-size:1.6rem;font-weight:900;color:#fff;}
.footer-brand .brand-mark em{font-style:italic;color:var(--lemon);}
.footer-col h4{
  font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;
  color:#fff;margin-bottom:16px;
}
.footer-col ul{display:flex;flex-direction:column;gap:10px;}
.footer-col a{color:#9B8FB8;font-size:.95rem;}
.footer-col a:hover{color:var(--lemon);}
.footer-bottom{
  max-width:var(--max);margin:48px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:.85rem;color:#7A6F94;
}
.social-row{display:flex;gap:10px;}
.social-row a{
  width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:#CFC6E0;
  transition:.2s;
}
.social-row a:hover{background:var(--lemon);color:var(--plum);}
.social-row svg{width:18px;height:18px;}

/* ==========================================================================
   Page hero (smaller, used on inner pages)
   ========================================================================== */
.page-hero{
  position:relative;overflow:hidden;
  padding:96px 28px 80px;text-align:center;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,210,63,.45), transparent 60%),
    var(--paper);
}
.page-hero h1{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em;
  color:var(--plum);margin:14px 0 14px;text-wrap:balance;
}
.page-hero h1 em{font-style:italic;color:var(--lemon-deep);}
.page-hero p{color:var(--ink-soft);max-width:620px;margin:0 auto;font-size:1.1rem;}

/* ==========================================================================
   Donate / funding cards (Pour Some Good)
   ========================================================================== */
.fund-list{max-width:1000px;margin:0 auto;display:flex;flex-direction:column;gap:18px;}
.fund-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;
  transition:transform .2s ease, box-shadow .2s ease;
}
.fund-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.fund-card .info h3{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--plum);margin-bottom:6px;}
.fund-card .info p{color:var(--ink-soft);font-size:.97rem;margin-bottom:12px;max-width:560px;}
.fund-card .goal{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--lemon-soft);color:var(--rind);
  font-weight:700;font-size:.85rem;
}
.fund-card .goal::before{content:"🎯";}

/* Donate mini chips (homepage) */
.donate-mini{
  max-width:1080px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;
}
.donate-chip{
  display:flex;align-items:center;gap:14px;
  background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:16px 18px;
  transition:.2s ease;
}
.donate-chip:hover{
  transform:translateY(-3px);
  border-color:var(--coral);
  box-shadow:0 10px 28px rgba(232,85,61,.14);
}
.donate-chip .dc-ico{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  display:grid;place-items:center;font-size:20px;
}
.donate-chip .dc-body{display:flex;flex-direction:column;flex:1;gap:2px;line-height:1.35;}
.donate-chip .dc-body strong{font-family:var(--font-display);font-weight:800;color:var(--plum);font-size:1.04rem;}
.donate-chip .dc-body small{font-size:.82rem;color:var(--ink-soft);}
.donate-chip .dc-arrow{
  font-size:1.1rem;color:var(--coral);font-weight:800;
  transition:transform .2s ease;
}
.donate-chip:hover .dc-arrow{transform:translateX(4px);}

/* Contact form */
.contact-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;
}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px;
  box-shadow:var(--shadow-sm);
}
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.form-row label{font-weight:700;font-size:.88rem;color:var(--plum);}
.form-row input, .form-row textarea, .form-row select{
  font-family:inherit;font-size:1rem;padding:12px 14px;border-radius:12px;
  border:1.5px solid var(--line);background:var(--paper);color:var(--ink);
  transition:border-color .2s ease;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus{
  outline:none;border-color:var(--lemon-deep);
}
.form-row textarea{min-height:140px;resize:vertical;}

.contact-list{display:flex;flex-direction:column;gap:18px;}
.contact-row{
  display:flex;gap:16px;align-items:flex-start;
  padding:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
}
.contact-row .ico{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--lemon);color:var(--plum);
  display:grid;place-items:center;
}
.contact-row .ico svg{width:20px;height:20px;}
.contact-row h4{font-weight:800;color:var(--plum);font-size:1rem;margin-bottom:2px;}
.contact-row p{color:var(--ink-soft);font-size:.95rem;}
.contact-row a{color:var(--rind);font-weight:600;}
.contact-row a:hover{color:var(--coral);}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .stats{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:820px){
  :root{--header-h:64px;}
  .header-inner{padding:0 18px;}
  .site-logo img{height:38px;}
  .hero{padding:80px 24px 100px;}
  .hero-inner{grid-template-columns:1fr;gap:60px;}
  .hero-art{max-width:440px;margin:0 auto;width:100%;}
  .two-col{grid-template-columns:1fr;gap:40px;}
  .two-col.flip > :first-child{order:0;}
  .col-image .frame{aspect-ratio:5/4;transform:none;}
  .fund-card{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}

  .nav-menu{
    position:fixed;inset:var(--header-h) 0 auto 0;
    flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:14px 20px calc(20px + env(safe-area-inset-bottom));
    gap:4px;z-index:99;
    transform:translateY(-110%);transition:transform .25s ease;
    box-shadow:var(--shadow-md);
    max-height:calc(100vh - var(--header-h));overflow-y:auto;
  }
  .nav-menu a{padding:14px 16px;font-size:1rem;border-radius:12px;}
  .nav-cta{margin-left:0;margin-top:6px;text-align:center;padding:14px 20px;}
  .main-navigation.active .nav-menu{transform:translateY(0);}
  .mobile-menu-toggle{display:flex;}
}
@media (max-width:520px){
  .section{padding:72px 24px;}
  .hero{padding:64px 24px 80px;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}
  .stats{grid-template-columns:1fr 1fr;}
  .col-image .sticker{width:90px;height:90px;font-size:.82rem;top:-10px;right:-10px;}
}
