/* ==========================================================================
   RFW Website Stylesheet - style.css
   ========================================================================== */

/* ==========================================================================
   1. Base Styles & Variables
   ========================================================================== */
   :root {
    /* RFW Color Palette */
    --primary-teal: #1D7874;
    --light-teal: #679289;
    --dark-teal: #0C3A38;
    --accent-gold: #D9B96D;
    --soft-coral: #F2746B;
    --accent-pink: #FF4F93; /* Example for consistency if used */

    /* Neutrals */
    --white: #FFFFFF;
    --off-white: #F8F9FA;
    --light-gray: #F0F2F5;
    --mid-gray: #DEE2E6;
    --dark-gray: #495057;
    --black: #212529;

    /* Fonts */
    --font-primary: 'Montserrat', sans-serif;
    --font-secondary: 'Montserrat', sans-serif;

    /* Layout */
    --container-width: 1200px;
    --padding-standard: 80px 20px;
    --padding-condensed: 50px 20px;
    --border-radius: 8px;
    --box-shadow-light: 0 4px 15px rgba(0, 0, 0, 0.06);
    --box-shadow-medium: 0 8px 25px rgba(0, 0, 0, 0.1);
    --header-height-desktop: 76px; /* Approx for V2 Header */
    --header-height-mobile: 61px; /* Approx for V2 Header */
    --transition-speed: 0.3s;
}

/* Basic Reset */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html {
    scroll-behavior: smooth;
    scroll-padding-top: var(--header-height-desktop);
}
body {
    font-family: var(--font-primary);
    font-size: 16px;
    line-height: 1.7;
    color: var(--dark-gray);
    background-color: var(--white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-secondary);
    font-weight: 600;
    line-height: 1.3;
    margin-top: 0;
    margin-bottom: 1rem;
    color: var(--dark-teal);
}
h1 { font-size: clamp(2.5rem, 5vw, 3.5rem); margin-bottom: 1.5rem; }
h2 { font-size: clamp(1.8rem, 4vw, 2.4rem); margin-bottom: 1.2rem; }
h3 { font-size: 1.6rem; }
h4 { font-size: 1.2rem; }
p { margin-top: 0; margin-bottom: 1rem; }
p:last-of-type { margin-bottom: 0; }
a { text-decoration: none; color: var(--primary-teal); transition: color var(--transition-speed) ease; }
a:hover { color: var(--dark-teal); }
img { max-width: 100%; height: auto; display: block; vertical-align: middle; }
ul { list-style: none; padding: 0; margin: 0; }
/* Blockquotes */
blockquote { font-style: italic; font-size: 1.1rem; line-height: 1.7; color: var(--dark-gray); border-left: 4px solid var(--primary-teal); padding: 15px 25px; margin: 1.5rem 0; background-color: var(--off-white); border-radius: 0 var(--border-radius) var(--border-radius) 0; }
blockquote footer { font-style: normal; margin-top: 10px; font-weight: 500; font-size: 1rem; color: var(--light-teal); display: block; }
blockquote footer::before { content: "— "; }

/* ==========================================================================
   2. Layout & Helper Classes
   ========================================================================== */
.container { max-width: var(--container-width); margin: 0 auto; padding: 0 20px; width: 100%; }
.section-padding { padding: var(--padding-standard); }
.section-padding--large { padding: calc(var(--padding-standard) + 20px); }
.section-padding--condensed { padding: var(--padding-condensed); }
.text-center { text-align: center; }
.text-light { color: var(--white) !important; }
.text-light h1, .text-light h2, .text-light h3, .text-light h4,
.text-light p, .text-light span, .text-light cite, .text-light li,
.text-light .section-title, .text-light .section-intro { color: var(--white) !important; }
.text-light a:not(.btn) { color: var(--mid-gray) !important; }
.text-light a:not(.btn):hover { color: var(--white) !important; }
.text-light blockquote { background-color: rgba(255,255,255,0.1); border-color: var(--white); color: var(--white); }
.text-light blockquote footer { color: rgba(255, 255, 255, 0.8); }
.section-title { margin-bottom: 40px; text-align: center; position: relative; }
.section-title--smaller { font-size: 1.8rem; margin-bottom: 30px; }
.section-title.has-divider::after { content: ''; display: block; width: 60px; height: 3px; background: var(--accent-gold); margin: 15px auto 0; }
.section-title.text-left { text-align: left; }
.section-title.text-left.has-divider::after { margin-left: 0; margin-right: auto; }
.section-intro { max-width: 750px; margin: 0 auto 50px auto; text-align: center; color: var(--dark-gray); font-size: 1.1rem; line-height: 1.8; }
.text-light .section-intro { color: rgba(255, 255, 255, 0.9); }
.bg-light-gray { background-color: var(--light-gray); }
.bg-off-white { background-color: var(--off-white); }
.bg-white { background-color: var(--white); }
.bg-gradient-teal { background: linear-gradient(135deg, #f0f7f7 0%, #e6efef 100%); }
.bg-light-teal { background-color: var(--light-teal); }
.bg-dark-teal { background-color: var(--dark-teal); }
.bg-gradient-footer { background: linear-gradient(135deg, var(--dark-teal), var(--primary-teal)); }
.grid { display: grid; gap: 30px; }
.grid-2-col { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); align-items: start; }
.grid-3-col { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); align-items: stretch; }
.grid-4-col { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); align-items: stretch; }
.grid-2-col-center { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); align-items: center; gap: 50px; }
.flex-container { display: flex; gap: 30px; flex-wrap: wrap; }
.flex-item { flex: 1; min-width: 300px; }
.flex-align-center { align-items: center; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.has-bg-image { position: relative; background-color: var(--dark-teal); overflow: hidden; }
.section-bg-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-size: cover; background-position: center center; background-repeat: no-repeat; z-index: 1; }
.section-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 2; }
.section-content-over-bg { position: relative; z-index: 3; }

/* ==========================================================================
   3. Buttons
   ========================================================================== */
.btn { display: inline-block; padding: 12px 30px; border: none; border-radius: 30px; font-family: var(--font-secondary); font-weight: 500; font-size: 1rem; text-align: center; cursor: pointer; transition: all var(--transition-speed) ease; text-transform: none; letter-spacing: 0.5px; line-height: 1.4; text-decoration: none; }
.btn-primary { background-color: var(--primary-teal); color: var(--white) !important; }
.btn-primary:hover { background-color: var(--dark-teal); transform: translateY(-2px); box-shadow: 0 5px 15px rgba(29,120,116,0.3); text-decoration: none; }
.btn-secondary-light-bg { background-color: transparent; color: var(--primary-teal) !important; border: 2px solid var(--primary-teal); }
.btn-secondary-light-bg:hover { background-color: var(--primary-teal); color: var(--white) !important; transform: translateY(-2px); text-decoration: none; }
.btn-secondary { background-color: transparent; color: var(--white) !important; border: 2px solid var(--white); }
.btn-secondary:hover { background-color: rgba(255, 255, 255, 0.1); transform: translateY(-2px); text-decoration: none; color: var(--white) !important; }
/* .btn-donate is now .btn-nav-donate for header */
.cta-banner-btn { background-color: var(--soft-coral); color: white !important; font-size: 1.1rem; padding: 15px 40px; }
.cta-banner-btn:hover { background-color: #e65a50; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(242,116,107,0.3); }
.hero-donate-alt { border-color: var(--white); }
.hero-donate-alt:hover { background-color: var(--white); color: var(--primary-teal) !important; border-color: var(--white); }
.footer-btn { padding: 10px 22px; font-size: 0.9rem; /* Modifies .btn-secondary for footer */ background-color: transparent; color: var(--white) !important; border: 2px solid var(--white); }
.footer-btn:hover { background-color: rgba(255, 255, 255, 0.1); transform: translateY(-2px); }

.btn-hot-pink { background-color: var(--accent-pink); color: var(--white) !important; padding: 18px 40px; font-size: 1.1rem; font-weight: 600; border: none; }
.btn-hot-pink:hover { background-color: #e6397b; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(255, 79, 147, 0.4); text-decoration: none; }


/* ==========================================================================
   4. Header & Navigation (V2 - Consolidated & Corrected)
   ========================================================================== */
.site-header { padding: 10px 20px; background-color: var(--white); border-bottom: 1px solid var(--light-gray); position: sticky; top: 0; z-index: 1000; box-shadow: 0 2px 8px rgba(0,0,0,0.08); }
.nav-container { display: flex; justify-content: space-between; align-items: center; max-width: var(--container-width); margin: 0 auto; }
.site-logo { display: flex; align-items: center; gap: 12px; text-decoration: none; color: inherit; flex-shrink: 0; }
.site-logo img { height: 55px; width: auto; }
.site-logo .logo-text { font-family: var(--font-secondary); font-size: 1.15rem; font-weight: 600; color: var(--dark-teal); white-space: nowrap; }
.nav-actions { display: flex; align-items: center; gap: 30px; }
.main-navigation { position: relative; }
.nav-list { display: flex; list-style: none; margin: 0; padding: 0; gap: 35px; }
.nav-item { position: relative; }
.nav-list > .nav-item > a { display: block; padding: 10px 0px; font-family: var(--font-secondary); font-size: 1rem; font-weight: 500; color: var(--dark-gray); text-decoration: none; position: relative; white-space: nowrap; transition: color var(--transition-speed) ease; }
.nav-item.has-dropdown > a { padding-right: 18px; }
.nav-item.has-dropdown > a::after { content: '▾'; font-size: 0.7em; position: absolute; right: 0; top: 50%; transform: translateY(-50%); transition: transform 0.2s ease-out; color: var(--light-teal); pointer-events: none; }
.nav-item.has-dropdown:hover > a::after { transform: translateY(-50%) rotate(180deg); }
.nav-list > .nav-item > a::before { content: ''; position: absolute; width: 0; height: 2px; display: block; background: var(--primary-teal); transition: width var(--transition-speed) ease; bottom: 5px; left: 0; }
.nav-list > .nav-item > a:hover::before, .nav-list > .nav-item > a.active::before { width: 100%; }
.nav-list > .nav-item.has-dropdown > a:hover::before, .nav-list > .nav-item.has-dropdown > a.active::before, .nav-list > .nav-item.has-dropdown > a.active-parent::before { width: calc(100% - 18px); }
.nav-list > .nav-item > a:hover, .nav-list > .nav-item > a.active, .nav-list > .nav-item > a.active-parent { color: var(--primary-teal); }
.nav-list > .nav-item > a.active { font-weight: 600; }
.dropdown-menu { display: none; position: absolute; top: calc(100% - 5px); left: -15px; background-color: var(--white); list-style: none; padding: 10px 0; margin: 0; min-width: 210px; z-index: 1010; border-radius: 0 0 var(--border-radius) var(--border-radius); box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1); border-top: 3px solid var(--primary-teal); opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity 0.2s ease-out, transform 0.2s ease-out, visibility 0s linear 0.2s; pointer-events: none; }
.nav-item.has-dropdown:hover > .dropdown-menu, .nav-item.has-dropdown:focus-within > .dropdown-menu { display: block; opacity: 1; visibility: visible; transform: translateY(0); transition-delay: 0s; pointer-events: auto; }
.dropdown-menu li { margin: 0 !important; padding: 0 !important; list-style-type: none !important; }
.dropdown-menu li::before, .dropdown-menu li::after { content: none !important; }
.dropdown-menu li a { display: block; padding: 10px 20px; color: var(--dark-gray); font-family: var(--font-secondary); font-size: 0.95rem; font-weight: 400; white-space: nowrap; text-decoration: none; }
.dropdown-menu li a:hover { background-color: var(--light-gray); color: var(--primary-teal); }
.dropdown-menu li a::before, .dropdown-menu li a::after { display: none !important; }
.btn-nav-donate { background-color: var(--soft-coral); color: var(--white) !important; padding: 8px 20px; font-size: 0.95rem; font-weight: 500; border-radius: 20px; transition: background-color var(--transition-speed) ease, transform var(--transition-speed) ease; white-space: nowrap; text-decoration: none; border: none; flex-shrink: 0; }
.btn-nav-donate:hover { background-color: #e65a50; transform: translateY(-1px); text-decoration: none; color: var(--white) !important;}


/* ==========================================================================
   5. Footer Styles
   ========================================================================== */
footer { background: var(--bg-gradient-footer); color: var(--white); padding-top: 70px; position: relative; }
.footer-decor-shape { position: absolute; top: 0; right: 0; width: 30%; height: 100%; background-color: rgba(255,255,255,0.03); clip-path: polygon(100% 0, 0% 100%, 100% 100%); z-index: 1; pointer-events: none;}
footer .container { position: relative; z-index: 2; }
.footer-content { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 40px; margin-bottom: 50px; }
.footer-info h3, .footer-links h3, .footer-social h3 { color: var(--white); margin-bottom: 25px; font-size: 1.4rem; font-weight: 500; }
.footer-info p { margin-bottom: 12px; font-size: 0.95rem; line-height: 1.6; color: var(--mid-gray); }
.footer-info p:last-of-type { margin-bottom: 0; }
.footer-info a { color: var(--mid-gray); text-decoration: none; }
.footer-info a:hover { text-decoration: underline; color: var(--white); }
.footer-links ul { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 14px; }
.footer-links a { color: var(--mid-gray); text-decoration: none; transition: color var(--transition-speed); }
.footer-links a:hover { color: var(--white); }
.social-link { display: flex; align-items: center; text-decoration: none; color: var(--mid-gray); margin-bottom: 14px; transition: transform 0.3s, color 0.3s; }
.social-link img { width: 22px; height: 22px; margin-right: 12px; filter: brightness(0) invert(1); }
.social-link:hover { transform: translateX(5px); color: var(--white); }
.footer-subscribe-section { text-align: center; padding: 40px 0; margin-top: 30px; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.footer-subscribe-section h3 { margin-bottom: 1rem; color: var(--white); }
.footer-subscribe-section p { color: var(--mid-gray); font-size: 0.95rem; margin-bottom: 1.8rem; max-width: 500px; margin-left: auto; margin-right: auto; }
.subscribe-form { max-width: 550px; margin: 0 auto; }
.subscribe-form-inputs { display: flex; gap: 15px; margin-bottom: 15px; flex-wrap: wrap; }
.subscribe-form-inputs div { flex: 1; min-width: 200px; }
.subscribe-form input[type="text"], .subscribe-form input[type="email"] { width: 100%; padding: 14px; border: 1px solid rgba(255,255,255,0.2); border-radius: 6px; background-color: rgba(255,255,255,0.05); color: var(--white); font-size: 1rem; transition: border-color 0.3s, background-color 0.3s; font-family: var(--font-primary); }
.subscribe-form input::placeholder { color: rgba(255,255,255,0.6); }
.subscribe-form input:focus { background-color: rgba(255,255,255,0.1); border-color: var(--mid-gray); outline: none; }
.subscribe-form button[type="submit"] { background-color: var(--soft-coral); color: white !important; width: 100%; border: none; padding: 14px 20px; font-size: 1rem; font-weight: 500; border-radius: 6px; cursor: pointer; transition: background-color 0.3s; font-family: var(--font-secondary); }
.subscribe-form button[type="submit"]:hover { background-color: #e65a50; }
.copyright { text-align: center; padding: 30px 0; margin-top: 40px; border-top: 1px solid rgba(255, 255, 255, 0.1); font-size: 0.9rem; color: rgba(255,255,255,0.7); }
.copyright a { color: var(--mid-gray); } .copyright a:hover { color: var(--white); text-decoration: underline;}


/* ==========================================================================
   6. Homepage Specific Styles
   ========================================================================== */
#hero { position: relative; height: 85vh; min-height: 600px; overflow: hidden; }
.hero-background { position: absolute; top:0; left:0; width: 100%; height: 100%; background: url('img/rfw-photo-interview.jpeg') no-repeat center center; background-size: cover; }
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(12, 58, 56, 0) 0%, rgba(12, 58, 56, 0.6) 60%, rgba(12, 58, 56, 0.85) 100%); }
.hero-content { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; max-width: 850px; margin: 0 auto; padding: 0 20px; text-align: center; }
.hero-content h1 { font-size: clamp(2.8rem, 6vw, 4rem); color: var(--white); }
.hero-content .subtitle { font-size: clamp(1.2rem, 3vw, 1.5rem); margin-bottom: 3rem; font-weight: 300; color: var(--white); }
.hero-buttons .btn { margin: 10px; }
.welcome-card { padding: 50px 30px; text-align: center; margin-bottom: 50px; background-color: var(--white); border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
.welcome-card h2 { color: var(--dark-teal); margin-bottom: 15px; font-size: 2rem; }
.welcome-card p { font-size: 1.1rem; max-width: 750px; margin: 0 auto 25px; }
.pillar { text-align: center; }
.pillar .icon { display: flex; justify-content: center; align-items: center; height: 70px; margin-bottom: 20px; }
.pillar .pillar-icon-img { width: 45px; height: 45px; object-fit: contain; }
.pillar-content { padding: 0 15px 20px; flex-grow: 1; display: flex; flex-direction: column; }
.pillar h3 { color: var(--dark-teal); margin-bottom: 15px; font-size: 1.4rem; }
.pillar p { flex-grow: 1; margin-bottom: 1.5rem;}
.pillar .text-link { margin-top: auto; }
#our-distinct-approach { position: relative; overflow: hidden; }
#our-distinct-approach.has-bg-image { background-color: var(--dark-teal); }
.approach-highlights.grid-3-col { gap: 30px; align-items: stretch; }
.approach-point.card { text-align: center; padding: 35px 25px; display: flex; flex-direction: column; align-items: center; }
.approach-point.transparent-card { background-color: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.3); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); box-shadow: none; }
.approach-point.transparent-card:hover { background-color: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.5); transform: translateY(-3px); }
.approach-point .icon { font-size: 2.5rem; color: var(--primary-teal); margin-bottom: 20px; line-height: 1; }
.approach-point.transparent-card .icon { color: var(--accent-gold); }
.approach-point .icon i { font-size: inherit; }
.approach-point h3 { font-size: 1.4rem; color: var(--dark-teal); margin-bottom: 15px; }
.approach-point.transparent-card h3 { color: var(--white); }
.approach-point p { font-size: 0.95rem; flex-grow: 1; margin-bottom: 0; color: var(--dark-gray); }
.approach-point.transparent-card p { color: rgba(255, 255, 255, 0.85); margin-bottom: 1rem; }
.collapsible-text { width: 100%; }
p.text-preview { display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; margin-bottom: 15px; }
.text-full { display: none; margin-bottom: 15px; }
.see-more-btn { background: none; border: none; color: var(--accent-gold); font-weight: 600; cursor: pointer; padding: 5px 0; margin-top: auto; text-decoration: none; transition: color var(--transition-speed) ease; }
.see-more-btn:hover { color: var(--white); text-decoration: underline; }
.approach-conclusion { text-align: center; margin-top: 40px; }
.approach-conclusion p { font-size: 1.1rem; max-width: 800px; margin: 0 auto 20px auto; line-height: 1.7; }
.approach-conclusion.text-light p { color: var(--mid-gray); }
#impact-highlights { background: var(--bg-gradient-teal); }
#impact-highlights .section-title { color: var(--dark-teal); }
.impact-stats-container { display: flex; flex-wrap: wrap; justify-content: center; gap: 30px; margin-bottom: 40px; }
.impact-stat { text-align: center; padding: 35px 20px; background: white; border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); min-width: 200px; flex: 1; max-width: 240px; transition: transform var(--transition-speed) ease; }
.impact-stat:hover { transform: translateY(-5px); }
.stat-number { font-family: var(--font-secondary); font-size: 3.2rem; font-weight: 700; color: var(--primary-teal); display: block; margin-bottom: 8px; line-height: 1; }
.stat-label { font-size: 1rem; color: var(--dark-gray); display: block; }
#impact-highlights .btn-primary { margin-top: 20px; }
#testimonials h2.section-title { color: var(--dark-teal); }
.testimonial-card { background: white; border-radius: var(--border-radius); padding: 40px; box-shadow: var(--box-shadow-light); position: relative; border-left: 5px solid var(--accent-gold); }
.testimonial-card p:first-of-type { font-style: italic; margin-bottom: 25px; font-size: 1.1rem; line-height: 1.8; }
.testimonial-author-info { display: flex; align-items: center; margin-top: 15px; }
.testimonial-author-img { width: 55px; height: 55px; border-radius: 50%; margin-right: 15px; overflow: hidden; flex-shrink: 0; border: 2px solid var(--accent-gold); }
.testimonial-author-img img { width: 100%; height: 100%; object-fit: cover; }
.author-name { font-weight: 600; margin: 0; color: var(--dark-teal); }
.author-title { font-size: 0.9rem; color: var(--light-teal); margin: 0; }
/* Swiper News Slider */
#stories-snippet { background-color: var(--off-white); position: relative; }
#stories-snippet .container { max-width: 100%; padding-left: 0; padding-right: 0; }
.news-slider-container { width: 100%; max-width: var(--container-width); margin: 0 auto; padding-top: 20px; padding-bottom: 60px; position: relative; overflow: visible; }
.news-slider-container .swiper-wrapper { align-items: stretch; padding-bottom: 10px; }
.news-slider-container .swiper-slide { width: 65%; height: auto; transition: transform 0.4s ease-out, opacity 0.4s ease-out; transform: scale(0.8); opacity: 0.6; display: flex; align-items: stretch; }
.news-slider-container .swiper-slide-active { transform: scale(1); opacity: 1; z-index: 10; }
.news-slider-container .swiper-slide .news-card { width: 100%; margin: 0; display: flex; flex-direction: column; height: 100%; }
.news-slider-container .news-card .news-img { height: 220px; overflow: hidden; position: relative; }
.news-slider-container .news-card .news-img::after { content:''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(transparent, rgba(0,0,0,0.2)); }
.news-slider-container .news-card .news-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.news-slider-container .news-card:hover .news-img img { transform: scale(1.05); }
.news-slider-container .news-card .news-content { padding: 25px; flex-grow: 1; display: flex; flex-direction: column; min-height: 180px; }
.news-slider-container .news-date { color: var(--light-teal); font-size: 0.85rem; margin-bottom: 10px; }
.news-slider-container .news-content h3 { margin-bottom: 15px; color: var(--dark-teal); font-size: 1.25rem; }
.news-slider-container .news-content p { margin-bottom: 20px; flex-grow: 1; font-size: 0.95rem; }
.news-slider-container .news-content .text-link { margin-top: auto; align-self: flex-start; }
.news-slider-container .swiper-button-next,
.news-slider-container .swiper-button-prev { color: var(--primary-teal) !important; background-color: rgba(255, 255, 255, 0.9); border-radius: 50%; width: 44px !important; height: 44px !important; transition: background-color var(--transition-speed) ease, box-shadow var(--transition-speed) ease; box-shadow: 0 2px 8px rgba(0,0,0,0.15); top: 50%; transform: translateY(-50%); margin-top: -44px; }
.news-slider-container .swiper-button-next:hover,
.news-slider-container .swiper-button-prev:hover { background-color: var(--white); }
.news-slider-container .swiper-button-next:after,
.news-slider-container .swiper-button-prev:after { font-size: 18px !important; font-weight: bold; }
.news-slider-container .swiper-button-prev { left: 15px !important; }
.news-slider-container .swiper-button-next { right: 15px !important; }
.swiper-pagination { position: relative !important; bottom: auto !important; margin-top: 30px; }
.swiper-pagination-bullet { background: var(--mid-gray) !important; opacity: 0.7 !important; width: 10px !important; height: 10px !important; transition: background-color var(--transition-speed) ease, opacity var(--transition-speed) ease; }
.swiper-pagination-bullet-active { background: var(--primary-teal) !important; opacity: 1 !important; }
.blog-link-container { text-align: center; margin-top: 40px; }
#cta-banner { background: var(--bg-gradient-footer); position: relative; overflow: hidden; color: var(--white); text-align: center; }
.cta-decor-1, .cta-decor-2 { position: absolute; border-radius: 50%; background: rgba(255,255,255,0.05); z-index: 1; pointer-events: none; }
.cta-decor-1 { width: 300px; height: 300px; top: -150px; right: -50px; }
.cta-decor-2 { width: 200px; height: 200px; bottom: -100px; left: 10%; }
#cta-banner .container { position: relative; z-index: 2; }
#cta-banner h2 { font-size: clamp(1.8rem, 4vw, 2.5rem); margin-bottom: 20px; color: var(--white); }
#cta-banner p { font-size: 1.2rem; max-width: 700px; margin: 0 auto 30px auto; opacity: 0.95; }
#video-feature { background-color: var(--off-white); }
.video-placeholder-wrapper { max-width: 850px; margin: 0 auto; box-shadow: var(--box-shadow-medium); border-radius: var(--border-radius); overflow: hidden; aspect-ratio: 16/9; background-color: var(--dark-teal); display: flex; align-items: center; justify-content: center; position: relative; cursor: pointer; }
.video-placeholder-wrapper img.video-thumbnail { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; opacity: 0.6; transition: opacity var(--transition-speed) ease; }
.video-placeholder-wrapper:hover img.video-thumbnail { opacity: 0.4; }
.video-placeholder-content { text-align: center; padding: 20px; position: relative; z-index: 2; }
.video-play-icon-outer { width: 80px; height: 80px; border-radius: 50%; background-color: rgba(242,116,107,0.9); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; transition: background-color var(--transition-speed) ease, transform var(--transition-speed) ease; }
.video-placeholder-wrapper:hover .video-play-icon-outer { background-color: var(--soft-coral); transform: scale(1.1); }
.video-play-icon-inner { width: 0; height: 0; border-top: 15px solid transparent; border-bottom: 15px solid transparent; border-left: 25px solid var(--white); margin-left: 5px; }
.video-placeholder-content p { color: var(--white); margin-bottom: 5px; text-shadow: 1px 1px 3px rgba(0,0,0,0.5); }
.video-placeholder-content p:last-of-type { font-size: 0.9rem; margin-bottom: 0; }
.video-iframe-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; background: #000; border-radius: var(--border-radius); }
.video-iframe-container iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }
#partners { background-color: var(--white); }
#partners h2.section-title--smaller { color: var(--dark-teal); margin-bottom: 50px; }
.logo-container { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 70px; max-width: 900px; margin: 0 auto; min-height: 100px; }
.partner-logo { max-height: 75px; width: auto; max-width: 200px; transition: all var(--transition-speed) ease; filter: none; opacity: 1; object-fit: contain; }
.partner-logo:hover { opacity: 0.85; transform: scale(1.05); }
#social-links-section { background-color: var(--off-white); }
#social-links-section .section-intro { margin-bottom: 30px; }
.social-links-feature { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.social-feature-link { display: flex; align-items: center; text-decoration: none; color: var(--dark-gray); background: white; padding: 10px 20px; border-radius: 30px; box-shadow: var(--box-shadow-light); transition: transform var(--transition-speed) ease, box-shadow var(--transition-speed) ease, color var(--transition-speed) ease; font-size: 1rem; }
.social-feature-link:hover { transform: translateY(-3px); box-shadow: var(--box-shadow-medium); color: var(--primary-teal); }
.social-feature-link img { width: 20px; height: 20px; margin-right: 10px; }


/* ==========================================================================
   7. About Page Specific Styles
   ========================================================================== */
.about-hero { background: linear-gradient(rgba(12, 58, 56, 0.85), rgba(12, 58, 56, 0.85)), url('img/uganda-community-wide.jpg') no-repeat center center; background-size: cover; color: var(--white); padding: 100px 0 80px; text-align: center; position: relative; }
.about-hero .container { position: relative; z-index: 2; }
.about-hero h1 { font-size: 3rem; margin-bottom: 20px; font-weight: 700; color: var(--white); }
.about-hero-content { max-width: 800px; margin: 0 auto; position: relative; padding: 0 20px; }
.about-hero p { font-size: 1.15rem; line-height: 1.7; margin-bottom: 30px; color: rgba(255, 255, 255, 0.9); }
.hero-divider { width: 80px; height: 4px; background-color: var(--accent-pink); margin: 0 auto; border: none; }
#guiding-purpose .section-title-container { text-align: center; margin-bottom: 50px; }
#guiding-purpose .section-title { margin-bottom: 15px; } /* Reduced margin for main title */
.title-divider { width: 60px; height: 3px; background-color: var(--primary-teal); margin: 0 auto 30px; border: none; }
.mission-vision-grid { max-width: 1100px; margin: 0 auto; }
.mission-box, .vision-box { padding: 35px; background-color: var(--light-gray); text-align: left; border-radius: var(--border-radius); border-left: 4px solid; box-shadow: var(--box-shadow-light); }
.mission-box { border-color: var(--primary-teal); }
.vision-box { border-color: var(--accent-pink); }
.mission-box h3, .vision-box h3 { color: var(--dark-teal); margin-bottom: 20px; font-size: 1.6rem; }
.mission-box p, .vision-box p { font-size: 1.1rem; line-height: 1.7; color: var(--dark-gray); }
.story-container { display: flex; flex-wrap: wrap; align-items: flex-start; gap: 40px; }
.story-left, .story-right { flex: 1; min-width: 300px; }
.story-left img { margin-bottom: 30px; box-shadow: var(--box-shadow-light); border-radius: var(--border-radius); }
.story-snippet p, .full-story p { font-size: 1.05rem; line-height: 1.7; color: var(--dark-gray); margin-bottom: 15px; }
.read-more-container { margin-top: 15px; }
.read-more-link { color: var(--dark-teal); font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; cursor: pointer; transition: color var(--transition-speed); }
.read-more-link:hover { color: var(--primary-teal); text-decoration: none; }
.read-more-link span { margin-left: 5px; transition: transform var(--transition-speed); }
.read-more-link.open span { transform: rotate(180deg); }
.full-story { display: none; margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--mid-gray); }
.story-right .section-title--smaller { font-size: 2rem; color: var(--dark-teal); margin-bottom: 25px; line-height: 1.3; text-align: left; }
#the-need h2.section-title--smaller { margin-bottom: 20px; }
#the-need ul { list-style: none; padding-left: 0; }
#the-need ul li { padding-left: 28px; position: relative; margin-bottom: 15px; list-style-type: none !important; }
#the-need ul li::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--primary-teal); position: absolute; left: 0; top: 4px; font-size: 1em; }
#the-need .about-snippet-image img { border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
#unique-approach .section-title { margin-bottom: 20px; }
#unique-approach p.section-intro { margin-bottom: 40px; max-width: 800px; margin-left: auto; margin-right: auto;}
#unique-approach .grid-3-col { gap: 30px; }
#unique-approach .pillar.card { padding: 30px 25px; background-color: var(--white); }
#unique-approach p:last-of-type { margin-top: 2.5rem; font-size: 1.05rem; max-width: 850px; margin-left: auto; margin-right: auto; }
#team h2.section-title { margin-bottom: 15px; }
#team p.section-intro { margin-bottom: 50px; max-width: 800px; margin-left: auto; margin-right: auto;}
.team-row-top.grid-2-col { gap: 30px; margin-bottom: 30px; align-items: stretch; }
.team-row-bottom { display: flex; justify-content: center; margin-top: 30px; }
.team-member.card { border-radius: var(--border-radius); padding: 30px; text-align: center; }
.team-row-bottom .team-member.card { max-width: calc(50% - 15px); width: 100%; }
.team-member-img-wrapper { width: 180px; height: 180px; margin: 0 auto 20px auto; overflow: hidden; border-radius: 50%; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.team-member-img-wrapper img { width: 100%; height: 100%; object-fit: cover; }
.team-member h3 { font-size: 1.4rem; margin-bottom: 5px; }
.team-title { font-size: 0.95rem; color: var(--light-teal); font-weight: 500; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 0.5px; }
.read-bio-btn { background-color: var(--primary-teal); color: white !important; border: none; padding: 8px 18px; border-radius: 20px; cursor: pointer; font-size: 0.9rem; font-weight: 500; transition: background-color var(--transition-speed); text-decoration: none; }
.read-bio-btn:hover { background-color: var(--dark-teal); text-decoration: none; }
.bio-content { display: none; margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--mid-gray); text-align: left; }
.team-bio { font-size: 0.95rem; line-height: 1.6; color: var(--dark-gray); }
#location h2.section-title--smaller { margin-bottom: 20px; }
#map-placeholder { border: 1px solid var(--mid-gray); background-color: #e9ecef; text-align: center; padding: 50px 20px; border-radius: var(--border-radius); min-height: 350px; display: flex; flex-direction: column; justify-content: center; align-items: center; font-style: italic; color: var(--dark-gray); }
#map-placeholder p { margin-bottom: 10px; }
#map-placeholder a { font-style: normal; }
#map-placeholder iframe { border-radius: var(--border-radius); border:0; width:100%; height:350px;}
#about-cta h2.section-title { margin-bottom: 15px; }
#about-cta p.section-intro { margin-bottom: 30px; max-width: 750px; margin-left: auto; margin-right: auto; }
.cta-buttons { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }

/* ==========================================================================
   8. Program Page Specific Styles
   ========================================================================== */
body.program-page .page-header { background-color: var(--primary-teal); } /* Example body class specific */
#ast-intro .program-image img { border-radius: var(--border-radius); box-shadow: 0 6px 20px rgba(0,0,0,0.1); }
#unique-approach .pillar.card .icon img { width: 60px; height: 60px; object-fit: contain; } /* Potentially reuse .pillar */
.phase-infographic { margin: 2rem auto; display: block; max-width: 100%; height: auto; }
#women-youth .program-image img { border-radius: var(--border-radius); box-shadow: 0 6px 20px rgba(0,0,0,0.1); }
#program-impact .impact-card { padding: 25px; }
#program-impact .impact-card .icon { height: 60px; margin-bottom: 15px; }
#program-impact .impact-card .icon img { width: 50px; height: 50px; object-fit: contain; }
#program-impact .impact-card h4 { font-size: 1.2rem; margin-bottom: 10px; }

/* --- What We Do Summary Section --- */
#what-we-do-summary {
    /* background-color: var(--off-white); /* Or var(--light-gray) or var(--white) */
}

#what-we-do-summary .section-title {
    /* Existing .section-title styles will apply */
    /* You can add overrides if needed, e.g., slightly smaller margin */
    margin-bottom: 30px;
}

/* Optional: Title Divider (if you use the <hr> in HTML) */
/*
#what-we-do-summary .title-divider {
    width: 60px;
    height: 3px;
    background-color: var(--accent-gold); // Or var(--primary-teal)
    margin: 0 auto 40px auto;
    border: none;
}
*/

.what-we-do-content p {
    font-size: 1.2rem; /* As per inline style, good for emphasis */
    line-height: 1.8;
    max-width: 850px; /* Keeps lines from getting too long */
    margin: 0 auto 25px auto; /* Centers block and adds space below */
    color: var(--dark-gray); /* Ensure good readability */
}
.what-we-do-content p strong {
    color: var(--primary-teal); /* Highlight key terms */
    font-weight: 600; /* Ensure boldness */
}
.what-we-do-content p:last-of-type {
    margin-bottom: 0; /* Remove margin from the last paragraph */
}

/* Button styling will be inherited from .btn and .btn-primary */
#what-we-do-summary .btn-primary {
    margin-top: 30px; /* Space above the button */
}

/* Responsive adjustments */
@media (max-width: 767px) {
    #what-we-do-summary .section-padding {
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .what-we-do-content p {
        font-size: 1.1rem; /* Slightly smaller on mobile */
        margin-bottom: 20px;
    }
    #what-we-do-summary .btn-primary {
        margin-top: 20px;
    }
}

/* ==========================================================================
   9. Impact Page Specific Styles
   ========================================================================== */
.impact-intro-card { background-color: var(--white); padding: 30px; border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); display: flex; flex-wrap: wrap; align-items: center; gap: 40px; }
.impact-intro-content { flex: 1 1 55%; }
.impact-intro-image { flex: 1 1 40%; }
.impact-intro-image img { border-radius: var(--border-radius); }
#impact-highlights.bg-dark-teal { background-color: var(--dark-teal); }
#impact-highlights.bg-dark-teal .section-title { color: var(--white); }
#impact-highlights.bg-dark-teal .section-intro { color: rgba(255, 255, 255, 0.9); }
#impact-highlights.bg-dark-teal .impact-stat { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); }
#impact-highlights.bg-dark-teal .stat-number { color: var(--white); }
#impact-highlights.bg-dark-teal .stat-label { color: rgba(255, 255, 255, 0.9); }
#impact-highlights.bg-dark-teal .text-link { color: var(--white); }
#impact-highlights.bg-dark-teal .text-link:hover { color: rgba(255, 255, 255, 0.8); }
.case-study-card { background-color: var(--white); padding: 30px; border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); display: flex; flex-wrap: wrap; align-items: center; gap: 40px; }
.case-study-content { flex: 1 1 55%; }
.case-study-image { flex: 1 1 40%; }
.case-study-image img { border-radius: var(--border-radius); }
.case-study-content ul { list-style: none; padding-left: 0; }
.case-study-content ul li { padding-left: 28px; position: relative; margin-bottom: 10px; list-style-type: none !important; }
.case-study-content ul li::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--primary-teal); position: absolute; left: 0; top: 4px; font-size: 0.9em; }
#transformation-stories .grid-2-col { gap: 40px; margin-top: 3rem; }
.story-card img { height: 220px; object-fit: cover; border-bottom: 1px solid var(--mid-gray); }
.story-card h3 { font-size: 1.4rem; margin-bottom: 15px; }
.innovation-flex-container { display: flex; align-items: flex-start; gap: 40px; margin-top: 2rem; flex-wrap: wrap; }
.innovation-image-col { flex: 1 1 40%; max-width: 100%; }
.innovation-text-col { flex: 1 1 55%; max-width: 100%; }
.innovation-image-col img { border-radius: var(--border-radius); }
#impact-vision-cta p:last-of-type { margin-bottom: 2.5rem; font-weight: 500; }
#impact-vision-cta .cta-buttons { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }

/* ==========================================================================
  10. Get Involved Page Specific Styles
   ========================================================================== */
#why-support .support-image img { border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
.fiscal-sponsor { padding: 40px 0; }
.fiscal-sponsor h3 { color: var(--dark-teal); margin-bottom: 1.5rem; font-size: 1.6rem; }
.fiscal-sponsor img { max-height: 100px; margin: 0 auto 1.5rem auto; display: block; }
.fiscal-sponsor p { max-width: 750px; margin: 0 auto 2rem auto; font-size: 1.05rem; line-height: 1.7;}
.fiscal-sponsor .disclaimer { font-size: 0.85rem; margin-top: 1rem; color: var(--dark-gray); }
.donate-options { margin-top: 2rem; }
.donate-tier { /* Add styles if making cards */ }
#partner .partner-image img { border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
#partner .partner-content ul { list-style: none; padding-left: 0; }
#partner .partner-content ul li { padding-left: 28px; position: relative; margin-bottom: 10px; list-style-type: none !important; }
#partner .partner-content ul li::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--primary-teal); position: absolute; left: 0; top: 4px; font-size: 0.9em; }
#partner .partner-content .btn-secondary-light-bg { margin-top: 1.5rem; } /* Use new class */
#spread-word { background-color: var(--primary-teal); }
#spread-word h2.section-title--smaller { margin-bottom: 15px; color: var(--white); }
#spread-word p.section-intro { margin-bottom: 2.5rem; color: rgba(255, 255, 255, 0.9); }
.social-links-large { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 30px; }
.social-links-large a { display: flex; align-items: center; text-decoration: none; color: var(--white); font-size: 1.1rem; transition: transform var(--transition-speed), color var(--transition-speed); }
.social-links-large a:hover { transform: translateY(-3px); color: rgba(255, 255, 255, 0.8); }
.social-links-large img { width: 32px; height: 32px; margin-right: 10px; filter: brightness(0) invert(1); }
#spread-word p:last-of-type { margin-top: 2rem; color: rgba(255, 255, 255, 0.9); }
#volunteer .volunteer-image img { border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
#volunteer .volunteer-content ul { list-style: none; padding-left: 0; }
#volunteer .volunteer-content ul li { padding-left: 28px; position: relative; margin-bottom: 10px; list-style-type: none !important; }
#volunteer .volunteer-content ul li::before { content: "\f058"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--light-teal); position: absolute; left: 0; top: 4px; font-size: 1em; }
#thank-you img { max-width: 400px; margin: 0 auto 2rem auto; border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); }
#thank-you h2.section-title--smaller { margin-bottom: 15px; }
#thank-you p.section-intro { margin-bottom: 0; max-width: 850px; }

/* ==========================================================================
  11. Contact Page Specific Styles
   ========================================================================== */
.page-header { background-color: var(--light-teal); color: var(--white); padding: 60px 20px; text-align: center; }
.page-header h1 { font-size: clamp(2.2rem, 4vw, 2.8rem); margin-bottom: 10px; color: var(--white); }
.page-header .section-intro { font-size: 1.15rem; color: rgba(255, 255, 255, 0.9); max-width: 800px; margin: 0 auto; }
#contact-main .grid-2-col-about { align-items: start; }
.contact-info-area h2.section-title--smaller { margin-bottom: 20px; text-align: left;}
.contact-info-area .section-intro { text-align: left; margin-left: 0; margin-right: 0; margin-bottom: 2rem;}
.direct-contact { margin-top: 2.5rem; }
.direct-contact h3 { color: var(--dark-teal); margin-bottom: 1.5rem; font-size: 1.4rem; }
.contact-item { display: flex; align-items: flex-start; margin-bottom: 1.2rem; gap: 15px; }
.contact-item i { font-size: 1.2rem; color: var(--primary-teal); width: 20px; text-align: center; margin-top: 3px; flex-shrink: 0; }
.contact-item-details { flex: 1; }
.contact-item-details strong { display: block; margin-bottom: 3px; font-weight: 600; color: var(--dark-teal); }
.contact-item-details p, .contact-item-details a { margin: 0; line-height: 1.5; color: var(--dark-gray); }
.contact-item-details a { color: var(--primary-teal); text-decoration: none; }
.contact-item-details a:hover { text-decoration: underline; }
.contact-item-details .email-note { font-size: 0.9rem; color: var(--light-teal); display: block; margin-top: 5px; }
.social-connect { margin-top: 2.5rem; }
.social-connect h3 { color: var(--dark-teal); margin-bottom: 1.5rem; font-size: 1.4rem; }
.social-connect .social-links { display: flex; flex-wrap: wrap; gap: 20px; }
.social-connect .social-link { display: inline-flex; align-items: center; text-decoration: none; color: var(--dark-gray); transition: color var(--transition-speed); font-size: 1rem; margin-bottom: 0; } /* Removed bottom margin */
.social-connect .social-link:hover { color: var(--primary-teal); text-decoration: none;}
.social-connect .social-link img { width: 24px; height: 24px; margin-right: 8px; filter: none; }
.contact-form-area.card { padding: 0; overflow: hidden; }
.contact-form-area iframe { display: block; border: none; width: 100%; min-height: 600px; }

/* ==========================================================================
  12. Component Styles (Shared across pages)
   ========================================================================== */
.card { background-color: var(--white); border-radius: var(--border-radius); box-shadow: var(--box-shadow-light); transition: transform var(--transition-speed) ease, box-shadow var(--transition-speed) ease; overflow: hidden; height: 100%; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-5px); box-shadow: var(--box-shadow-medium); }
.card .card-content { padding: 25px; flex-grow: 1; display: flex; flex-direction: column;}
.card .card-image img { width: 100%; height: 200px; object-fit: cover; }
.card .icon { height: 60px; margin-bottom: 15px; display: flex; align-items: center; justify-content: center; color: var(--primary-teal); }
.card .icon img { width: 50px; height: 50px; object-fit: contain; }
.card .icon i { font-size: 2rem; }
.card h3 { font-size: 1.4rem; margin-bottom: 10px; }
.card h4 { font-size: 1.2rem; margin-bottom: 10px; }
.card p { flex-grow: 1; margin-bottom: 1rem; } /* Ensure p has bottom margin unless it's the last */
.card p:last-of-type { margin-bottom: 0; }
ul.check-list { list-style: none; padding-left: 0; margin-bottom: 1rem;}
ul.check-list li { padding-left: 28px; position: relative; margin-bottom: 12px; list-style-type: none !important; }
ul.check-list li::before { content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; color: var(--primary-teal); position: absolute; left: 0; top: 4px; font-size: 1em; }


/* ==========================================================================
   13. Mobile Navigation Styles (V2 Consolidated)
   ========================================================================== */
.mobile-menu-toggle { display: none; }
@media (max-width: 991px) {
    html { scroll-padding-top: var(--header-height-mobile); }
    .nav-actions { gap: 10px; }
    .site-header { padding: 8px 15px; }
    .site-logo img { height: 45px; }
    .site-logo .logo-text { display: none; }
    .btn-nav-donate { display: none; }
    .mobile-menu-toggle { display: block; background: none; border: none; padding: 8px; margin: 0; cursor: pointer; width: 40px; height: 40px; position: relative; z-index: 1001; order: 1; }
    .mobile-menu-toggle .toggle-bar { display: block; width: 24px; height: 3px; background-color: var(--dark-teal); border-radius: 1px; margin: 5px auto; transition: all 0.3s ease-in-out; }
    .mobile-menu-toggle.open .toggle-bar:nth-child(1) { transform: translateY(8px) rotate(45deg); }
    .mobile-menu-toggle.open .toggle-bar:nth-child(2) { opacity: 0; }
    .mobile-menu-toggle.open .toggle-bar:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
    .nav-list { display: none; position: fixed; top: 0; right: 0; bottom: 0; width: 280px; max-width: 85%; background-color: var(--dark-teal); flex-direction: column; padding: 5rem 0 2rem 0; margin: 0; box-shadow: -3px 0 15px rgba(0,0,0,0.2); transform: translateX(100%); transition: transform 350ms ease-out; z-index: 1000; overflow-y: auto; gap: 0; }
    .nav-list.active { display: flex !important; transform: translateX(0%); }
    .nav-list li.nav-item { width: 100%; border-bottom: 1px solid rgba(255, 255, 255, 0.1); margin: 0 !important; padding: 0 !important; list-style-type: none !important; }
    .nav-list li.nav-item:last-child { border-bottom: none; }
    .nav-list li.nav-item::before, .nav-list li.nav-item::after { content: none !important; }
    .nav-list a { color: var(--white); font-family: var(--font-secondary); font-size: 1.1rem; font-weight: 500; padding: 14px 25px; display: block; text-decoration: none; white-space: normal; transition: background-color 0.2s ease; }
    .nav-list a:hover, .nav-list a.active { background-color: rgba(255, 255, 255, 0.1); }
    .nav-list a.active { font-weight: 600; }
    .nav-list a::before { display: none !important; }
    .nav-list li.has-dropdown > a::after { display: inline-block; content: '▸'; font-size: 0.8em; margin-left: 8px; float: right; line-height: inherit; transition: transform 0.2s ease-out; color: var(--mid-gray); }
    .nav-list li.has-dropdown.submenu-open > a::after { transform: rotate(90deg); }
    .nav-list .dropdown-menu { position: static; display: none; background-color: rgba(0, 0, 0, 0.2); padding: 5px 0 5px 25px; margin: 0; min-width: unset; z-index: auto; border-radius: 0; box-shadow: none; opacity: 1; visibility: visible; transform: none; transition: none; border-top: 1px solid rgba(255, 255, 255, 0.1); }
    .nav-list .dropdown-menu li { border: none; margin: 0 !important; padding: 0 !important; list-style-type: none !important; }
    .nav-list .dropdown-menu li::before, .nav-list .dropdown-menu li::after { content: none !important; }
    .nav-list .dropdown-menu li a { padding: 10px 15px; font-size: 1rem; font-weight: 400; color: var(--mid-gray); }
    .nav-list .dropdown-menu li a:hover, .nav-list .dropdown-menu li a.active { background-color: rgba(255, 255, 255, 0.1); color: var(--white); }
    /* Mobile Swiper */
    #stories-snippet .container { padding-left: 15px; padding-right: 15px; max-width: var(--container-width); }
    .news-slider-container { padding: 0 0 40px 0; overflow: hidden;}
    .news-slider-container .swiper-slide { width: 80%; transform: scale(1); opacity: 1;}
    .news-slider-container .swiper-button-next,
    .news-slider-container .swiper-button-prev { display: none; }
}

/* ==========================================================================
   14. Further Responsiveness (Consolidated)
   ========================================================================== */
@media (max-width: 767px) {
    html { scroll-padding-top: var(--header-height-mobile); }
    h1 { font-size: clamp(2rem, 7vw, 2.5rem); } h2 { font-size: clamp(1.6rem, 5vw, 2rem); }
    .section-padding { padding: 60px 15px; } .section-padding--condensed { padding: 40px 15px; }
    .hero-content h1 { font-size: clamp(2.2rem, 8vw, 2.8rem); }
    .hero-content .subtitle { font-size: clamp(1rem, 4vw, 1.2rem); }
    .hero-buttons .btn { font-size: 0.9rem; padding: 10px 22px; }
    .grid-3-col, .grid-2-col, .grid-2-col-about, .grid-4-col { grid-template-columns: 1fr; }
    .about-snippet-image { order: -1; margin-bottom: 30px;}
    .impact-stat { max-width: none; flex-basis: calc(50% - 15px); }
    .testimonial-card p:first-of-type { font-size: 1rem; }
    #cta-banner h2 { font-size: 2rem; } #cta-banner p { font-size: 1.1rem; }
    .footer-content { text-align: center; }
    .footer-info, .footer-links, .footer-social { margin-bottom: 30px; }
    .footer-info p, .footer-links a, .social-link { font-size: 1rem; }
    .footer-social .social-links { justify-content: center; }
    .social-link { margin-bottom: 0;}
    .subscribe-form-inputs { flex-direction: column; gap: 15px; }
    .subscribe-form-inputs div { min-width: unset; }
    .subscribe-form button[type="submit"] { width: auto; padding: 12px 30px; }
    /* Specific page mobile stacks */
    #the-need .grid-2-col-about .about-snippet-content { order: 1; }
    #the-need .grid-2-col-about .about-snippet-image { order: 2; }
    /* Example for #women-youth from program page if that structure is used on other pages */
    /* #women-youth .grid-2-col-about .program-content { order: 2; } */
    /* #women-youth .grid-2-col-about .program-image { order: 1; margin-bottom: 20px; } */
    .impact-intro-card, .case-study-card { flex-direction: column; }
    .impact-intro-content, .impact-intro-image,
    .case-study-content, .case-study-image { flex-basis: 100%; }
    .impact-intro-image, .case-study-image { order: -1; margin-bottom: 20px; }
    .innovation-flex-container { flex-direction: column; }
    .innovation-image-col { order: -1; margin-bottom: 20px; }
    #contact-main .grid-2-col-about { grid-template-columns: 1fr; gap: 40px; }
    .contact-form-area.card { margin-top: 30px; }
    /* Mobile Timeline */
    .timeline:before { left: 11px; } .timeline-dot { left: 0; transform: translateX(0); }
    .timeline-item { padding-left: 40px; margin-bottom: 30px; }
    .timeline-content { width: 100%; left: 0 !important; }
}
@media (max-width: 480px) {
     html { scroll-padding-top: calc(var(--header-height-mobile) - 1px); }
     .impact-stat { flex-basis: 100%; }
     /* .logo span.logo-text { display: none; } /* Already handled by .site-logo .logo-text in 991px */
     .site-header { padding: 6px 10px; }
     .nav-actions { gap: 8px; }
     .nav-list { max-width: 90%; min-width: 200px;} /* From V2 */
}

/* ==========================================================================
  15. Newsletter Archive Page Specific Styles
   ========================================================================== */
.newsletter-archive-main { min-height: 60vh; }
.archive-header { text-align: center; padding-bottom: 40px; border-bottom: 1px solid var(--mid-gray); margin-bottom: 40px; }
.archive-header h1 { margin-bottom: 10px; font-size: clamp(2rem, 6vw, 3rem); }
.archive-header p { font-size: 1.1rem; color: var(--dark-gray); max-width: 700px; margin: 0 auto; }
.past-issues { margin-bottom: 50px; padding-bottom: 30px; border-bottom: 1px solid var(--light-gray); }
.past-issues h2 { font-size: 1.5rem; color: var(--primary-teal); margin-bottom: 20px; text-align: center; }
.past-issues ul { list-style: none; padding: 0; margin: 0; text-align: center; }
.past-issues li { display: inline-block; margin: 0 10px 10px 10px; }
.past-issues li a { text-decoration: underline; font-weight: 500; color: var(--dark-gray); }
.past-issues li a:hover { color: var(--primary-teal); }
.past-issues li.current-issue a { font-weight: 700; color: var(--dark-teal); text-decoration: none; cursor: default; }
.current-newsletter { margin-bottom: 50px; }
.current-newsletter h2 { font-size: 1.8rem; color: var(--dark-teal); margin-bottom: 25px; text-align: center; }
.newsletter-iframe-wrapper { border: 1px solid var(--mid-gray); box-shadow: 0 5px 15px rgba(0,0,0,0.1); margin: 0 auto; max-width: 100%; }
.newsletter-iframe { display: block; width: 100%; height: 90vh; border: none; }

/* --- Theory of Change Section Styles (Image Left, Text Right) --- */
#theory-of-change {
    /* Uses .grid-2-col-about for layout */
    align-items: center; /* Vertically center image and text block */
}

.toc-image img {
    border-radius: var(--border-radius);
    box-shadow: var(--box-shadow-medium);
    width: 100%;
    height: auto;
}

/* Text Column Content */
.toc-content h2.section-title--smaller {
    text-align: left; /* <<< Keep heading aligned left with text */
    margin-bottom: 15px; /* Space below heading */
}

.toc-content > p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--dark-gray);
    margin-bottom: 1rem; /* Space below intro/outro para */
}

/* Styles for the If/Then Block */
.if-then-block {
    margin: 1.5rem 0; /* Vertical spacing */
    padding: 20px 25px;
    background-color: var(--off-white); /* Use off-white or light-gray */
    border-left: 4px solid var(--primary-teal);
    border-radius: 0 var(--border-radius) var(--border-radius) 0;
}

.if-then-block p {
    font-size: 1rem; /* Slightly smaller for contrast */
    line-height: 1.7;
    color: var(--dark-gray);
    margin-bottom: 0;
}

.if-then-block p strong {
    color: var(--dark-teal);
    font-weight: 600;
}

.if-then-block span {
    display: block;
    text-align: center;
    font-weight: 700;
    margin: 0.75rem 0;
    color: var(--primary-teal);
    font-size: 0.9rem;
    letter-spacing: 0.5px;
}

/* Style concluding italic sentence */
.toc-content > p em {
    font-style: italic;
    color: var(--dark-teal);
    display: block;
    margin-top: 1.5rem; /* Space above conclusion */
}

.toc-content .btn-secondary-light-bg {
    margin-top: 25px; /* Space above button */
}

/* Responsive */
@media (max-width: 767px) {
    #theory-of-change.grid-2-col-about .toc-image {
        order: -1; /* Image appears above text */
        margin-bottom: 30px;
    }
     .toc-content h2.section-title--smaller {
         text-align: center; /* Optional: Center heading on mobile */
     }
     .toc-content > p,
     .if-then-block p {
         font-size: 1rem; /* Adjust size */
     }
    .if-then-block { padding: 15px 20px; }
}