/*
Theme Name: NEADS Modern
Theme URI: https://neads.ca
Author: ShiftOut Strategy
Author URI: https://shiftoutstrategy.com
Description: A modern, WCAG 2.2 AA compliant WordPress theme designed for the National Educational Association of Disabled Students (NEADS). Features clean typography, accessible navigation, responsive layouts, and a professional nonprofit aesthetic.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: neads-modern
Tags: accessibility-ready, custom-logo, custom-menu, featured-images, translation-ready, blog, education, one-column, two-columns, left-sidebar, right-sidebar, full-width-template
*/

/* ==========================================================================
   CSS Custom Properties / Design Tokens
   ========================================================================== */

:root {
    /* Primary palette — Customizer-overridable */
    --color-primary: #1B4F7C;
    --color-primary-dark: #0F3555;
    --color-primary-light: #2A6DA8;
    --color-primary-lightest: #E8F0F8;

    /* Accent */
    --color-accent: #C04520;
    --color-accent-dark: #A83C18;
    --color-accent-light: #F2C4B0;
    --color-accent-bg: #D4572A;
    --color-accent-bg-dark: #B3441D;

    /* Neutrals */
    --color-white: #FFFFFF;
    --color-gray-50: #F7F8FA;
    --color-gray-100: #EBEDF0;
    --color-gray-200: #D1D5DB;
    --color-gray-300: #9CA3AF;
    --color-gray-400: #6B7280;
    --color-gray-500: #4B5563;
    --color-gray-600: #374151;
    --color-gray-700: #1F2937;
    --color-gray-900: #111827;

    /* Semantic */
    --color-success: #0D7A3F;
    --color-warning: #B45309;
    --color-error: #C41E1E;
    --color-info: #1B4F7C;

    /* Component tokens — driven by Customizer, fallback to defaults */
    --header-bg: #FFFFFF;
    --header-text: var(--color-primary);
    --header-nav-text: var(--color-gray-600);
    --header-nav-hover: var(--color-primary);
    --header-nav-hover-bg: var(--color-primary-lightest);
    --header-cta-bg: var(--color-accent);
    --header-cta-text: #FFFFFF;
    --header-border: var(--color-gray-100);

    --utilitybar-bg: var(--color-primary-dark);
    --utilitybar-text: #FFFFFF;
    --utilitybar-border: var(--color-accent);

    --pageheader-bg-start: var(--color-primary-dark);
    --pageheader-bg-end: var(--color-primary);
    --pageheader-text: #FFFFFF;
    --pageheader-subtitle: rgba(255, 255, 255, 0.85);

    --body-bg: var(--color-gray-50);
    --body-text: var(--color-gray-700);
    --body-heading: var(--color-gray-900);
    --body-link: var(--color-primary-light);
    --body-link-hover: var(--color-primary-dark);
    --content-bg: #FFFFFF;
    --content-border: var(--color-gray-200);

    --widget-bg: #FFFFFF;
    --widget-border: var(--color-gray-200);
    --widget-title-color: var(--header-text);
    --widget-title-border: var(--color-primary-lightest);
    --widget-link: var(--color-gray-600);
    --widget-link-hover: var(--color-primary);

    --btn-primary-bg: var(--color-accent);
    --btn-primary-text: #FFFFFF;
    --btn-primary-hover-bg: var(--color-accent-dark);
    --btn-outline-color: var(--header-text);
    --btn-outline-hover-bg: var(--color-primary);
    --btn-outline-hover-text: #FFFFFF;

    --card-bg: #FFFFFF;
    --card-border: var(--color-gray-200);
    --card-title: var(--color-gray-900);
    --card-text: var(--color-gray-500);
    --card-meta: var(--color-gray-400);
    --card-link: var(--color-primary);

    --hero-bg-start: var(--color-primary-dark);
    --hero-bg-end: var(--color-primary-light);
    --hero-text: #FFFFFF;

    --footer-bg: var(--color-gray-900);
    --footer-text: var(--color-gray-300);
    --footer-heading: #FFFFFF;
    --footer-link: var(--color-gray-300);
    --footer-link-hover: #FFFFFF;
    --footer-border: var(--color-gray-700);
    --footer-bottom-bg: var(--color-gray-900);
    --footer-bottom-border: var(--color-gray-700);

    /* Typography */
    --font-heading: 'Source Serif 4', 'Georgia', serif;
    --font-body: 'Source Sans 3', 'Segoe UI', 'Helvetica Neue', sans-serif;

    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 1.875rem;
    --text-4xl: 2.25rem;
    --text-5xl: 3rem;

    --leading-tight: 1.25;
    --leading-normal: 1.6;
    --leading-relaxed: 1.75;

    /* Spacing */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;

    /* Layout */
    --container-max: 1200px;
    --container-narrow: 800px;
    --sidebar-width: 320px;

    /* Borders & Radii */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --border-thin: 1px solid var(--color-gray-200);

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.1);

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;

    /* Focus ring */
    --focus-ring: 0 0 0 3px #103E5C, 0 0 0 6px #FFFFFF;
}


/* ==========================================================================
   Reset & Base
   ========================================================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 100%;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--body-text);
    background-color: var(--body-bg);
    -webkit-font-smoothing: antialiased;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: var(--body-link);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color var(--transition-fast);
}

a:hover { color: var(--body-link-hover); }

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid #103E5C;
    outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
    border-radius: var(--radius-sm);
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--body-heading);
    line-height: var(--leading-tight);
    font-weight: 600;
}

h1 { font-size: var(--text-4xl); margin-bottom: var(--space-6); }
h2 { font-size: var(--text-3xl); margin-bottom: var(--space-5); }
h3 { font-size: var(--text-2xl); margin-bottom: var(--space-4); }
h4 { font-size: var(--text-xl);  margin-bottom: var(--space-3); }

p     { margin-bottom: var(--space-4); }
ul,ol { margin-bottom: var(--space-4); padding-left: var(--space-6); }
li    { margin-bottom: var(--space-2); }

blockquote {
    border-left: 4px solid var(--color-primary);
    padding: var(--space-4) var(--space-6);
    margin: var(--space-6) 0;
    background: var(--color-primary-lightest);
    font-style: italic;
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

table       { width: 100%; border-collapse: collapse; margin-bottom: var(--space-6); }
th, td      { padding: var(--space-3) var(--space-4); text-align: left; border-bottom: var(--border-thin); }
th          { background-color: var(--color-primary); color: var(--color-white); font-weight: 600; }


/* ==========================================================================
   Standalone Utility Bar (renders above all headers via wp_body_open)
   ========================================================================== */

.neads-lang-bar {
    background-color: var(--color-primary-dark, #0F3555);
    border-bottom: 2px solid var(--color-accent, #C04520);
    padding: var(--space-1) var(--space-6);
    position: relative;
    z-index: 10000;
    color: #fff;
    font-size: var(--text-sm, 0.875rem);
}

.neads-lang-bar__inner {
    max-width: var(--container-max, 1200px);
    margin: 0 auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* Widget titles hidden visually in the bar */
.neads-lang-bar .widget-title,
.neads-lang-bar h2,
.neads-lang-bar h3 {
    position: absolute;
    width: 1px;
    height: 1px;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    overflow: hidden;
    margin: -1px;
    padding: 0;
    border: 0;
}

/* Polylang widget list */
.neads-lang-bar ul {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    list-style: none;
    padding: 0;
    margin: 0;
}

.neads-lang-bar li {
    margin: 0;
    padding: 0;
}

.neads-lang-bar a {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-weight: 600;
    border-radius: var(--radius-sm, 4px);
    min-height: 44px;
    line-height: 44px;
    transition: background-color 150ms ease;
}

.neads-lang-bar a:hover {
    background-color: rgba(255, 255, 255, 0.15);
    color: #fff;
}

.neads-lang-bar .current-lang a,
.neads-lang-bar a[aria-current] {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.neads-lang-bar li + li::before {
    content: '|';
    color: rgba(255, 255, 255, 0.35);
    margin-right: var(--space-1);
}

/* Polylang dropdown mode */
.neads-lang-bar select {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-sm, 4px);
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-sm, 0.875rem);
    min-height: 44px;
    cursor: pointer;
}

/* Generic widget text in bar */
.neads-lang-bar .utility-widget,
.neads-lang-bar .widget {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.neads-lang-bar .utility-widget p,
.neads-lang-bar .widget p {
    margin: 0;
}


/* ==========================================================================
   Skip Link
   ========================================================================== */

.skip-link {
    position: absolute;
    top: -100%;
    left: var(--space-4);
    z-index: 10000;
    padding: var(--space-3) var(--space-6);
    background: var(--color-primary-dark);
    color: var(--color-white);
    font-weight: 600;
    text-decoration: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.skip-link:focus { top: 0; outline: 3px solid #103E5C; outline-offset: 2px; box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C; }


/* ==========================================================================
   Utility Bar
   ========================================================================== */

.utility-bar {
    background-color: var(--utilitybar-bg);
    color: var(--color-white);
    font-size: var(--text-sm);
    border-bottom: 3px solid var(--utilitybar-border);
}

.utility-bar__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-2) var(--space-6);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.utility-bar a {
    color: var(--color-white);
    text-decoration: none;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    transition: background-color var(--transition-fast);
}

.utility-bar a:hover { background-color: rgba(255,255,255,0.15); color: var(--color-white); }

.utility-links {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    list-style: none;
    padding: 0;
    margin: 0;
}

.utility-widgets {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-sm);
}

.utility-widgets .utility-widget {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.utility-widgets .utility-widget p { margin: 0; }
.utility-widgets .utility-widget a { color: var(--utilitybar-text); text-decoration: none; }
.utility-widgets .utility-widget a:hover { text-decoration: underline; }


/* ==========================================================================
   Site Header
   ========================================================================== */

.site-header {
    background-color: var(--header-bg);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 1000;
    overflow: visible;
}

.site-header.scrolled { box-shadow: var(--shadow-md); }

.site-header__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-4) var(--space-6);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-6);
    position: relative;
    overflow: visible;
}

.site-branding        { flex-shrink: 0; }
.site-branding a      { text-decoration: none; display: flex; align-items: center; gap: var(--space-3); }
.site-branding img,
.site-branding .custom-logo { height: 48px; width: auto; max-width: 100%; }

.site-title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--header-text);
    margin: 0;
    line-height: 1.2;
}

.site-title a          { color: inherit; text-decoration: none; }
.site-description      { font-size: var(--text-sm); color: var(--color-gray-400); margin: 0; }


/* ==========================================================================
   Primary Navigation
   ========================================================================== */

.primary-navigation    { flex-grow: 1; }

.primary-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: var(--space-1);
    justify-content: flex-end;
}

.primary-navigation li { position: relative; margin: 0; }

.primary-navigation a {
    display: block;
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--header-nav-text);
    text-decoration: none;
    border-radius: var(--radius-md);
    transition: color var(--transition-fast), background-color var(--transition-fast);
    white-space: nowrap;
}

.primary-navigation a:hover,
.primary-navigation .current-menu-item > a,
.primary-navigation .current-menu-ancestor > a {
    color: var(--header-text);
    background-color: var(--color-primary-lightest);
}

/* Dropdowns */
.primary-navigation .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 240px;
    background: var(--color-white);
    border: var(--border-thin);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: var(--space-2);
    z-index: 9999;
    flex-direction: column;
}

.primary-navigation li:hover > .sub-menu,
.primary-navigation li:focus-within > .sub-menu,
.primary-navigation li.submenu-open > .sub-menu { display: flex; }

.primary-navigation .sub-menu a { font-weight: 400; padding: var(--space-2) var(--space-3); }

/* Dropdown toggle button */
.dropdown-toggle {
    background: none;
    border: none;
    padding: var(--space-2);
    cursor: pointer;
    color: var(--color-gray-400);
    display: inline-flex;
    align-items: center;
    min-width: 44px;
    min-height: 44px;
    justify-content: center;
}

.dropdown-toggle:hover { color: var(--color-primary); }

/* Mobile toggle */
.menu-toggle {
    display: none;
    background: none;
    border: 2px solid var(--color-primary);
    color: var(--header-text);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-weight: 600;
    cursor: pointer;
    line-height: 1;
}

.menu-toggle:hover { background-color: var(--color-primary); color: var(--color-white); }

.menu-toggle[aria-expanded="true"] .menu-toggle__open  { display: none; }
.menu-toggle[aria-expanded="false"] .menu-toggle__close,
.menu-toggle:not([aria-expanded]) .menu-toggle__close  { display: none; }


/* ==========================================================================
   Container & Layout
   ========================================================================== */

.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6);
}

.container-narrow {
    max-width: var(--container-narrow);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--space-6);
    padding-right: var(--space-6);
}

.site-content { padding: var(--space-12) 0; position: relative; z-index: 1; }

/* Grid layouts */
.layout-sidebar-right {
    display: grid;
    grid-template-columns: 1fr var(--sidebar-width);
    gap: var(--space-10);
}

.layout-sidebar-left {
    display: grid;
    grid-template-columns: var(--sidebar-width) 1fr;
    gap: var(--space-10);
}

.layout-full-width { max-width: 100%; }

.content-area { min-width: 0; }


/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    border-radius: var(--radius-md);
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition-fast);
    white-space: nowrap;
    min-height: 44px;
}

.btn-primary {
    background-color: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    border-color: var(--btn-primary-bg);
}
.btn-primary:hover {
    background-color: var(--btn-primary-hover-bg);
    border-color: var(--btn-primary-hover-bg);
    color: var(--color-white);
}

.btn-secondary {
    background-color: transparent;
    color: var(--color-white);
    border-color: var(--color-white);
}
.btn-secondary:hover {
    background-color: var(--color-white);
    color: var(--color-primary-dark);
}

.btn-outline {
    background-color: transparent;
    color: var(--header-text);
    border-color: var(--header-text);
}
.btn-outline:hover {
    background-color: var(--header-text);
    color: var(--btn-outline-hover-text);
}

.btn-sm { padding: var(--space-2) var(--space-4); font-size: var(--text-sm); }
.btn-lg { padding: var(--space-4) var(--space-8); font-size: var(--text-lg); }


/* ==========================================================================
   Hero Section (Homepage)
   ========================================================================== */

.hero {
    background: linear-gradient(var(--hero-gradient-angle, 135deg), var(--hero-bg-start) 0%, var(--color-primary) 40%, var(--hero-bg-end) 100%);
    color: var(--hero-text);
    padding: var(--space-20) var(--space-6);
    position: relative;
    overflow: hidden;
    background-size: cover;
    background-position: center;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(var(--hero-gradient-angle, 135deg), var(--hero-bg-start) 0%, var(--color-primary) 40%, var(--hero-bg-end) 100%);
    z-index: 1;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='1.5' fill='rgba(255,255,255,0.06)'/%3E%3C/svg%3E") repeat;
    background-size: 40px 40px;
    z-index: 2;
}

.hero > .container {
    position: relative;
    z-index: 3;
}

/* Grid: 1-col or 2-col */
.hero__grid {
    display: grid;
    gap: var(--space-10);
    align-items: center;
}

.hero--1-col .hero__grid        { grid-template-columns: 1fr; text-align: center; max-width: 800px; margin: 0 auto; }
.hero--1-col-left .hero__grid   { grid-template-columns: 1fr; text-align: left; max-width: 700px; }
.hero--2-col .hero__grid        { grid-template-columns: 1.2fr 1fr; }

.hero__title {
    font-size: var(--text-5xl);
    color: inherit;
    margin-bottom: var(--space-4);
    font-weight: 700;
}

.hero__desc {
    font-size: var(--text-xl);
    line-height: var(--leading-relaxed);
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--space-8);
}

.hero__desc p { margin-bottom: var(--space-3); }
.hero__desc p:last-child { margin-bottom: 0; }

.hero__buttons {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.hero--1-col .hero__buttons { justify-content: center; }

/* Right column (2-col layout) */
.hero__right {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.hero__right img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
}

.hero__right .hero-widget {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    color: inherit;
}

/* Stats bar */
/* Stats — cards variant (default) */
.hero__stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-12);
}

.hero__stats--cards .stat-item {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    text-align: center;
}

/* Stats — bar variant */
.hero__stats--bar {
    display: flex;
    justify-content: center;
    gap: 0;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-top: var(--space-12);
}

.hero__stats--bar .stat-item {
    flex: 1;
    padding: var(--space-5) var(--space-6);
    text-align: center;
    position: relative;
}

.hero__stats--bar .stat-item + .stat-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background: rgba(255, 255, 255, 0.2);
}

.stat-item {
    text-align: center;
}

.stat-number {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    font-weight: 700;
    display: block;
    margin-bottom: var(--space-1);
}

.stat-label {
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.8);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}


/* ==========================================================================
   Homepage Sections
   ========================================================================== */

.home-section {
    padding: var(--space-16) 0;
}

.home-section--white   { background-color: var(--color-white); }
.home-section--light   { background-color: var(--color-gray-50); }
.home-section--primary {
    background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
    color: var(--color-white);
}
.home-section--primary .home-section__title { color: var(--color-white); }
.home-section--primary > .container > .home-section__content > .home-widget > .widget-title,
.home-section--primary > .container > .home-section__split .home-section__col > .home-widget > .widget-title {
    /* Widget titles inside cards stay dark — only bare section text goes white */
}
.home-section--primary a { color: rgba(255,255,255,0.9); }
.home-section--primary .widget a { color: var(--widget-link); }

.home-section--dark {
    background-color: var(--color-gray-900);
    color: var(--color-gray-300);
}
.home-section--dark .home-section__title { color: var(--color-white); }
.home-section--dark a { color: rgba(255,255,255,0.85); }
.home-section--dark .widget a { color: var(--widget-link); }

.home-section__title {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    color: var(--section-heading-color, var(--body-heading));
    margin-bottom: var(--space-8);
}

.home-section__full {
    padding: 0 var(--space-6);
}

/* Custom section link colour */
.home-section a {
    color: var(--section-link-color, inherit);
}
.home-section .widget a {
    color: var(--section-link-color, var(--widget-link));
}

/* Padding variants */
.home-section--pad-compact  { padding: var(--space-8) 0; }
.home-section--pad-normal   { padding: var(--space-16) 0; }
.home-section--pad-spacious { padding: var(--space-24) 0; }

.home-section__content > .widget + .widget,
.home-section__content > .home-widget + .home-widget {
    margin-top: var(--space-8);
}

/* Split layout — left/right columns */
.home-section__split {
    display: grid;
    gap: var(--space-8);
}

.home-section__col {
    display: flex;
    flex-direction: column;
}

.home-section__col > .widget,
.home-section__col > .home-widget {
    flex: 1;
}

.home-section__col > .widget + .widget,
.home-section__col > .home-widget + .home-widget {
    margin-top: var(--space-6);
}

@media (max-width: 768px) {
    .home-section__split {
        grid-template-columns: 1fr !important;
    }
}


/* ==========================================================================
   Cards
   ========================================================================== */

.card {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--card-border);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    display: flex;
    flex-direction: column;
}

.card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.card-image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
    display: block;
}

.card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.card:hover .card-image img { transform: scale(1.03); }

.card-body {
    padding: var(--space-6);
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.card-meta {
    font-size: var(--text-sm);
    color: var(--color-gray-400);
    margin-bottom: var(--space-2);
}

.card-title {
    font-size: var(--text-xl);
    margin-bottom: var(--space-3);
}

.card-title a {
    color: var(--body-heading);
    text-decoration: none;
}

.card-title a:hover { color: var(--color-primary); }

.card-excerpt {
    color: var(--color-gray-500);
    margin-bottom: var(--space-4);
    flex-grow: 1;
}

.read-more-link {
    font-weight: 600;
    color: var(--header-text);
    text-decoration: none;
}

.read-more-link:hover { text-decoration: underline; }

/* Card Grids */
.card-grid {
    display: grid;
    gap: var(--space-8);
}

.card-grid-3 { grid-template-columns: repeat(3, 1fr); }

.posts-grid {
    display: grid;
    gap: var(--space-8);
}


/* ==========================================================================
   CTA Banner
   ========================================================================== */

.cta-banner {
    background: linear-gradient(135deg, var(--color-accent-bg-dark), var(--color-accent-bg));
    color: var(--color-white);
    padding: var(--space-16) var(--space-6);
    text-align: center;
}

.cta-banner h2 {
    color: var(--color-white);
    margin-bottom: var(--space-4);
}

.cta-banner p {
    font-size: var(--text-lg);
    color: rgba(255, 255, 255, 0.9);
    max-width: 600px;
    margin: 0 auto var(--space-8);
}

.cta-buttons {
    display: flex;
    gap: var(--space-4);
    justify-content: center;
    flex-wrap: wrap;
}

.cta-banner .btn-primary {
    background-color: var(--btn-primary-text);
    color: var(--color-accent-dark);
    border-color: var(--btn-primary-text);
}
.cta-banner .btn-primary:hover {
    background-color: transparent;
    color: var(--color-white);
    border-color: var(--color-white);
}

.cta-banner .btn-outline {
    color: var(--color-white);
    border-color: var(--color-white);
}
.cta-banner .btn-outline:hover {
    background-color: var(--btn-outline-hover-text);
    color: var(--color-accent-dark);
}


/* ==========================================================================
   Sidebar / Widgets
   ========================================================================== */

.sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

.widget {
    background: var(--widget-bg);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--widget-border);
}

.widget-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--header-text);
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--color-primary-lightest);
}

.widget ul           { list-style: none; padding: 0; }
.widget ul li         { margin-bottom: var(--space-2); padding-bottom: var(--space-2); border-bottom: 1px solid var(--color-gray-100); }
.widget ul li:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.widget ul li a       { display: block; padding: var(--space-1) 0; color: var(--color-gray-600); text-decoration: none; }
.widget ul li a:hover { color: var(--color-primary); }

.widget--donate {
    background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
    color: var(--color-white);
    border: none;
}
.widget--donate .widget-title { color: var(--color-white); border-bottom-color: rgba(255,255,255,0.2); }


/* ==========================================================================
   Header CTA Button (CCS-style)
   ========================================================================== */

/* ==========================================================================
   Header Language Switcher
   ========================================================================== */

.header-lang {
    flex-shrink: 0;
}

.header-lang__link {
    display: inline-flex;
    align-items: center;
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--header-nav-text);
    text-decoration: none;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    min-height: 44px;
    transition: all var(--transition-fast);
}

.header-lang__link:hover {
    color: var(--header-nav-hover);
    background-color: var(--header-nav-hover-bg);
    border-color: var(--header-nav-hover);
}

.header-lang__link:focus-visible {
    outline: 3px solid #103E5C;
    outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}

/* Utility bar language list */
.utility-lang {
    margin-left: auto;
    flex-shrink: 0;
}

.utility-lang__list {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    list-style: none;
    padding: 0;
    margin: 0;
    font-weight: 600;
}

.utility-lang__list li { margin: 0; padding: 0; }

.utility-lang__list li a {
    display: inline-block;
    color: var(--utilitybar-text);
    text-decoration: none;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
}

.utility-lang__list li a:hover { background-color: rgba(255,255,255,0.15); }

.utility-lang__list li.current-lang a {
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.utility-lang__list li + li::before {
    content: '|';
    color: rgba(255,255,255,0.4);
    margin-right: var(--space-1);
}

/* Language switcher shortcode [neads_lang_switcher] */
.neads-lang-switch {
    display: inline-flex;
    gap: var(--space-2);
    align-items: center;
}

.neads-lang-switch__link {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-sm);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius-sm);
    min-height: 44px;
    line-height: 44px;
}

.neads-lang-switch--inline .neads-lang-switch__link {
    color: var(--body-link);
}

.neads-lang-switch--inline .neads-lang-switch__link.is-current {
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.neads-lang-switch--buttons .neads-lang-switch__link {
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-4);
}

.neads-lang-switch--buttons .neads-lang-switch__link.is-current {
    background: var(--color-primary);
    color: var(--color-white);
}

.neads-lang-switch--buttons .neads-lang-switch__link:hover {
    background: var(--color-primary);
    color: var(--color-white);
}


/* ==========================================================================
   Header CTA Button (CCS-style)
   ========================================================================== */

.header-donate-btn {
    display: inline-flex;
    align-items: center;
    padding: var(--space-2) var(--space-5);
    background-color: var(--header-cta-bg);
    color: var(--header-cta-text);
    font-weight: 700;
    font-size: var(--text-sm);
    text-decoration: none;
    border-radius: var(--radius-md);
    min-height: 44px;
    transition: background-color var(--transition-fast);
    white-space: nowrap;
    flex-shrink: 0;
}

.header-donate-btn:hover {
    background-color: var(--color-accent-dark);
    color: var(--color-white);
}

.header-donate-btn:focus-visible {
    outline: 3px solid #103E5C;
    outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}


/* ==========================================================================
   Page Hero Banner (compact, for sidebar + hero templates)
   ========================================================================== */

.page-hero-banner {
    background: linear-gradient(var(--pageheader-gradient-angle, 135deg), var(--pageheader-bg-start, var(--color-primary-dark)) 0%, var(--pageheader-bg-end, var(--color-primary)) 100%);
    color: var(--pageheader-text, #FFFFFF);
    position: relative;
    overflow: hidden;
}

.page-hero-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='1' fill='rgba(255,255,255,0.05)'/%3E%3C/svg%3E") repeat;
    background-size: 30px 30px;
    pointer-events: none;
}

.page-hero-banner__inner {
    position: relative;
    z-index: 1;
    padding: var(--space-10) 0;
}

/* Widget styling inside the hero banner */
.page-hero-widget {
    color: inherit;
}

.page-hero-widget__title {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: inherit;
    margin: 0 0 var(--space-4);
}

.page-hero-widget p {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: rgba(255, 255, 255, 0.9);
    max-width: 700px;
    margin-bottom: var(--space-4);
}

.page-hero-widget p:last-child {
    margin-bottom: 0;
}

.page-hero-widget a {
    color: #FFFFFF;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.page-hero-widget a:hover {
    color: rgba(255, 255, 255, 0.8);
}

.page-hero-widget img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
}

.page-hero-widget + .page-hero-widget {
    margin-top: var(--space-6);
}

/* Buttons inside hero banner */
.page-hero-widget .btn,
.page-hero-widget .wp-block-button__link {
    display: inline-flex;
    margin-top: var(--space-3);
}

@media (max-width: 768px) {
    .page-hero-banner__inner {
        padding: var(--space-6) 0;
    }
    .page-hero-widget__title {
        font-size: var(--text-2xl);
    }
}


/* ==========================================================================
   Page Header (inside <main>)
   ========================================================================== */

.page-header {
    background: var(--pageheader-bg, linear-gradient(var(--pageheader-gradient-angle, 135deg), var(--pageheader-bg-start) 0%, var(--pageheader-bg-end) 100%));
    color: var(--pageheader-text);
    padding: var(--space-8) var(--space-6);
    margin-bottom: var(--space-8);
    border-radius: var(--pageheader-radius, 12px);
    border: var(--pageheader-border-color, transparent) 1px solid;
    position: relative;
    overflow: hidden;
}

/* Subtle decorative pattern overlay */
.page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='1' fill='rgba(255,255,255,0.05)'/%3E%3C/svg%3E") repeat;
    background-size: 30px 30px;
    pointer-events: none;
}

.page-header__inner {
    position: relative;
    z-index: 1;
}

.page-header__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, var(--text-4xl));
    font-weight: 700;
    color: var(--pageheader-text);
    margin: 0;
    line-height: var(--leading-tight);
}

.page-header__subtitle {
    font-size: var(--text-lg);
    color: var(--pageheader-subtitle);
    margin: var(--space-3) 0 0;
    max-width: 640px;
    line-height: var(--leading-normal);
}

/* Breadcrumbs inside page header — light on dark */
.page-header .breadcrumbs {
    padding: 0 0 var(--space-3);
}

.page-header .breadcrumbs__item a {
    color: rgba(255, 255, 255, 0.8);
}

.page-header .breadcrumbs__item a:hover {
    color: var(--color-white);
}

.page-header .breadcrumbs__item[aria-current="page"] {
    color: rgba(255, 255, 255, 0.95);
}

.page-header .breadcrumbs__sep {
    color: rgba(255, 255, 255, 0.5);
}


/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.breadcrumbs {
    padding: var(--space-4) 0 var(--space-2);
    font-size: var(--text-sm);
    color: var(--color-gray-400);
}

.breadcrumbs__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-1);
}

.breadcrumbs__item { margin: 0; padding: 0; }

.breadcrumbs__item a {
    color: var(--color-primary-light);
    text-decoration: none;
}

.breadcrumbs__item a:hover { text-decoration: underline; }

.breadcrumbs__item[aria-current="page"] {
    color: var(--color-gray-500);
    font-weight: 500;
}

.breadcrumbs__sep {
    color: var(--color-gray-300);
    margin: 0 var(--space-1);
    padding: 0;
}


/* ==========================================================================
   Posts / Articles
   ========================================================================== */

.hentry {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: var(--border-thin);
    margin-bottom: var(--space-8);
}

.entry-header  { padding: var(--space-8) var(--space-8) 0; }
.entry-content { padding: var(--space-6) var(--space-8) var(--space-8); }
.entry-footer  { padding: 0 var(--space-8) var(--space-8); font-size: var(--text-sm); color: var(--color-gray-400); }

.entry-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    font-size: var(--text-sm);
    color: var(--color-gray-400);
    margin-bottom: var(--space-3);
}

.entry-title { font-size: var(--text-3xl); }
.entry-title a { color: var(--color-gray-900); text-decoration: none; }
.entry-title a:hover { color: var(--color-primary); }

.entry-thumbnail { margin-bottom: var(--space-6); }
.entry-thumbnail img { width: 100%; height: auto; border-radius: var(--radius-md); }
.entry-thumbnail figcaption { font-size: var(--text-sm); color: var(--color-gray-400); text-align: center; margin-top: var(--space-2); }

.single-post .entry-content,
.page .entry-content {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
}

.entry-content h2 { margin-top: var(--space-10); }
.entry-content h3 { margin-top: var(--space-8); }
.entry-content img { border-radius: var(--radius-md); margin: var(--space-6) 0; }

.cat-links, .tags-links { display: block; margin-bottom: var(--space-2); }

/* Post Navigation */
.post-navigation {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    margin-top: var(--space-10);
    padding-top: var(--space-8);
    border-top: var(--border-thin);
}

.post-navigation a {
    display: block;
    padding: var(--space-4);
    background: var(--color-gray-50);
    border-radius: var(--radius-md);
    text-decoration: none;
}

.post-navigation a:hover { background-color: var(--color-primary-lightest); }

.nav-subtitle { font-size: var(--text-sm); color: var(--color-gray-400); display: block; margin-bottom: var(--space-1); }
.nav-title    { font-weight: 600; color: var(--body-text); }

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-8) 0;
}

.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    text-decoration: none;
    font-weight: 600;
    color: var(--header-nav-text);
    border: var(--border-thin);
}

.pagination .page-numbers:hover {
    background-color: var(--color-primary-lightest);
    border-color: var(--color-primary-light);
    color: var(--header-text);
}

.pagination .page-numbers.current {
    background-color: var(--header-text);
    border-color: var(--header-text);
    color: var(--color-white);
}


/* ==========================================================================
   Video Page
   ========================================================================== */

.video-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-8);
}

.video-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: var(--border-thin);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.video-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.video-card-thumb {
    position: relative;
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--color-gray-900);
}

.video-card-thumb img { width: 100%; height: 100%; object-fit: cover; }

.video-card-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--color-gray-600), var(--color-gray-700));
}

.play-icon {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.3);
    color: var(--color-white);
    transition: background-color var(--transition-fast);
}

.video-card:hover .play-icon { background: rgba(0,0,0,0.5); }

.video-card-body  { padding: var(--space-5); }
.video-card-title { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2); }
.video-card-title a { color: var(--color-gray-900); text-decoration: none; }
.video-card-title a:hover { color: var(--color-primary); }
.video-card-date  { font-size: var(--text-sm); color: var(--color-gray-400); }
.video-page-intro { margin-bottom: var(--space-8); }


/* ==========================================================================
   Comments
   ========================================================================== */

.comments-area {
    margin-top: var(--space-10);
    padding: var(--space-8);
    background: var(--color-white);
    border-radius: var(--radius-lg);
    border: var(--border-thin);
}

.comments-title { margin-bottom: var(--space-6); }
.comment-list   { list-style: none; padding: 0; }
.comment        { padding: var(--space-6) 0; border-bottom: var(--border-thin); }
.comment:last-child { border-bottom: none; }

.comment-reply-title { font-size: var(--text-2xl); margin-bottom: var(--space-4); }
.no-comments { font-style: italic; color: var(--color-gray-400); }

.comment-form label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--space-2);
    color: var(--body-text);
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--body-text);
    margin-bottom: var(--space-4);
}

.comment-form input:focus,
.comment-form textarea:focus {
    border-color: #103E5C;
    outline: 3px solid #103E5C; outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}

.comment-form .submit {
    display: inline-block;
    padding: var(--space-3) var(--space-6);
    background: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    font-weight: 600;
    cursor: pointer;
    min-height: 44px;
}

.comment-form .submit:hover { background: var(--color-primary-dark); }


/* ==========================================================================
   Search Form
   ========================================================================== */

.search-form {
    display: flex;
    gap: var(--space-2);
}

.search-field {
    flex: 1;
    padding: var(--space-3) var(--space-4);
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-family: var(--font-body);
}

.search-field:focus {
    border-color: #103E5C;
    outline: 3px solid #103E5C; outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}

.search-submit {
    padding: var(--space-3) var(--space-6);
    background: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    font-weight: 600;
    cursor: pointer;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.search-submit:hover { background: var(--color-primary-dark); }

.search-results-count { color: var(--color-gray-400); margin-bottom: var(--space-6); }


/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
    background: var(--footer-bg);
    color: var(--footer-text);
    padding: var(--space-16) 0 0;
}

.footer-widgets {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-10);
    margin-bottom: var(--space-12);
}

.footer-widgets .widget      { background: transparent; border: none; box-shadow: none; padding: 0; }
.footer-widgets .widget-title { color: var(--color-white); font-size: var(--text-base); text-transform: uppercase; letter-spacing: 0.05em; border-bottom-color: var(--color-gray-600); }
.footer-widgets .widget ul li { border-bottom-color: var(--body-text); }
.footer-widgets .widget ul li a { color: var(--color-gray-300); }
.footer-widgets .widget ul li a:hover { color: var(--color-white); }

.footer-funding {
    font-size: var(--text-sm);
    color: var(--color-gray-300);
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6) var(--space-8);
    line-height: var(--leading-relaxed);
}


/* ==========================================================================
   Social Links
   ========================================================================== */

.social-links {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6) var(--space-8);
}

.social-links__list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    list-style: none;
    padding: 0;
    margin: 0;
}

.social-links__list li {
    margin: 0;
    padding: 0;
}

.social-links__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    text-decoration: none;
    min-height: 44px;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

/* Footer variant — light icons on dark bg */
.social-links--footer .social-links__link {
    color: var(--color-gray-300);
}

.social-links--footer .social-links__link:hover {
    color: var(--color-white);
    background-color: rgba(255, 255, 255, 0.1);
}

.social-links--footer .social-links__label {
    font-size: var(--text-sm);
    font-weight: 500;
}

/* Header variant — compact, icons only by default */
.social-links--header .social-links__link {
    color: var(--header-nav-text);
    padding: var(--space-2);
}

.social-links--header .social-links__link:hover {
    color: var(--header-nav-hover);
    background-color: var(--header-nav-hover-bg);
}

.social-links--header .social-links__label {
    position: absolute;
    width: 1px;
    height: 1px;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    overflow: hidden;
}

/* Inline variant — dark icons on light bg */
.social-links--inline .social-links__link {
    color: var(--color-primary);
}

.social-links--inline .social-links__link:hover {
    color: var(--color-primary-dark);
    background-color: var(--color-primary-lightest);
}

.social-links--inline .social-links__label {
    font-size: var(--text-sm);
    font-weight: 500;
}

/* Icons-only style */
.social-links--icons .social-links__label {
    position: absolute;
    width: 1px;
    height: 1px;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    overflow: hidden;
}

/* Text-only style */
.social-links--text svg {
    display: none;
}

/* Both (default) — shows icon + text */
.social-links--both .social-links__label {
    font-size: var(--text-sm);
    font-weight: 500;
}

.social-links__link:focus-visible {
    outline: 3px solid #103E5C;
    outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}


.footer-bottom {
    border-top: 1px solid var(--color-gray-700);
    padding: var(--space-6);
}

.footer-bottom__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-3);
    font-size: var(--text-sm);
    color: var(--color-gray-300);
}

.footer-bottom a       { color: var(--color-gray-300); }
.footer-bottom a:hover { color: var(--color-white); }


/* ==========================================================================
   404 Page
   ========================================================================== */

.error-404 { padding: var(--space-8) 0; }
.error-404 .page-content { max-width: 720px; }

.error-404-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
    margin-top: var(--space-8);
}

.error-404-col h2 { font-size: var(--text-xl); margin-bottom: var(--space-4); }


/* ==========================================================================
   Screen Reader Text
   ========================================================================== */

.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: var(--color-white);
    clip: auto !important;
    clip-path: none;
    color: var(--color-primary-dark);
    display: block;
    font-size: var(--text-sm);
    font-weight: 600;
    height: auto;
    left: var(--space-2);
    padding: var(--space-3) var(--space-6);
    top: var(--space-2);
    width: auto;
    z-index: 100000;
    box-shadow: var(--shadow-lg);
}


/* ==========================================================================
   Forms
   ========================================================================== */

label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--space-2);
    color: var(--body-text);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="number"],
textarea,
select {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--body-text);
    background: var(--color-white);
    min-height: 44px;
}

input:focus, textarea:focus, select:focus {
    border-color: var(--color-primary-light);
    outline: 3px solid #103E5C; outline-offset: 2px;
    box-shadow: 0 0 0 6px #FFFFFF, 0 0 0 9px #103E5C;
}


/* ==========================================================================
   WCAG 2.2 AA Enhancements
   ========================================================================== */

button, a.btn, input[type="submit"], .pagination .page-numbers, .primary-navigation a {
    min-height: 44px;
}

:focus-visible {
    outline: 3px solid #103E5C;
    outline-offset: 2px;
}

@media (forced-colors: active) {
    .btn, .widget, .card { border: 2px solid ButtonText; }
    .hero, .page-header-banner, .cta-banner { border: 2px solid CanvasText; }
}


/* ==========================================================================
   WordPress Alignment
   ========================================================================== */

.alignleft   { float: left; margin-right: var(--space-6); margin-bottom: var(--space-4); }
.alignright  { float: right; margin-left: var(--space-6); margin-bottom: var(--space-4); }
.aligncenter { display: block; margin-left: auto; margin-right: auto; margin-bottom: var(--space-4); }

.wp-block-image figcaption { font-size: var(--text-sm); color: var(--color-gray-400); text-align: center; margin-top: var(--space-2); }


/* ==========================================================================
   Landing Page Template
   ========================================================================== */

.landing-page-body .site-header-landing {
    position: relative;
    background: var(--color-white);
    box-shadow: var(--shadow-sm);
    padding: 0.75rem 0;
}

.landing-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-6);
}

.landing-back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--header-text);
    text-decoration: none;
    font-size: var(--text-sm);
    font-weight: 600;
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
}

.landing-back-link:hover { background: var(--color-gray-100); }

.landing-hero {
    background-size: cover;
    background-position: center;
    background-color: var(--header-text);
    min-height: 320px;
    display: flex;
    align-items: center;
}

.landing-hero-overlay {
    width: 100%;
    background: rgba(27, 79, 124, 0.8);
    padding: var(--space-16) 0;
}

.landing-hero-plain {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    padding: var(--space-16) 0;
}

.landing-hero-title {
    color: var(--color-white);
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 3rem);
    margin: 0;
    max-width: 720px;
}

.landing-body       { padding: var(--space-12) 0 var(--space-16); }
.site-footer-landing { background: var(--color-gray-100); padding: var(--space-6) 0; text-align: center; }
.landing-footer-text { margin: 0; color: var(--color-gray-500); font-size: var(--text-sm); }


/* ==========================================================================
   Narrow Content Template
   ========================================================================== */

.narrow-content .entry-content.prose {
    font-size: var(--text-lg);
    line-height: 1.8;
}

.narrow-content .entry-content.prose p { margin-bottom: 1.5em; }
.narrow-meta { text-align: center; margin-bottom: var(--space-8); color: var(--color-gray-400); }

.narrow-thumbnail {
    margin: 0 calc(-1 * var(--space-6)) var(--space-10);
}

.narrow-thumbnail img { width: 100%; height: auto; border-radius: var(--radius-lg); }
.narrow-thumbnail figcaption { text-align: center; font-size: var(--text-sm); color: var(--color-gray-400); margin-top: var(--space-2); }


/* ==========================================================================
   Contact Template
   ========================================================================== */

.contact-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-12);
    padding: var(--space-8) 0 var(--space-12);
}

.contact-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.contact-detail-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-6);
}

.contact-detail-card h2 {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-primary-dark);
    margin: 0 0 var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--color-gray-100);
}

.contact-detail-item {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-3) 0;
}

.contact-detail-item + .contact-detail-item { border-top: 1px solid var(--color-gray-100); }
.contact-detail-item svg { flex-shrink: 0; color: var(--color-primary); margin-top: 0.2rem; }
.contact-detail-item strong { display: block; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--color-gray-400); margin-bottom: 0.125rem; }
.contact-detail-item p { margin: 0; line-height: 1.5; }
.contact-detail-item a { color: var(--color-primary); text-decoration: none; }
.contact-detail-item a:hover { text-decoration: underline; }


/* ==========================================================================
   Two-Column Sections Template
   ========================================================================== */

.two-col-sections .two-col-row { padding: var(--space-12) 0; }
.two-col-sections .two-col-row:nth-child(even) { background: var(--color-gray-50); }

.two-col-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}

.two-col-reverse .two-col-inner > *:first-child { order: 2; }
.two-col-reverse .two-col-inner > *:last-child  { order: 1; }
.two-col-inner img { width: 100%; height: auto; border-radius: var(--radius-lg); }
.two-col-inner .wp-block-media-text { grid-column: 1 / -1; }


/* ==========================================================================
   Archive Grid Template
   ========================================================================== */

.archive-grid-intro { max-width: 780px; margin-bottom: var(--space-8); }
.archive-grid-page .card-grid { margin-top: var(--space-4); }


/* ==========================================================================
   FAQ / Accordion Template
   ========================================================================== */

.faq-intro     { margin-bottom: var(--space-8); }
.faq-controls  { display: flex; gap: var(--space-3); margin-bottom: var(--space-6); }

.accordion {
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.accordion-item + .accordion-item { border-top: 1px solid var(--color-gray-200); }
.accordion-heading { margin: 0; font-size: var(--text-base); }

.accordion-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--space-4) var(--space-5);
    border: none;
    background: var(--color-white);
    cursor: pointer;
    text-align: left;
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-primary-dark);
    min-height: 44px;
    transition: background var(--transition-fast);
}

.accordion-trigger:hover { background: var(--color-gray-50); }
.accordion-trigger[aria-expanded="true"] { background: var(--color-gray-50); }

.accordion-icon { flex-shrink: 0; transition: transform 0.25s ease; }
.accordion-trigger[aria-expanded="true"] .accordion-icon { transform: rotate(180deg); }

.accordion-body { padding: 0 var(--space-5) var(--space-5); }
.accordion-body p:first-child { margin-top: var(--space-2); }
.accordion-body p:last-child  { margin-bottom: 0; }

@media (prefers-reduced-motion: no-preference) {
    .accordion-panel[hidden] {
        display: block !important;
        max-height: 0;
        overflow: hidden;
        visibility: hidden;
        transition: max-height 0.3s ease, visibility 0s 0.3s;
    }
    .accordion-panel:not([hidden]) {
        max-height: 2000px;
        visibility: visible;
        transition: max-height 0.4s ease, visibility 0s 0s;
    }
}


/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1024px) {
    .footer-widgets       { grid-template-columns: repeat(2, 1fr); }
    
    .hero__stats           { grid-template-columns: repeat(2, 1fr); }
    .hero__stats--bar      { flex-wrap: wrap; }
    .card-grid-3          { grid-template-columns: repeat(2, 1fr); }
    
}

@media (max-width: 768px) {
    :root {
        --text-4xl: 1.875rem;
        --text-5xl: 2.25rem;
    }

    .utility-bar__inner { justify-content: center; text-align: center; }

    /* Mobile nav */
    .menu-toggle { display: flex; align-items: center; gap: var(--space-2); }

    .primary-navigation ul {
        display: none;
        flex-direction: column;
        position: absolute;
        top: 100%;
        right: 0;
        left: 0;
        background: var(--color-white);
        border-top: var(--border-thin);
        box-shadow: var(--shadow-lg);
        padding: var(--space-4);
        z-index: 999;
    }

    .primary-navigation.toggled ul { display: flex; }

    .primary-navigation .sub-menu {
        position: static;
        box-shadow: none;
        border: none;
        padding-left: var(--space-4);
        display: none;
    }

    .primary-navigation li.submenu-open > .sub-menu { display: flex; }

    /* Sidebar stacking */
    .layout-sidebar-right,
    .layout-sidebar-left {
        grid-template-columns: 1fr;
    }

    .footer-widgets { grid-template-columns: 1fr; }
    .footer-bottom__inner { flex-direction: column; text-align: center; }

    .hero { padding: var(--space-12) var(--space-6); }
    .hero__stats { grid-template-columns: 1fr 1fr; gap: var(--space-4); }
    .hero__stats--bar { flex-wrap: wrap; }
    .hero__stats--bar .stat-item { flex: 0 0 50%; }
    .hero--2-col .hero__grid { grid-template-columns: 1fr; }

    .card-grid-3 { grid-template-columns: 1fr; }
    

    .post-navigation { grid-template-columns: 1fr; }

    .contact-layout { grid-template-columns: 1fr; gap: var(--space-8); }

    .two-col-inner {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
    .two-col-reverse .two-col-inner > * { order: unset; }

    .error-404-columns { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .hero__stats { grid-template-columns: 1fr; }
    .hero__stats--bar .stat-item { flex: 0 0 100%; }
    .hero__stats--bar .stat-item + .stat-item::before {
        left: 20%; top: 0; width: 60%; height: 1px;
    }
    .hero-buttons { flex-direction: column; }
    .hero-buttons .btn { width: 100%; justify-content: center; }
    .cta-buttons { flex-direction: column; align-items: center; }
    .site-header__inner { padding: var(--space-3) var(--space-4); }
}


/* ==========================================================================
   Dark Mode (respects OS / browser prefers-color-scheme)
   ========================================================================== */

@media (prefers-color-scheme: dark) {
    :root {
        /* Neutral palette — inverted */
        --color-white: #121826;
        --color-gray-50: #0F1219;
        --color-gray-100: #1A2030;
        --color-gray-200: #5F7290;
        --color-gray-300: #94A3B8;
        --color-gray-400: #94A3B8;
        --color-gray-500: #CBD5E1;
        --color-gray-600: #E2E8F0;
        --color-gray-700: #E2E8F0;
        --color-gray-900: #F1F5F9;

        /* Primary — lighter for dark backgrounds */
        --color-primary: #5BA3D9;
        --color-primary-dark: #93C5FD;
        --color-primary-light: #5BA3D9;
        --color-primary-lightest: rgba(91, 163, 217, 0.15);

        /* Accent — lighter for readability */
        --color-accent: #E8784F;
        --color-accent-dark: #F09070;
        --color-accent-light: rgba(232, 120, 79, 0.2);
        --color-accent-bg: #E8784F;
        --color-accent-bg-dark: #D4572A;

        /* Header */
        --header-bg: #121826;
        --header-text: #93C5FD;
        --header-nav-text: #CBD5E1;
        --header-nav-hover: #93C5FD;
        --header-nav-hover-bg: rgba(91, 163, 217, 0.12);
        --header-cta-bg: #E8784F;
        --header-cta-text: #121826;
        --header-border: #5F7290;

        /* Utility bar */
        --utilitybar-bg: #0A0E17;
        --utilitybar-text: #E2E8F0;
        --utilitybar-border: #E8784F;

        /* Page header */
        --pageheader-bg-start: #0F1219;
        --pageheader-bg-end: #1A2535;
        --pageheader-text: #F1F5F9;
        --pageheader-subtitle: #94A3B8;

        /* Body */
        --body-bg: #0F1219;
        --body-text: #E2E8F0;
        --body-heading: #F1F5F9;
        --body-link: #5BA3D9;
        --body-link-hover: #93C5FD;
        --content-bg: #1E2536;
        --content-border: #5F7290;

        /* Widgets */
        --widget-bg: #1E2536;
        --widget-border: #5F7290;
        --widget-title-color: #93C5FD;
        --widget-title-border: rgba(91, 163, 217, 0.2);
        --widget-link: #CBD5E1;
        --widget-link-hover: #93C5FD;

        /* Buttons */
        --btn-primary-bg: #E8784F;
        --btn-primary-text: #121826;
        --btn-primary-hover-bg: #F09070;
        --btn-outline-color: #5BA3D9;
        --btn-outline-hover-bg: #5BA3D9;
        --btn-outline-hover-text: #121826;

        /* Cards */
        --card-bg: #1E2536;
        --card-border: #5F7290;
        --card-title: #F1F5F9;
        --card-text: #CBD5E1;
        --card-meta: #94A3B8;
        --card-link: #5BA3D9;

        /* Hero */
        --hero-bg-start: #0A0E17;
        --hero-bg-end: #1A2535;
        --hero-text: #F1F5F9;

        /* Footer */
        --footer-bg: #0A0E17;
        --footer-text: #94A3B8;
        --footer-heading: #F1F5F9;
        --footer-link: #94A3B8;
        --footer-link-hover: #F1F5F9;
        --footer-border: #1A2030;
        --footer-bottom-bg: #0A0E17;
        --footer-bottom-border: #1A2030;

        /* Shadows — stronger in dark mode */
        --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
        --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
        --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);

        /* Border default */
        --border-thin: 1px solid #5F7290;

        /* Focus ring — white inner on dark, light outer */
        --focus-ring: 0 0 0 3px #93C5FD, 0 0 0 6px #121826;
    }

    /* Fix double focus ring for dark mode */
    a:focus-visible,
    button:focus-visible,
    input:focus-visible,
    select:focus-visible,
    textarea:focus-visible,
    [tabindex]:focus-visible {
        outline-color: #93C5FD;
        box-shadow: 0 0 0 6px #121826, 0 0 0 9px #93C5FD;
    }

    /* Body background */
    body {
        background-color: #0F1219;
        color: #E2E8F0;
    }

    /* Images — slight reduction to avoid blinding on dark bg */
    img {
        opacity: 0.92;
    }

    img:hover {
        opacity: 1;
    }

    /* Inputs */
    input, textarea, select {
        background-color: #1A2030;
        border-color: #5F7290;
        color: #E2E8F0;
    }

    /* Hero overlay adjustments */
    .hero__overlay {
        background: linear-gradient(var(--hero-gradient-angle, 135deg), #0A0E17 0%, #121826 40%, #1A2535 100%);
    }

    .hero::before {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='1.5' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
    }

    /* Stat items */
    .stat-item,
    .hero__stats--cards .stat-item {
        background: rgba(255, 255, 255, 0.06);
        border-color: rgba(255, 255, 255, 0.1);
    }

    .hero__stats--bar {
        background: rgba(255, 255, 255, 0.06);
        border-color: rgba(255, 255, 255, 0.1);
    }

    .hero__stats--bar .stat-item + .stat-item::before {
        background: rgba(255, 255, 255, 0.1);
    }

    /* Page header */
    .page-header {
        border-color: #5F7290;
    }

    .page-header::before {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Ccircle cx='40' cy='40' r='1' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
    }

    /* Page hero banner */
    .page-hero-banner {
        background: linear-gradient(var(--pageheader-gradient-angle, 135deg), #0A0E17 0%, #1A2535 100%);
    }

    /* Cards and widgets — dark surfaces */
    .card,
    .widget,
    .hentry {
        background: #1E2536;
        border-color: #5F7290;
    }

    /* Table headers */
    th {
        background-color: #1A2535;
    }

    /* Blockquotes */
    blockquote {
        background: rgba(91, 163, 217, 0.1);
        border-left-color: #5BA3D9;
    }

    /* Code blocks */
    code {
        background: #1A2030;
    }

    pre {
        background: #0A0E17;
        color: #E2E8F0;
    }

    /* Standalone utility bar */
    .neads-lang-bar {
        background-color: #0A0E17;
        border-bottom-color: #E8784F;
    }

    /* CTA banner dark mode */
    .cta-banner {
        background: linear-gradient(135deg, #1A2030, #5F7290);
    }

    /* Homepage sections */
    .home-section--white { background-color: #121826; }
    .home-section--light { background-color: #0F1219; }
    .home-section--primary {
        background: linear-gradient(135deg, #0A0E17, #1A2535);
    }
    .home-section--dark {
        background-color: #0A0E17;
    }

    /* Accordion */
    .accordion {
        border-color: #5F7290;
    }

    .accordion-item + .accordion-item {
        border-top-color: #5F7290;
    }

    .accordion-trigger {
        background: #1E2536;
        color: #93C5FD;
    }

    .accordion-trigger:hover,
    .accordion-trigger[aria-expanded="true"] {
        background: #141B2B;
        box-shadow: inset 3px 0 0 #5BA3D9;
    }

    /* Social links footer */
    .social-links--footer .social-links__link {
        color: #94A3B8;
    }

    .social-links--footer .social-links__link:hover {
        color: #F1F5F9;
        background-color: rgba(255, 255, 255, 0.08);
    }

    /* Search form */
    .search-field {
        background-color: #1A2030;
        border-color: #5F7290;
        color: #E2E8F0;
    }

    /* Comments */
    .comments-area {
        background: #1E2536;
        border-color: #5F7290;
    }

    .comment {
        border-bottom-color: #5F7290;
    }

    /* Pagination */
    .pagination .page-numbers {
        border-color: #5F7290;
        color: #CBD5E1;
    }

    .pagination .page-numbers:hover {
        background-color: rgba(91, 163, 217, 0.12);
        border-color: #5BA3D9;
        color: #93C5FD;
    }

    .pagination .page-numbers.current {
        background-color: #5BA3D9;
        border-color: #5BA3D9;
        color: #121826;
    }

    /* Dropdown menus */
    .primary-navigation .sub-menu {
        background: #1E2536;
        border-color: #5F7290;
    }

    /* Contact detail cards */
    .contact-detail-card {
        background: #1E2536;
        border-color: #5F7290;
    }

    .contact-detail-card h2 {
        border-bottom-color: #5F7290;
    }

    .contact-detail-item + .contact-detail-item {
        border-top-color: #5F7290;
    }

    /* Error 404 */
    .error-404-col h2 {
        color: #F1F5F9;
    }

    /* Video cards */
    .video-card {
        background: #1E2536;
        border-color: #5F7290;
    }

    /* Forced colors still takes precedence */
}


/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    .utility-bar, .site-header, .site-footer, .sidebar, .menu-toggle,
    .hero__stats, .cta-banner, .post-navigation, .comments-area, .pagination {
        display: none !important;
    }
    body { color: #000; background: #fff; font-size: 12pt; }
    a    { color: #000; text-decoration: underline; }
    .container { max-width: 100%; padding: 0; }
    .hentry    { box-shadow: none; border: none; }
}
