/* ==========================================================================
   Base & Theme
   ========================================================================== */
:root{
  /* Analogous eco-minimal palette */
  --clr-primary: #4caf50;
  --clr-primary-dark: #388e3c;
  --clr-primary-light: #7bcf7d;
  --clr-secondary: #8bc34a;
  --clr-accent: #cddc39;
  --clr-bg: #f8faf7;
  --clr-text: #333333;
  --clr-heading: #222222;
  --clr-white: #ffffff;
  --radius-sm: 4px;
  --radius-md: 8px;
  --shadow-sm: 0 2px 6px rgba(0,0,0,.08);
  --shadow-md: 0 4px 14px rgba(0,0,0,.12);
  --transition: .35s cubic-bezier(.25,.46,.45,.94); /* non-linear */
  --gradient-dark: linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.55));
}

/* ==========================================================================
   Resets & Typography
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',sans-serif;
  color:var(--clr-text);
  background:var(--clr-bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{
  font-family:'Space Grotesk',sans-serif;
  color:var(--clr-heading);
  line-height:1.2;
  text-align:center;
  text-shadow:1px 1px 3px rgba(0,0,0,.2);
  margin-bottom:.8em;
}
p,li,details{font-size:1rem;margin-bottom:1rem}
ul{list-style:none}
a{text-decoration:none;color:var(--clr-primary-dark);transition:color var(--transition)}
a:hover,a:focus{color:var(--clr-accent)}

.container{
  width:90%;
  max-width:1200px;
  margin:0 auto;
}

/* ==========================================================================
   Navigation
   ========================================================================== */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(12px);
  box-shadow:var(--shadow-sm);
}
.site-header nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.4rem;color:var(--clr-primary-dark)}
.nav-list{display:flex;gap:1.5rem}
.burger{display:none;background:none;border:none;cursor:pointer}
.burger span{display:block;width:24px;height:2px;background:var(--clr-heading);margin:5px 0;transition:var(--transition)}
@media(max-width:768px){
  .burger{display:block}
  .nav-list{
    position:fixed;top:64px;right:-100%;flex-direction:column;gap:1rem;
    background:var(--clr-white);padding:1.5rem;width:70%;height:calc(100vh - 64px);
    transition:right var(--transition)
  }
  .nav-list.open{right:0}
}

/* ==========================================================================
   Global Sections
   ========================================================================== */
.section{padding:4.5rem 0}
.alt-bg{background:var(--clr-primary-light);color:var(--clr-white)}
.alt-bg-light{background:#eef6ed}
.section.alt-bg h2,
.section.alt-bg p{color:var(--clr-white)}

.parallax{background-attachment:fixed;background-size:cover;background-repeat:no-repeat}

.progress-bar{background:#dfeedd;border-radius:var(--radius-md);overflow:hidden;margin-top:1.5rem}
.progress-bar span{
  display:block;background:var(--clr-accent);padding:.35rem 0;
  color:var(--clr-heading);font-weight:700;text-align:center
}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero-section{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;background-size:cover;background-repeat:no-repeat;
  position:relative;text-align:center;color:var(--clr-white)
}
.hero-section .stats-widget{
  margin-top:2rem;display:flex;gap:2rem;justify-content:center;flex-wrap:wrap
}
.hero-section .stat{display:flex;flex-direction:column;align-items:center}
.hero-section .stat strong{font-family:'Space Grotesk',sans-serif;font-size:2rem}
.hero-section .btn-primary{margin-top:2rem}

/* ==========================================================================
   Buttons & Links
   ========================================================================== */
.btn-primary,
.btn-secondary,
button,
input[type='submit']{
  display:inline-block;
  border:none;
  cursor:pointer;
  padding:.75rem 1.75rem;
  border-radius:var(--radius-md);
  font-family:'Space Grotesk',sans-serif;
  font-weight:600;
  transition:transform var(--transition),background var(--transition);
}
.btn-primary{
  background:var(--clr-primary);
  color:var(--clr-white);
}
.btn-primary:hover,
.btn-primary:focus{background:var(--clr-primary-dark);transform:translateY(-3px)}
.btn-secondary{
  background:transparent;
  color:var(--clr-primary-dark);
  border:2px solid var(--clr-primary-dark);
}
.btn-secondary:hover,
.btn-secondary:focus{background:var(--clr-primary-dark);color:var(--clr-white);transform:translateY(-3px)}

/* Read-more link */
.read-more{font-weight:600;position:relative;padding-right:1.2rem}
.read-more::after{
  content:'➔';position:absolute;right:0;top:0;transition:transform var(--transition)
}
.read-more:hover::after{transform:translateX(4px)}

/* ==========================================================================
   Cards
   ========================================================================== */
.cards-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem;margin-top:2rem
}
.card,.testimonial,.item,.product-card{
  background:var(--clr-white);border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);padding:1.5rem;display:flex;
  flex-direction:column;align-items:center;text-align:center;
  transition:transform var(--transition),box-shadow var(--transition)
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.card-image{width:100%;height:200px;overflow:hidden;border-radius:var(--radius-sm);margin-bottom:1rem}
.card-image img{width:100%;height:100%;object-fit:cover;display:block;margin:0 auto}

/* ==========================================================================
   Blog
   ========================================================================== */
.blog-post{margin-bottom:2.5rem}
.blog-post h3{text-align:left;margin-bottom:.5rem}
.blog-post p{margin-bottom:.75rem}

/* ==========================================================================
   Events Calendar
   ========================================================================== */
#events .card-content h3{color:var(--clr-primary-dark);margin-bottom:.5rem}

/* ==========================================================================
   FAQ
   ========================================================================== */
details{background:var(--clr-white);border:1px solid #d9e8d2;border-radius:var(--radius-md);padding:1rem}
summary{font-weight:600;cursor:pointer;margin-bottom:.75rem}

/* ==========================================================================
   Contact Form
   ========================================================================== */
form{max-width:640px;margin:0 auto}
.form-group{display:flex;flex-direction:column;margin-bottom:1.25rem}
label{margin-bottom:.4rem;font-weight:600}
input,textarea{
  padding:.75rem;border:2px solid #c7e2c0;border-radius:var(--radius-sm);font:inherit
}
input:focus,textarea:focus{outline:none;border-color:var(--clr-primary-dark)}
textarea{resize:vertical}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{
  background:var(--clr-primary-dark);color:var(--clr-white);padding:2.5rem 0;text-align:center
}
.site-footer nav{margin:1rem 0}
.site-footer a{color:var(--clr-accent);font-weight:500}
.site-footer a:hover{text-decoration:underline}
.site-footer p:last-child{margin-top:1rem}

/* ==========================================================================
   Social Link Styles (text-only)
   ========================================================================== */
.site-footer a[href*="facebook"],
.site-footer a[href*="instagram"],
.site-footer a[href*="x.com"]{
  padding:.25rem .5rem;border-radius:var(--radius-sm);background:rgba(255,255,255,.08);
  margin:0 .25rem;display:inline-block
}
.site-footer a[href*="facebook"]:hover{background:#3b5998;color:var(--clr-white)}
.site-footer a[href*="instagram"]:hover{background:#e1306c;color:var(--clr-white)}
.site-footer a[href*="x.com"]:hover{background:#1da1f2;color:var(--clr-white)}

/* ==========================================================================
   Modal
   ========================================================================== */
.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:2000;align-items:center;justify-content:center}
.modal-content{
  background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  padding:2rem 2.5rem;border-radius:var(--radius-md);text-align:center;
  animation:fadeIn .6s var(--transition) forwards
}
.close-modal{position:absolute;top:1rem;right:1.25rem;font-size:1.75rem;cursor:pointer;color:var(--clr-heading)}
@keyframes fadeIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}

/* ==========================================================================
   Success Page
   ========================================================================== */
.page-success{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--clr-bg);text-align:center;padding:1.5rem
}

/* ==========================================================================
   Privacy & Terms Padding
   ========================================================================== */
.page-legal{padding-top:100px}

/* ==========================================================================
   Non-linear Floating Animation for visual accents
   ========================================================================== */
@keyframes float{
  0%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
  100%{transform:translateY(0)}
}
[data-motion]{animation:float 4.5s ease-in-out infinite}

/* ==========================================================================
   Utility Classes
   ========================================================================== */
.text-center{text-align:center}
.mt-2{margin-top:2rem}
.mb-1{margin-bottom:1rem}