/* ========== KINDNESS GROVE V4 – CLEAN, RESPONSIVE, IMAGE-READY ========== */

:root{
  --kg4-bg: #ebe5da;
  --kg4-bg-soft: #f5efe3;
  --kg4-card: #ffffff;
  --kg4-ink: #201510;
  --kg4-muted: #71685e;
  --kg4-green: #1f7a4a;
  --kg4-orange: #f97316;
  --kg4-border: #d8d1c4;
  --kg4-radius-lg: 24px;
  --kg4-radius: 18px;
  --kg4-shadow: 0 18px 40px rgba(0,0,0,.18);
  --kg4-max: 1160px;
  --kg4-font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* Reset inside wrapper */
.kg4, .kg4 *{
  box-sizing: border-box;
}
.kg4 h1,
.kg4 h2,
.kg4 h3,
.kg4 p{
  margin: 0;
}
.kg4 a{
  color: inherit;
  text-decoration: none;
}

/* Wrapper */
.kg4{
  font-family: var(--kg4-font);
  color: var(--kg4-ink);
  background: radial-gradient(circle at top left,#f5efe0 0,#e3ded3 40%,#dedad0 100%);
}

/* Layout container */
.kg4-container{
  max-width: var(--kg4-max);
  margin: 0 auto;
  padding: 0 20px;
}

/* ========== NAV ========== */
.kg4-nav{
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(14px);
  background: rgba(235,229,218,.94);
  border-bottom: 1px solid rgba(0,0,0,.05);
}
.kg4-nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 12px 0;
  flex-wrap: wrap;
}
.kg4-brand{
  display:flex;
  align-items:center;
  gap: 10px;
  font-weight: 900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size: 12px;
}
.kg4-logo-dot{
  width: 30px;
  height: 30px;
  border-radius: 14px;
  background: conic-gradient(from 130deg,var(--kg4-green),var(--kg4-orange),var(--kg4-green));
  box-shadow: 0 0 0 3px rgba(255,255,255,.9), 0 10px 22px rgba(0,0,0,.22);
}
.kg4-links{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.kg4-links a{
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--kg4-muted);
}
.kg4-links a:hover{
  background: rgba(0,0,0,.05);
  color: var(--kg4-ink);
}

.kg4-actions{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}

.kg4-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid rgba(0,0,0,.08);
  background:#fdfaf4;
}
.kg4-btn.primary{
  border:none;
  background: linear-gradient(135deg,var(--kg4-green),var(--kg4-orange));
  color:#fff;
  box-shadow: 0 14px 30px rgba(0,0,0,.25);
}
.kg4-btn.primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(0,0,0,.3);
}
.kg4-btn.ghost{
  background: transparent;
}

/* ========== GENERIC SECTION ========== */
.kg4-section{
  padding: 72px 0;
}
.kg4-eyebrow{
  font-size: 11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color: var(--kg4-muted);
  font-weight: 800;
}
.kg4-h1{
  font-size: clamp(32px,4.4vw,56px);
  line-height: 1.02;
  font-weight: 980;
}
.kg4-h2{
  font-size: clamp(24px,3.2vw,38px);
  line-height: 1.1;
  font-weight: 900;
}
.kg4-lead{
  margin-top: 14px;
  font-size: 16px;
  line-height: 1.7;
  color: var(--kg4-muted);
  max-width: 70ch;
}

/* ========== HERO (TEXT + IMAGE CARD) ========== */
.kg4-hero{
  padding: 40px 0 44px;
}
.kg4-hero-grid{
  display:grid;
  grid-template-columns: minmax(0,1.3fr) minmax(0,1fr);
  gap: 22px;
  align-items:stretch;
}

/* Hero main card (text) */
.kg4-hero-main{
  background: rgba(255,255,255,.96);
  border-radius: var(--kg4-radius-lg);
  padding: 26px 26px 22px;
  box-shadow: var(--kg4-shadow);
  border: 1px solid rgba(0,0,0,.04);
  position:relative;
  overflow:hidden;
}
.kg4-tag-row{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.kg4-chip{
  padding: 6px 10px;
  border-radius: 999px;
  background:#f3ede1;
  font-size: 11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:800;
  color: var(--kg4-muted);
}
.kg4-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 18px;
}
.kg4-meta-pill{
  padding: 6px 10px;
  border-radius: 999px;
  background:#f7f1e4;
  font-size: 12px;
  color: var(--kg4-muted);
}

/* Hero side – impact + image */
.kg4-hero-side{
  display:grid;
  gap: 14px;
}

.kg4-impact{
  background:#151010;
  color:#fef9f3;
  border-radius: var(--kg4-radius-lg);
  padding: 20px 20px 18px;
  box-shadow: 0 18px 42px rgba(0,0,0,.48);
  position:relative;
  overflow:hidden;
}
.kg4-impact:before{
  content:"";
  position:absolute;
  inset:-40px 50% 40% -30px;
  background: radial-gradient(circle at top,var(--kg4-orange),transparent 70%);
  opacity:.75;
}
.kg4-impact-title{
  font-size: 12px;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:rgba(255,255,255,.7);
  font-weight:800;
}
.kg4-impact-main{
  margin-top: 12px;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  align-items:flex-end;
}
.kg4-impact-main strong{
  font-size: 32px;
  font-weight: 950;
}
.kg4-impact-main span{
  font-size: 13px;
  color:rgba(255,255,255,.9);
}
.kg4-impact-note{
  margin-top: 14px;
  font-size: 13px;
  color:rgba(255,255,255,.88);
  line-height:1.6;
}
.kg4-impact-footer{
  margin-top: 16px;
  font-size: 11px;
  color:rgba(255,255,255,.7);
  display:flex;
  justify-content:space-between;
}

/* Hero image card */
.kg4-hero-image{
  border-radius: var(--kg4-radius-lg);
  min-height: 180px;
  background: url("https://thekindnessgrove.org/wp-content/uploads/2026/02/DSC09930.jpg") center/cover no-repeat;
  position:relative;
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.32);
}
.kg4-hero-image:after{
  content:"FED Square · Melbourne · 5,000+ people";
  position:absolute;
  left: 14px;
  bottom: 14px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,.8);
  color:#fff;
  font-size: 11px;
  font-weight: 700;
}

/* Hero stats under cards */
.kg4-stats{
  display:grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 12px;
  margin-top: 24px;
}
.kg4-stat{
  background: rgba(255,255,255,.92);
  border-radius: var(--kg4-radius);
  padding: 14px;
  border: 1px solid rgba(0,0,0,.04);
}
.kg4-stat .n{
  font-size: 18px;
  font-weight: 900;
}
.kg4-stat .t{
  margin-top: 4px;
  font-size: 12px;
  color: var(--kg4-muted);
}

/* ========== GENERIC CARDS & GRID ========== */
.kg4-grid{ display:grid; gap: 16px; }
.kg4-3{ grid-template-columns: repeat(3,minmax(0,1fr)); }
.kg4-2{ grid-template-columns: repeat(2,minmax(0,1fr)); }

.kg4-card{
  background: var(--kg4-card);
  border-radius: var(--kg4-radius);
  padding: 20px;
  border: 1px solid var(--kg4-border);
  box-shadow: 0 16px 38px rgba(0,0,0,.08);
}
.kg4-soft{
  background: rgba(255,255,255,.9);
  border-radius: var(--kg4-radius);
  padding: 18px;
  border: 1px solid rgba(0,0,0,.04);
}

.kg4-icon{
  width:44px;
  height:44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background:#f3ede1;
  font-size:22px;
}

.kg4-list{
  margin-top: 10px;
  padding-left: 18px;
  color: var(--kg4-muted);
  line-height: 1.9;
}

/* ========== GALLERY ========== */
.kg4-gallery-grid{
  display:grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 14px;
  margin-top: 18px;
}
.kg4-photo{
  position:relative;
  border-radius: var(--kg4-radius);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 16px 38px rgba(0,0,0,.18);
}
.kg4-photo img{
  width:100%;
  height: 220px;
  object-fit:cover;
  display:block;
  transition: transform .35s ease;
}
.kg4-photo:hover img{ transform:scale(1.04); }
.kg4-cap{
  position:absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.75);
  color:#fff;
  font-size: 12px;
  font-weight: 700;
}

/* ========== SHORTS / HIGHLIGHTS ========== */
.kg4-shorts{
  display:grid;
  grid-template-columns: repeat(2,minmax(0,1fr));
  gap: 16px;
  margin-top: 18px;
}
.kg4-short{
  background: var(--kg4-card);
  border-radius: var(--kg4-radius);
  padding: 14px;
  border: 1px solid var(--kg4-border);
  box-shadow: 0 16px 36px rgba(0,0,0,.08);
}
.kg4-chip{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  background:#f3ede1;
  font-size: 11px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:800;
  color: var(--kg4-muted);
  margin-bottom: 10px;
}
.kg4-short iframe{
  width:100%;
  aspect-ratio: 9/16;
  border:0;
  border-radius: 16px;
}

/* ========== SPLIT 2-COLUMN ========== */
.kg4-split{
  display:grid;
  grid-template-columns: repeat(2,minmax(0,1fr));
  gap: 18px;
}

/* ========== DONATE ========== */
.kg4-donate-grid{
  display:grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  gap: 16px;
}
.kg4-tag{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius:999px;
  background:#f3ede1;
  font-size: 11px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:800;
  color: var(--kg4-muted);
}

/* ========== FOOTER ========== */
.kg4-footer{
  padding: 26px 0 32px;
  border-top: 1px solid rgba(0,0,0,.08);
  background:#e4ddd1;
  font-size:13px;
  color: var(--kg4-muted);
}

/* ========== RESPONSIVE ========== */
@media (max-width: 980px){
  .kg4-nav-inner{
    flex-direction: column;
    align-items:flex-start;
    gap: 6px;
  }
  .kg4-actions{
    width:100%;
  }

  .kg4-hero-grid{
    grid-template-columns:minmax(0,1fr);
  }
  .kg4-hero-main{ order:1; }
  .kg4-hero-side{ order:2; }

  .kg4-stats{
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
  .kg4-3,
  .kg4-2,
  .kg4-split{
    grid-template-columns:minmax(0,1fr);
  }
  .kg4-gallery-grid{
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
  .kg4-donate-grid{
    grid-template-columns:minmax(0,1fr);
  }
}

@media (max-width: 540px){
  .kg4-container{
    padding: 0 14px;
  }
  .kg4-gallery-grid,
  .kg4-stats{
    grid-template-columns:minmax(0,1fr);
  }
}

/* ========== PARTNERS / LOGO STRIP ========== */

.kg4-partners-grid{
  display:grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 16px;
  align-items:stretch;
}

.kg4-logo-card{
  background: rgba(255,255,255,.95);
  border-radius: 18px;
  padding: 14px 14px 12px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap: 10px;
}

.kg4-logo-wrap{
  width: 120px;
  height: 60px;
  border-radius: 14px;
  background:#f3ede1;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.kg4-logo-wrap img{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display:block;
}

.kg4-logo-text{
  display:flex;
  flex-direction:column;
  gap: 2px;
}

.kg4-logo-text strong{
  font-size: 13px;
  font-weight: 800;
}

.kg4-logo-text span{
  font-size: 12px;
  color: var(--kg4-muted);
}

/* Responsive layout for partners */
@media (max-width: 980px){
  .kg4-partners-grid{
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 540px){
  .kg4-partners-grid{
    grid-template-columns:minmax(0,1fr);
  }
}