/* === DESIGN TOKENS === */
:root {
  --primary: #1B5E20;
  --primary-light: #2E7D32;
  --primary-mid: #388E3C;
  --accent: #4CAF50;
  --accent-light: #81C784;
  --light-bg: #F1F8E9;
  --cream: #FAFDF8;
  --dark: #111827;
  --text: #374151;
  --text-muted: #6B7280;
  --white: #fff;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow: 0 4px 20px rgba(27,94,32,.10), 0 1px 3px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 40px rgba(27,94,32,.15), 0 4px 12px rgba(0,0,0,.08);
  --radius: 12px;
  --radius-lg: 20px;
  --max-w: 1200px;
  --transition: .3s cubic-bezier(.4,0,.2,1);
  --transition-fast: .15s cubic-bezier(.4,0,.2,1);
}

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Merriweather',serif;color:var(--dark);line-height:1.3}
a{color:var(--primary-light);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}

/* === SKIP LINK === */
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--primary);color:#fff;padding:.5rem 1rem;z-index:9999;border-radius:0 0 var(--radius) var(--radius)}
.skip-link:focus{top:0}

/* === CONTAINER === */
.container{width:90%;max-width:var(--max-w);margin:0 auto}

/* === HEADER / NAV === */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.08);transition:box-shadow var(--transition),background var(--transition)}
.site-header.scrolled{box-shadow:var(--shadow)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0}
.nav-logo{display:flex;align-items:center;gap:.6rem}
.nav-logo img{height:48px;width:auto}
.nav-logo span{font-family:'Merriweather',serif;font-weight:700;font-size:1rem;color:var(--primary)}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{font-weight:500;font-size:.95rem;color:var(--dark);position:relative;padding:.3rem 0;letter-spacing:.01em}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:2px;transition:width var(--transition)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.nav-toggle span{width:26px;height:3px;background:var(--primary);border-radius:2px;transition:var(--transition)}

@media(max-width:768px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:70%;max-width:300px;height:100vh;flex-direction:column;background:var(--white);box-shadow:-4px 0 20px rgba(0,0,0,.1);padding:5rem 2rem 2rem;gap:1.5rem;transition:right var(--transition);z-index:999}
  .nav-links.open{right:0}
  .nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:998;display:none}
  .nav-overlay.open{display:block}
}

/* === HERO === */
.hero{background:linear-gradient(160deg,#0d3312 0%,#1a4d20 45%,#1e5924 100%);color:#fff;text-align:center;padding:7rem 1rem 6rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 30% 50%,rgba(56,142,60,.25),transparent 70%),radial-gradient(ellipse 40% 60% at 80% 20%,rgba(76,175,80,.12),transparent 60%);pointer-events:none}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:1rem;color:#fff !important;text-shadow:0 2px 20px rgba(0,0,0,.35);letter-spacing:-.01em;position:relative}
.hero p{font-size:clamp(.95rem,2.2vw,1.15rem);max-width:640px;margin:0 auto 2.5rem;color:rgba(255,255,255,.88);line-height:1.85;position:relative}
.hero .logo-hero{height:90px;margin:0 auto 2rem;background:rgba(255,255,255,.97);border-radius:14px;padding:8px 18px;box-shadow:0 8px 32px rgba(0,0,0,.25);position:relative}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* Page hero (inner pages) */
.page-hero{background:linear-gradient(160deg,#0d3312 0%,#1a4d20 45%,#1e5924 100%);color:#fff;text-align:center;padding:3.5rem 1rem 2.5rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 30% 50%,rgba(56,142,60,.25),transparent 70%);pointer-events:none}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);color:#fff !important;position:relative}
.page-hero p{opacity:.88;margin-top:.5rem;font-size:1.05rem;color:#fff;position:relative}

/* Breadcrumb */
.breadcrumb{padding:.75rem 0;font-size:.9rem}
.breadcrumb a{color:var(--primary-light)}
.breadcrumb span{color:var(--text);margin:0 .4rem}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2.1rem;border-radius:50px;font-weight:600;font-size:.95rem;transition:all var(--transition);cursor:pointer;border:none;letter-spacing:.01em}
.btn-primary{background:linear-gradient(135deg,var(--accent),#2E7D32);color:var(--white);box-shadow:0 4px 15px rgba(76,175,80,.35)}
.btn-primary:hover{background:linear-gradient(135deg,#5CCC60,var(--primary-light));color:var(--white);transform:translateY(-2px);box-shadow:0 8px 25px rgba(76,175,80,.45)}
.btn-outline{background:rgba(255,255,255,.1);color:var(--white);border:2px solid rgba(255,255,255,.7);backdrop-filter:blur(4px)}
.btn-outline:hover{background:var(--white);color:var(--primary);border-color:var(--white);transform:translateY(-2px)}
.btn-green{background:var(--primary);color:var(--white);box-shadow:var(--shadow-sm)}
.btn-green:hover{background:var(--primary-light);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow)}

/* === SECTIONS === */
.section{padding:4rem 0}
.section-alt{background:var(--light-bg)}
.section-title{text-align:center;margin-bottom:2.5rem}
.section-title h2{font-size:clamp(1.6rem,3.5vw,2.2rem);margin-bottom:.5rem}
.section-title p{color:var(--text);max-width:600px;margin:0 auto;font-size:1.05rem}

/* === MISSION STRIP === */
.mission-strip{background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:var(--white);text-align:center;padding:2.5rem 1rem;position:relative;overflow:hidden}
.mission-strip::before{content:'"';position:absolute;font-size:20rem;font-family:'Merriweather',serif;color:rgba(255,255,255,.04);top:-4rem;left:1rem;line-height:1;pointer-events:none}
.mission-strip p{font-size:clamp(1rem,2.2vw,1.2rem);font-style:italic;max-width:800px;margin:0 auto;position:relative;z-index:1;opacity:.95;line-height:1.8}

/* === CARDS GRID === */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.75rem}
.card{background:var(--white);border-radius:var(--radius-lg);padding:2.25rem 1.75rem;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition);text-align:center;position:relative;overflow:hidden;border:1px solid rgba(27,94,32,.06)}
.card::before{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(76,175,80,.06),transparent);opacity:0;transition:opacity var(--transition)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card:hover::before{opacity:1}
.card .icon{width:68px;height:68px;margin:0 auto 1.25rem;background:linear-gradient(135deg,var(--light-bg),rgba(76,175,80,.12));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(27,94,32,.1)}
.card .icon svg{width:32px;height:32px;stroke:var(--primary);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:1.15rem;margin-bottom:.6rem;color:var(--primary)}
.card p{font-size:.93rem;color:var(--text-muted);line-height:1.7}
.card a.card-link{display:inline-flex;align-items:center;gap:.3rem;margin-top:1.1rem;font-weight:600;color:var(--primary-light);font-size:.92rem;transition:gap var(--transition)}
.card a.card-link:hover{gap:.6rem;color:var(--accent)}

/* === STATS === */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center;padding:2rem 0}
.stat-item{padding:1.5rem 1rem;border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow-sm);border:1px solid rgba(27,94,32,.06);transition:transform var(--transition)}
.stat-item:hover{transform:translateY(-4px)}
.stat-item h3{font-size:clamp(2rem,4vw,2.8rem);color:var(--primary);margin-bottom:.25rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-item p{font-size:.9rem;color:var(--text-muted);font-weight:500;letter-spacing:.02em;text-transform:uppercase}

/* === CTA SECTION === */
.cta-section{background:linear-gradient(135deg,#0d3b14,var(--primary-light),var(--primary-mid));color:var(--white);text-align:center;padding:4.5rem 2rem;border-radius:var(--radius-lg);margin:2rem auto;max-width:var(--max-w);position:relative;overflow:hidden;box-shadow:0 20px 60px rgba(27,94,32,.25)}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 0%,rgba(76,175,80,.2),transparent)}
.cta-section>*{position:relative;z-index:1}
.cta-section h2{color:var(--white);margin-bottom:.75rem;font-size:clamp(1.6rem,3vw,2.2rem)}
.cta-section p{margin-bottom:1.75rem;opacity:.9;max-width:560px;margin-left:auto;margin-right:auto}

/* === TWO COLUMNS === */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
@media(max-width:768px){.two-col{grid-template-columns:1fr;gap:1.5rem}}
.two-col.reverse .col-visual{order:-1}
@media(max-width:768px){.two-col.reverse .col-visual{order:0}}

/* Visual placeholder (SVG decorative) */
.col-visual{background:var(--light-bg);border-radius:var(--radius);min-height:280px;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}
.col-visual svg{width:120px;height:120px;opacity:.6}
.col-visual::before{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(76,175,80,.1);top:-40px;right:-40px}

/* === VALUES GRID === */
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.value-card{display:flex;gap:1rem;padding:1.5rem;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform var(--transition)}
.value-card:hover{transform:translateY(-4px)}
.value-card .v-icon{flex-shrink:0;width:48px;height:48px;background:var(--light-bg);border-radius:50%;display:flex;align-items:center;justify-content:center}
.value-card .v-icon svg{width:24px;height:24px;stroke:var(--primary);fill:none;stroke-width:1.5}
.value-card h3{font-size:1.05rem;color:var(--primary);margin-bottom:.3rem}
.value-card p{font-size:.9rem}

/* === TIMELINE === */
.timeline{position:relative;padding:2rem 0}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:3px;background:var(--accent);transform:translateX(-50%)}
.timeline-item{display:flex;justify-content:flex-end;padding:0 0 2rem;width:50%;position:relative}
.timeline-item:nth-child(even){align-self:flex-end;margin-left:50%;justify-content:flex-start}
.timeline-content{background:var(--white);padding:1.25rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);max-width:400px;position:relative}
.timeline-content h3{color:var(--primary);font-size:1rem;margin-bottom:.3rem}
.timeline-content p{font-size:.9rem}
.timeline-item::after{content:'';position:absolute;width:14px;height:14px;background:var(--accent);border:3px solid var(--white);border-radius:50%;top:1.5rem;right:-7px;box-shadow:var(--shadow)}
.timeline-item:nth-child(even)::after{left:-7px;right:auto}
@media(max-width:768px){
  .timeline::before{left:20px}
  .timeline-item,.timeline-item:nth-child(even){width:100%;margin-left:0;padding-left:50px;justify-content:flex-start}
  .timeline-item::after,.timeline-item:nth-child(even)::after{left:13px;right:auto}
}

/* === PROGRAM SECTIONS === */
.program-section{padding:3rem 0;border-bottom:1px solid rgba(27,94,32,.08)}
.program-section:last-child{border-bottom:none}
.program-section .key-points{margin-top:1rem}
.program-section .key-points li{padding:.4rem 0 .4rem 1.5rem;position:relative;font-size:.95rem}
.program-section .key-points li::before{content:'';position:absolute;left:0;top:.7rem;width:8px;height:8px;background:var(--accent);border-radius:50%}

/* === FORMS === */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.95rem;color:var(--dark)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:var(--radius);font-size:1rem;font-family:inherit;transition:border-color var(--transition);background:var(--white)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group .error-msg{color:#d32f2f;font-size:.85rem;margin-top:.25rem;display:none}
.form-group.error input,.form-group.error textarea{border-color:#d32f2f}
.form-group.error .error-msg{display:block}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:576px){.form-grid{grid-template-columns:1fr}}

/* === CONTACT INFO CARDS === */
.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:3rem}
.contact-card{text-align:center;padding:2rem 1.5rem;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow)}
.contact-card .c-icon{width:56px;height:56px;margin:0 auto .75rem;background:var(--light-bg);border-radius:50%;display:flex;align-items:center;justify-content:center}
.contact-card .c-icon svg{width:24px;height:24px;stroke:var(--primary);fill:none;stroke-width:1.5}
.contact-card h3{font-size:1rem;color:var(--primary);margin-bottom:.3rem}
.contact-card p,.contact-card a{font-size:.95rem;color:var(--text)}
.contact-card a:hover{color:var(--accent)}

/* Map */
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-top:2rem}
.map-wrap iframe{width:100%;height:380px;border:none}

/* === NEWSLETTER STRIP === */
.newsletter-strip{background:var(--primary);padding:2.5rem 1rem;text-align:center;color:var(--white)}
.newsletter-strip h2{color:var(--white);margin-bottom:.5rem;font-size:1.5rem}
.newsletter-strip p{margin-bottom:1.25rem;opacity:.9}
.newsletter-form{display:flex;gap:.5rem;max-width:480px;margin:0 auto}
.newsletter-form input{flex:1;padding:.75rem 1rem;border:none;border-radius:var(--radius);font-size:1rem}
.newsletter-form button{white-space:nowrap}
@media(max-width:480px){.newsletter-form{flex-direction:column}}

/* === SOCIAL GRID === */
.social-grid{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.social-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);font-weight:500;color:var(--dark);transition:all var(--transition)}
.social-link:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(27,94,32,.15);color:var(--primary)}
.social-link svg{width:22px;height:22px}

/* === FOOTER === */
.site-footer{background:linear-gradient(160deg,#0a2010,var(--dark) 60%);color:rgba(255,255,255,.75);padding:4rem 0 1.75rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{color:var(--white);font-size:.95rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.08em;opacity:.6}
.footer-grid p,.footer-grid a{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.8}
.footer-grid a:hover{color:var(--accent-light)}
.footer-links{display:flex;flex-direction:column;gap:.5rem}
.footer-bottom{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);font-size:.82rem;color:rgba(255,255,255,.35)}

/* === ANIMATIONS === */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:.1s}
.fade-up:nth-child(3){transition-delay:.2s}
.fade-up:nth-child(4){transition-delay:.3s}

.mission-strip p,.cta-section h2,.cta-section p,.newsletter-strip h2,.newsletter-strip p{color:#fff}
@media print{.site-header,.site-footer,.nav-toggle,.btn{display:none}body{color:#000}}
