/* === Franvelotix — Layout D: cultural foundation, emerald #047857 + warm cream bg, Playfair Display + Source Sans Pro === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans Pro','Helvetica Neue',sans-serif;font-size:16px;line-height:1.75;color:#444;background:#faf9f6}
a{color:#047857;text-decoration:none;transition:color .2s}a:hover{color:#065f46}
img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.25;color:#1a1a1a}
h1{font-size:44px;margin-bottom:18px}h2{font-size:30px;margin-bottom:16px}h3{font-size:20px;margin-bottom:8px}
p{margin-bottom:16px;color:#555}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.container-sm{max-width:720px;margin:0 auto;padding:0 24px}

/* HEADER — cream with dark text */
.header{background:#faf9f6;padding:16px 0;position:sticky;top:0;z-index:100;border-bottom:1px solid #e8e5de}
.header .container{display:flex;justify-content:space-between;align-items:center}
.logo{font-family:'Playfair Display',Georgia,serif;font-size:20px;font-weight:700;color:#1a1a1a}
.logo span{color:#047857}
.nav-menu{display:flex;gap:24px;align-items:center}
.nav-menu a{font-size:14px;font-weight:600;color:#555;transition:color .2s}
.nav-menu a:hover{color:#047857}
.mobile-toggle{display:none;background:none;border:none;color:#1a1a1a;font-size:24px;cursor:pointer}

/* HERO D — full-bleed with diagonal gradient overlay */
.hero-d{position:relative;min-height:560px;display:flex;align-items:center;overflow:hidden;background:#0f2e1f}
.hero-d .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35}
.hero-d .hero-content{position:relative;z-index:2;max-width:620px;padding:80px 24px}
.hero-d h1{color:#fff;font-size:46px;letter-spacing:-.5px}
.hero-d p{color:rgba(255,255,255,.8);font-size:17px;line-height:1.8;margin-bottom:28px}
.hero-d .hero-badge{display:inline-block;padding:6px 16px;background:rgba(4,120,87,.3);border:1px solid rgba(4,120,87,.5);border-radius:20px;color:#6ee7b7;font-size:13px;font-weight:600;margin-bottom:20px;letter-spacing:1px;text-transform:uppercase}
.btn-emerald{display:inline-block;padding:14px 32px;background:#047857;color:#fff;border-radius:6px;font-weight:600;font-size:15px;transition:background .2s;border:none;cursor:pointer}
.btn-emerald:hover{background:#065f46;color:#fff}

/* MISSION STRIP */
.mission-strip{background:#047857;padding:48px 0;color:#fff;text-align:center}
.mission-strip h2{color:#fff;font-size:22px;font-weight:400;max-width:800px;margin:0 auto;line-height:1.7}
.mission-strip h2 strong{font-weight:700}

/* PROGRAMS — 3 col cards with top accent */
.programs-section{padding:80px 0;background:#fff}
.programs-section h2{text-align:center;margin-bottom:48px}
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.program-card{background:#faf9f6;border-radius:10px;overflow:hidden;border:1px solid #e8e5de;transition:box-shadow .2s}
.program-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.08)}
.program-card .accent{height:4px;background:#047857}
.program-card .card-inner{padding:28px}
.program-card .tag{font-size:12px;font-weight:700;text-transform:uppercase;color:#047857;letter-spacing:1px;margin-bottom:8px;display:block}
.program-card h3{font-size:18px;margin-bottom:10px}
.program-card p{font-size:14px;color:#666;margin-bottom:0}

/* STATS — cream bg */
.stats-cream{padding:60px 0;background:#f5f0e8}
.stats-cream .stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stats-cream .stat h3{font-size:42px;color:#047857;margin-bottom:4px}
.stats-cream .stat p{font-size:14px;color:#888;text-transform:uppercase;letter-spacing:1px}

/* ABOUT — two col with image */
.about-split{padding:80px 0;background:#fff}
.about-split .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-split img{border-radius:10px;aspect-ratio:4/3;object-fit:cover;width:100%}
.about-split h2{margin-bottom:16px}
.about-split p{font-size:15px;line-height:1.8}

/* GALLERY — masonry-style */
.gallery-section{padding:80px 0;background:#faf9f6}
.gallery-section h2{text-align:center;margin-bottom:40px}
.gallery-masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-masonry img{border-radius:8px;aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .3s}
.gallery-masonry img:hover{transform:scale(1.02)}

/* TIMELINE */
.timeline-section{padding:80px 0;background:#fff}
.timeline-section h2{text-align:center;margin-bottom:48px}
.timeline-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.timeline-step{text-align:center;padding:24px 16px}
.timeline-step .num{width:48px;height:48px;border-radius:50%;background:#047857;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;margin-bottom:16px}
.timeline-step h3{font-size:16px;margin-bottom:6px}
.timeline-step p{font-size:14px;color:#777}

/* TESTIMONIALS */
.testi-section{padding:80px 0;background:#0f2e1f;color:#fff}
.testi-section h2{text-align:center;color:#fff;margin-bottom:40px}
.testi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);padding:28px;border-radius:10px}
.testi-card p{color:rgba(255,255,255,.8);font-style:italic;font-size:15px;line-height:1.8}
.testi-card .author{display:block;margin-top:16px;color:#6ee7b7;font-size:13px;font-weight:600;font-style:normal}

/* FAQ */
.faq-section{padding:80px 0;background:#fff}
.faq-section h2{text-align:center;margin-bottom:40px}
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid #e8e5de}
.faq-trigger{display:flex;justify-content:space-between;align-items:center;width:100%;padding:18px 0;background:none;border:none;font-size:15px;font-weight:600;color:#1a1a1a;cursor:pointer;text-align:left;font-family:inherit}
.faq-trigger:hover{color:#047857}
.faq-trigger .icon{font-size:20px;color:#047857;transition:transform .2s}
.faq-content{max-height:0;overflow:hidden;transition:max-height .3s,padding .3s;font-size:14px;line-height:1.8;color:#666}
.faq-content.open{max-height:300px;padding-bottom:18px}

/* CTA */
.cta-section{padding:64px 0;background:linear-gradient(135deg,#047857,#065f46);text-align:center}
.cta-section h2{color:#fff;margin-bottom:12px}
.cta-section p{color:rgba(255,255,255,.8);margin-bottom:24px}
.btn-white{display:inline-block;padding:14px 32px;background:#fff;color:#047857;border-radius:6px;font-weight:600;font-size:15px;transition:all .2s}
.btn-white:hover{background:#f0fdf4;color:#065f46}

/* FORM */
.form-section{padding:80px 0;background:#faf9f6}
.form-section h2{text-align:center;margin-bottom:8px}
.form-section>div>p{text-align:center;color:#888;margin-bottom:32px}
.form-section form{max-width:460px;margin:0 auto}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:6px}
.form-group input{width:100%;padding:12px 14px;border:1px solid #d4d0c8;border-radius:6px;font-size:15px;background:#fff;transition:border-color .2s;font-family:inherit}
.form-group input:focus{outline:none;border-color:#047857}
.form-submit{width:100%;padding:14px;background:#047857;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;font-family:inherit}
.form-submit:hover{background:#065f46}
.form-note{text-align:center;font-size:12px;color:#999;margin-top:12px}

/* CONTACT STRIP */
.contact-strip{padding:48px 0;background:#1a1a1a;color:#fff}
.contact-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.c-item h4{font-family:'Source Sans Pro',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#6ee7b7;margin-bottom:8px}
.c-item p{font-size:14px;color:rgba(255,255,255,.7);margin-bottom:0}
.c-item a{color:#6ee7b7}

/* FOOTER */
.footer{background:#111;padding:24px 0;text-align:center;color:#888;font-size:13px}
.footer a{color:#6ee7b7}

.btn-outline{display:inline-block;padding:10px 24px;border:2px solid #047857;color:#047857;border-radius:6px;font-weight:600;font-size:14px;transition:all .2s}
.btn-outline:hover{background:#047857;color:#fff}

/* RESPONSIVE */
@media(max-width:768px){
.hero-d{min-height:420px}
.hero-d h1{font-size:30px}
.hero-d .hero-content{padding:60px 20px}
.programs-grid,.testi-row,.contact-row{grid-template-columns:1fr}
.stats-cream .stats-row{grid-template-columns:repeat(2,1fr)}
.about-split .about-grid{grid-template-columns:1fr}
.gallery-masonry{grid-template-columns:1fr}
.timeline-grid{grid-template-columns:repeat(2,1fr)}
.nav-menu{display:none}
.mobile-toggle{display:block}
h1{font-size:28px}h2{font-size:24px}
}
