/* Global Styles & Variables */
:root {
    /* Fonts */
    --font-primary: 'Oswald', sans-serif;
    --font-secondary: 'Nunito', sans-serif;

    /* Neutral Colors - Brutalist Inspired */
    --color-bg: #F0F2F5; /* Light, slightly cool grey */
    --color-bg-alt: #E4E6EB; /* Slightly darker for alternate sections */
    --color-surface: #FFFFFF; /* For cards, forms - stark white */
    --color-text-primary: #1C1E21; /* Very dark grey, high contrast */
    --color-text-secondary: #555B66; /* Medium dark grey for less emphasis */
    --color-border: #CED0D4; /* Mid-grey for subtle borders */
    --color-border-strong: #1C1E21; /* Strong, black-like border for brutalist elements */

    /* Accent Colors */
    --color-accent1: #007BFF; /* Vibrant Blue - primary action */
    --color-accent1-dark: #0056b3;
    --color-accent2: #FFC107; /* Bold Yellow - secondary action/highlight */
    --color-accent2-dark: #d39e00;

    /* Text color for on-accent backgrounds */
    --color-text-on-accent: #FFFFFF;

    /* Brutalist Elements */
    --brutalist-border-style: 2px solid var(--color-border-strong);
    --brutalist-shadow-offset: 4px;
    --brutalist-shadow: var(--brutalist-shadow-offset) var(--brutalist-shadow-offset) 0px var(--color-border-strong);
    --brutalist-shadow-hover-offset: 6px;
    --brutalist-shadow-hover: var(--brutalist-shadow-hover-offset) var(--brutalist-shadow-hover-offset) 0px var(--color-border-strong);

    /* Spacing */
    --spacing-unit: 8px;
    --spacing-xs: var(--spacing-unit);
    --spacing-s: calc(var(--spacing-unit) * 2);
    --spacing-m: calc(var(--spacing-unit) * 3);
    --spacing-l: calc(var(--spacing-unit) * 4);
    --spacing-xl: calc(var(--spacing-unit) * 6);
    --spacing-xxl: calc(var(--spacing-unit) * 8);

    /* Transitions */
    --transition-speed: 0.25s;
    --transition-timing: cubic-bezier(0.645, 0.045, 0.355, 1);

    /* Dynamic Gradient & Overlays */
    --gradient-dynamic: linear-gradient(45deg, var(--color-accent1), var(--color-accent2));
    --gradient-overlay: linear-gradient(rgba(0,0,0,0.65), rgba(0,0,0,0.65)); /* For hero text readability */

    /* Font Sizes */
    --font-size-base: 16px;
    --font-size-sm: 0.875rem;
    --font-size-md: 1rem;
    --font-size-lg: 1.125rem; /* Adjusted for more subtle hierarchy */
    --font-size-xl: 1.375rem;
    --font-size-h1: clamp(2.5rem, 5vw, 3.5rem);
    --font-size-h2: clamp(1.8rem, 4vw, 2.5rem);
    --font-size-h3: clamp(1.4rem, 3vw, 1.75rem);

    /* Header Height - adjust if JS changes it */
    --header-height: 70px;
}

/* Basic Reset & Global Settings */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: var(--font-size-base); }
body {
    font-family: var(--font-secondary);
    line-height: 1.7;
    color: var(--color-text-primary);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

/* Container */
.container { width: 90%; max-width: 1200px; margin: 0 auto; padding: 0 var(--spacing-s); }

/* Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-primary);
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: var(--spacing-m);
    color: var(--color-text-primary);
    text-shadow: 1px 1px 1px rgba(0,0,0,0.05);
}
h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }
p { margin-bottom: var(--spacing-m); font-size: var(--font-size-md); }
a { color: var(--color-accent1); text-decoration: none; transition: color var(--transition-speed) var(--transition-timing); }
a:hover, a:focus { color: var(--color-accent1-dark); text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }

/* Global Button Styles */
.btn, button, input[type="submit"], input[type="button"] {
    display: inline-block;
    font-family: var(--font-primary);
    font-size: var(--font-size-md);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: calc(var(--spacing-s) * 0.9) calc(var(--spacing-l) * 0.9);
    border: var(--brutalist-border-style);
    border-radius: 0;
    cursor: pointer;
    text-align: center;
    transition: all var(--transition-speed) var(--transition-timing);
    position: relative;
    z-index: 1;
}
.btn-primary { background-color: var(--color-accent1); color: var(--color-text-on-accent); box-shadow: var(--brutalist-shadow); }
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--color-accent1-dark);
    color: var(--color-text-on-accent);
    box-shadow: var(--brutalist-shadow-hover);
    transform: translate(calc(-1 * (var(--brutalist-shadow-hover-offset) - var(--brutalist-shadow-offset))), calc(-1 * (var(--brutalist-shadow-hover-offset) - var(--brutalist-shadow-offset))));
}
.btn-secondary { background-color: var(--color-surface); color: var(--color-text-primary); box-shadow: var(--brutalist-shadow); }
.btn-secondary:hover, .btn-secondary:focus { background-color: var(--color-bg-alt); box-shadow: var(--brutalist-shadow-hover); transform: translate(-2px, -2px); border-color: var(--color-accent1); }

.btn-read-more { /* For links styled as "Read More" */
    font-family: var(--font-secondary); font-weight: 700; text-transform: none; padding: var(--spacing-xs) 0; color: var(--color-accent1); border: none; background: none; box-shadow: none; position: relative; display: inline-block;
}
.btn-read-more::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 2px; background-image: var(--gradient-dynamic); transition: width var(--transition-speed) var(--transition-timing); }
.btn-read-more:hover::after, .btn-read-more:focus::after { width: 100%; }

/* Utility Classes */
.text-center { text-align: center; }
.alt-bg { background-color: var(--color-bg-alt); }

/* General Section Styling */
.content-section { padding: var(--spacing-xxl) 0; }
.section-title { text-align: center; margin-bottom: var(--spacing-xl); color: var(--color-text-primary); position: relative; padding-bottom: var(--spacing-s); }
.section-title::after { content: ""; display: block; width: 70px; height: 4px; background: var(--gradient-dynamic); margin: var(--spacing-s) auto 0; clip-path: polygon(0 0, 100% 0, 93% 100%, 7% 100%); }
.section-intro { text-align: center; max-width: 750px; margin: 0 auto var(--spacing-xl); color: var(--color-text-secondary); font-size: var(--font-size-lg); }

/* Card Base Styles */
.card {
    background-color: var(--color-surface); border: var(--brutalist-border-style); box-shadow: var(--brutalist-shadow); padding: var(--spacing-m);
    transition: transform var(--transition-speed) var(--transition-timing), box-shadow var(--transition-speed) var(--transition-timing);
    display: flex; flex-direction: column; height: 100%;
}
.card:hover { transform: translateY(-4px) translate(-2px, -2px); box-shadow: var(--brutalist-shadow-hover); }
.card-image { /* Container for image */
    margin-bottom: var(--spacing-m); overflow: hidden; display: flex; justify-content: center; align-items: center;
    height: 200px; /* STROGO: Fixed height for consistent card images */
    width: 100%;
}
.card-image img { width: 100%; height: 100%; object-fit: cover; /* STROGO: Ensure image covers and is centered */ }
.card-content { flex-grow: 1; }
.card-content h3 { font-size: var(--font-size-xl); margin-bottom: var(--spacing-s); color: var(--color-text-primary); }
.card-content p { font-size: var(--font-size-md); color: var(--color-text-secondary); line-height: 1.6; }

/* Header & Navigation */
.site-header { background-color: var(--color-surface); padding: calc(var(--spacing-s) * 0.8) 0; position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; border-bottom: var(--brutalist-border-style); box-shadow: 0 2px 4px rgba(0,0,0,0.05); height: var(--header-height); }
.header-container { display: flex; justify-content: space-between; align-items: center; height: 100%; }
.logo img { max-height: calc(var(--header-height) - var(--spacing-m)); width: auto; }
.main-navigation .nav-menu { list-style: none; display: flex; align-items: center; }
.main-navigation .nav-menu li { margin-left: var(--spacing-l); }
.main-navigation .nav-menu a { font-family: var(--font-primary); font-weight: 700; text-transform: uppercase; color: var(--color-text-primary); padding: var(--spacing-xs) var(--spacing-s); position: relative; letter-spacing: 0.5px; }
.main-navigation .nav-menu a::after { content: ""; position: absolute; bottom: -3px; left: 50%; transform: translateX(-50%); width: 0; height: 3px; background: var(--gradient-dynamic); transition: width var(--transition-speed) var(--transition-timing); clip-path: polygon(10% 0, 90% 0, 100% 100%, 0% 100%); }
.main-navigation .nav-menu a:hover::after, .main-navigation .nav-menu a:focus::after, .main-navigation .nav-menu .active a::after { width: 100%; }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: var(--spacing-s); }
.hamburger-icon { display: block; width: 24px; height: 3px; background-color: var(--color-text-primary); position: relative; transition: background-color var(--transition-speed) var(--transition-timing); }
.hamburger-icon::before, .hamburger-icon::after { content: ""; position: absolute; left: 0; width: 100%; height: 3px; background-color: var(--color-text-primary); transition: transform var(--transition-speed) var(--transition-timing), top var(--transition-speed) var(--transition-timing); }
.hamburger-icon::before { top: -7px; } .hamburger-icon::after { top: 7px; }
.nav-toggle[aria-expanded="true"] .hamburger-icon { background-color: transparent; }
.nav-toggle[aria-expanded="true"] .hamburger-icon::before { transform: rotate(45deg); top: 0; }
.nav-toggle[aria-expanded="true"] .hamburger-icon::after { transform: rotate(-45deg); top: 0; }

/* Hero Section */
.hero-section {
    padding-top: calc(var(--header-height) + var(--spacing-xl)); /* Account for fixed header */
    padding-bottom: var(--spacing-xl); display: flex; align-items: center; justify-content: center; text-align: center; position: relative;
    background-size: cover; background-position: center center; background-repeat: no-repeat; background-attachment: fixed; /* Basic parallax */
    color: #FFFFFF; /* STROGO: Text in hero section should be WHITE */
}
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--gradient-overlay); z-index: 1; }
.hero-content { position: relative; z-index: 2; max-width: 800px; }
.hero-title { margin-bottom: var(--spacing-m); color: #FFFFFF !important; text-shadow: 2px 2px 5px rgba(0,0,0,0.7); }
.hero-subtitle { margin-bottom: var(--spacing-l); line-height: 1.6; color: #FFFFFF !important; text-shadow: 1px 1px 4px rgba(0,0,0,0.6); font-size: var(--font-size-lg); }
.btn-hero { padding: var(--spacing-m) var(--spacing-xl); font-size: var(--font-size-lg); }

/* Methodology Section */
.methodology-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--spacing-l); margin-top: var(--spacing-xl); }
.methodology-item { text-align: center; padding: var(--spacing-m); border: 2px dashed var(--color-border); transition: border-color var(--transition-speed) var(--transition-timing), transform var(--transition-speed) var(--transition-timing); }
.methodology-item:hover { border-color: var(--color-accent1); transform: translateY(-5px); }
.methodology-icon { width: 60px; height: 60px; margin: 0 auto var(--spacing-m); }
.methodology-item-title { font-size: var(--font-size-xl); margin-bottom: var(--spacing-s); }

/* Our Process Section */
.process-steps { list-style: none; padding-left: 0; margin-top: var(--spacing-xl); position: relative; }
.process-step { position: relative; margin-bottom: var(--spacing-l); background-color: var(--color-surface); padding: var(--spacing-m); padding-left: calc(var(--spacing-l) + 40px); border: var(--brutalist-border-style); box-shadow: var(--brutalist-shadow); }
.process-step:last-child { margin-bottom: 0; }
.process-step-number {
    position: absolute; left: var(--spacing-m); top: 50%; transform: translateY(-50%); width: 36px; height: 36px; background-color: var(--color-accent1); color: var(--color-text-on-accent);
    font-family: var(--font-primary); font-size: var(--font-size-lg); font-weight: 700; display: flex; align-items: center; justify-content: center; border: 2px solid var(--color-border-strong); z-index: 1; box-shadow: 2px 2px 0px var(--color-border-strong);
}
.process-step-title { font-size: var(--font-size-xl); margin-bottom: var(--spacing-s); }

/* Projects, Media, External Resources Sections (Card Grids) */
.projects-grid, .media-grid, .resources-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--spacing-l); margin-top: var(--spacing-xl); }
.project-card .card-image, .media-article .card-image { /* Using .card-image fixed height from global styles */ }
.project-title, .media-title, .resource-title { font-size: var(--font-size-xl); margin-bottom: var(--spacing-s); }
.resource-title a { color: var(--color-text-primary); } .resource-title a:hover { color: var(--color-accent1); }
.project-description, .media-summary, .resource-description { font-size: var(--font-size-sm); line-height: 1.6; }
.media-article .card-content { display: flex; flex-direction: column; justify-content: space-between; }

/* FAQ Section (Accordion) */
.accordion { max-width: 800px; margin: var(--spacing-xl) auto 0; }
.accordion-item { background-color: var(--color-surface); margin-bottom: var(--spacing-s); border: var(--brutalist-border-style); box-shadow: var(--brutalist-shadow); }
.accordion-header { background-color: transparent; border: none; width: 100%; text-align: left; padding: var(--spacing-m); font-family: var(--font-primary); font-size: var(--font-size-lg); font-weight: 700; color: var(--color-text-primary); cursor: pointer; position: relative; display: flex; justify-content: space-between; align-items: center; }
.accordion-header:hover { color: var(--color-accent1); }
.accordion-icon { width: 10px; height: 10px; border-left: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(-45deg); transition: transform var(--transition-speed) var(--transition-timing); margin-left: var(--spacing-m); }
.accordion-header[aria-expanded="true"] .accordion-icon { transform: rotate(135deg); }
.accordion-content { max-height: 0; overflow: hidden; transition: max-height var(--transition-speed) ease-out, padding var(--transition-speed) ease-out; padding: 0 var(--spacing-m); }
.accordion-content p { margin-bottom: var(--spacing-m); font-size: var(--font-size-md); color: var(--color-text-secondary); }

/* Contact Section */
.contact-wrapper { display: grid; grid-template-columns: 1fr; gap: var(--spacing-xl); margin-top: var(--spacing-xl); }
@media (min-width: 800px) { .contact-wrapper { grid-template-columns: minmax(0, 2fr) minmax(0, 1.2fr); } } /* Adjusted ratio */
.contact-form-container, .contact-details { background-color: var(--color-surface); padding: var(--spacing-l); border: var(--brutalist-border-style); box-shadow: var(--brutalist-shadow); }
.form-group { margin-bottom: var(--spacing-m); }
.form-group label { display: block; font-family: var(--font-primary); font-weight: 700; margin-bottom: var(--spacing-xs); color: var(--color-text-primary); font-size: var(--font-size-sm); }
.form-group input[type="text"], .form-group input[type="email"], .form-group textarea {
    width: 100%; padding: var(--spacing-s); border: 2px solid var(--color-border); border-radius: 0; font-family: var(--font-secondary); font-size: var(--font-size-md); background-color: var(--color-bg);
    transition: border-color var(--transition-speed) var(--transition-timing), box-shadow var(--transition-speed) var(--transition-timing);
}
.form-group input[type="text"]:focus, .form-group input[type="email"]:focus, .form-group textarea:focus { outline: none; border-color: var(--color-accent1); box-shadow: 0 0 0 2px var(--color-accent1-dark); }
.form-group textarea { min-height: 120px; resize: vertical; }
.form-group-switch { display: flex; align-items: center; justify-content: space-between; margin-top: var(--spacing-l); }
.switch-label { margin-bottom: 0 !important; margin-right: var(--spacing-m); font-weight: normal !important; font-family: var(--font-secondary) !important; font-size: var(--font-size-md) !important; }
.switch { position: relative; display: inline-block; width: 48px; height: 24px; } .switch input { opacity: 0; width: 0; height: 0; }
.slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--color-border); transition: var(--transition-speed); border: 2px solid var(--color-border-strong); }
.slider:before { position: absolute; content: ""; height: 16px; width: 16px; left: 2px; bottom: 2px; background-color: white; transition: var(--transition-speed); border: 1px solid var(--color-border-strong); }
input:checked + .slider { background-color: var(--color-accent1); }
input:checked + .slider:before { transform: translateX(24px); }
.contact-details h3 { font-size: var(--font-size-xl); margin-bottom: var(--spacing-m); }
.contact-details p { margin-bottom: var(--spacing-s); } .contact-details strong { font-family: var(--font-primary); }
.contact-map-placeholder img { border: var(--brutalist-border-style); margin-top: var(--spacing-m); }
.map-caption { font-size: var(--font-size-sm); text-align: center; color: var(--color-text-secondary); margin-top: var(--spacing-xs); }

/* Footer */
.site-footer { background-color: var(--color-text-primary); color: var(--color-bg); padding: var(--spacing-xl) 0 var(--spacing-m); border-top: 4px solid var(--color-accent1); }
.footer-widgets { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--spacing-l); margin-bottom: var(--spacing-xl); }
.footer-widget h4 { font-family: var(--font-primary); font-size: var(--font-size-lg); margin-bottom: var(--spacing-m); color: var(--color-surface); position: relative; padding-bottom: var(--spacing-xs); }
.footer-widget h4::after { content: ''; display: block; width: 30px; height: 2px; background-color: var(--color-accent1); margin-top: var(--spacing-xs); }
.footer-widget p, .footer-widget ul { font-size: var(--font-size-sm); color: var(--color-bg-alt); }
.footer-widget ul { list-style: none; padding-left: 0; } .footer-widget ul li { margin-bottom: var(--spacing-xs); }
.footer-widget ul a { color: var(--color-bg-alt); transition: color var(--transition-speed) var(--transition-timing), padding-left var(--transition-speed) var(--transition-timing); }
.footer-widget ul a:hover, .footer-widget ul a:focus { color: var(--color-surface); text-decoration: none; padding-left: var(--spacing-xs); }
.footer-widget .social-links-text a { display: inline-block; padding: var(--spacing-xs) 0; } /* Ensured social links are text */
.footer-bottom { text-align: center; padding-top: var(--spacing-m); border-top: 1px solid var(--color-border); font-size: var(--font-size-sm); color: var(--color-bg-alt); }
.footer-widget img[alt*="Logo"] { max-width: 150px; margin-top: var(--spacing-s); }

/* Specific Page Styles */
.success-page-container { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; text-align: center; padding: var(--spacing-xl); background-color: var(--color-bg); }
.success-page-container .card { max-width: 500px; padding: var(--spacing-xl); text-align: center; }
.success-page-container h1 { color: var(--color-accent1); font-size: var(--font-size-h1); }

.privacy-page-container, .terms-page-container { padding-top: calc(var(--header-height) + var(--spacing-xl)); padding-bottom: var(--spacing-xl); }
.privacy-page-container .container h1, .terms-page-container .container h1 { margin-bottom: var(--spacing-l); text-align: left; }
.privacy-page-container .container h1::after, .terms-page-container .container h1::after { margin-left: 0; margin-right: auto; }
.privacy-page-container .content-wrapper, .terms-page-container .content-wrapper { background-color: var(--color-surface); padding: var(--spacing-l); border: var(--brutalist-border-style); box-shadow: var(--brutalist-shadow); }
.privacy-page-container h2, .terms-page-container h2 { font-size: var(--font-size-h3); margin-top: var(--spacing-l); margin-bottom: var(--spacing-s); border-bottom: 2px solid var(--color-border); padding-bottom: var(--spacing-xs); }
.privacy-page-container ul, .terms-page-container ul { list-style-position: inside; padding-left: var(--spacing-s); margin-bottom: var(--spacing-m); }
.privacy-page-container li, .terms-page-container li { margin-bottom: var(--spacing-xs); }

/* Responsive Design */
@media (max-width: 992px) { /* Tablet */
    /* Typography adjustments can go here if needed */
}

@media (max-width: 768px) { /* Mobile landscape and portrait */
    .nav-toggle { display: block; z-index: 1001; }
    .main-navigation .nav-menu {
        display: none; flex-direction: column; position: absolute; top: 100%; left: 0; width: 100%; background-color: var(--color-surface);
        border-top: var(--brutalist-border-style); border-bottom: var(--brutalist-border-style); padding: var(--spacing-m) 0; box-shadow: 0 5px 10px rgba(0,0,0,0.1);
    }
    .main-navigation .nav-menu.is-active { display: flex; }
    .main-navigation .nav-menu li { margin-left: 0; width: 100%; text-align: center; }
    .main-navigation .nav-menu a { display: block; padding: var(--spacing-m); border-bottom: 1px solid var(--color-border); }
    .main-navigation .nav-menu li:last-child a { border-bottom: none; }
    .main-navigation .nav-menu a::after { display: none; }
    .main-navigation .nav-menu a:hover, .main-navigation .nav-menu a:focus { background-color: var(--color-bg-alt); color: var(--color-accent1); }

    .methodology-grid, .projects-grid, .media-grid, .resources-grid { grid-template-columns: 1fr; }
    .contact-wrapper { grid-template-columns: 1fr; }
    .contact-details { margin-top: var(--spacing-l); } /* Add space if stacked */
    .footer-widgets { grid-template-columns: 1fr; text-align: center; }
    .footer-widget h4::after { margin-left: auto; margin-right: auto; }
    .footer-widget img[alt*="Logo"] { margin-left: auto; margin-right: auto; }
}

@media (max-width: 480px) { /* Small mobile */
    :root { --font-size-base: 15px; }
    .btn, button, input[type="submit"] { padding: var(--spacing-s) var(--spacing-m); font-size: calc(var(--font-size-md) * 0.95); }
    .container { width: 95%; }
    .section-title { font-size: calc(var(--font-size-h2) * 0.9); }
    .hero-title { font-size: calc(var(--font-size-h1) * 0.85 ); }
    .hero-subtitle { font-size: calc(var(--font-size-lg) * 0.9); }
}