/**
 * WessForum Theme v1.0 — CSS custom property overrides
 *
 * Water-sector blue-green palette via hyper-parameter overrides.
 * No !important, no tag selectors, only --ui-* / --hp-* tokens.
 */

/* Teal-green water palette — clean, professional, environmental */
:root {
    --hp-hue-1: 200;
    --hp-sat-1: 80;
    --hp-hue-2: 165;
    --hp-sat-2: 60;
    --hp-hue-accent: 35;          /* warm amber — calls to action */

    /* Shape & rhythm */
    --hp-corner-scale: 1.0;
    --hp-density: 0.95;
    --hp-text-scale: 1.02;
    --hp-shadow-intensity: 0.08;
    --hp-shadow-blur: 1.4;
    --hp-style-weight: 0.55;
    --hp-range: 0.85;
    --hp-transition-speed: 1.0;
    --hp-neutral-warmth: 4;
    --hp-surface-tint: 0.8;
}

/* Typography */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Poppins:wght@500;600;700&display=swap');

.wessforum-app {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ─── Stage breathing room ─── */
.wessforum-app .ui-pageframe-stage {
    padding: var(--ui-space-5) var(--ui-space-6);
    background: color-mix(in srgb, var(--ui-primary-50) 10%, var(--ui-white));
}

/* ─── Section headers ─── */
.wf-section-title {
    font-family: 'Poppins', sans-serif;
    font-size: var(--ui-text-lg);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-800);
    margin-bottom: var(--ui-space-3);
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
}

.wf-section-title i {
    color: var(--ui-primary);
    font-size: var(--ui-text-base);
}

/* ─── Card grid ─── */
.wf-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--ui-space-4);
}

/* ─── Content cards ─── */
.wf-card {
    background: var(--ui-white);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-lg);
    box-shadow: var(--ui-shadow-sm);
    padding: var(--ui-space-4);
    transition: box-shadow 0.2s, transform 0.2s;
}

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

.wf-clickable {
    cursor: pointer;
}

.wf-card-header {
    display: flex;
    align-items: flex-start;
    gap: var(--ui-space-3);
    margin-bottom: var(--ui-space-3);
}

.wf-card-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--ui-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: var(--ui-text-lg);
    color: var(--ui-white);
    background: var(--ui-primary);
}

.wf-card-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-base);
    color: var(--ui-gray-800);
    line-height: 1.3;
}

.wf-card-meta {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    margin-top: var(--ui-space-1);
}

.wf-card-body {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    line-height: 1.6;
}

/* ─── Badge / chip ─── */
.wf-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: var(--ui-radius-full);
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-medium);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.wf-badge-primary {
    background: color-mix(in srgb, var(--ui-primary) 12%, transparent);
    color: var(--ui-primary-700);
}

.wf-badge-success {
    background: color-mix(in srgb, var(--ui-secondary) 12%, transparent);
    color: hsl(var(--hp-hue-2), var(--hp-sat-2)%, 30%);
}

.wf-badge-warning {
    background: color-mix(in srgb, var(--ui-accent) 12%, transparent);
    color: hsl(var(--hp-hue-accent), 80%, 30%);
}

.wf-badge-danger {
    background: color-mix(in srgb, #ef4444 12%, transparent);
    color: #991b1b;
}

/* ─── Stats strip ─── */
.wf-stats-strip {
    display: flex;
    gap: var(--ui-space-3);
    flex-wrap: wrap;
    padding: var(--ui-space-3) 0;
}

.wf-stat {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    padding: var(--ui-space-2) var(--ui-space-3);
    background: var(--ui-white);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-md);
    box-shadow: var(--ui-shadow-sm);
}

.wf-stat-value {
    font-family: 'Poppins', sans-serif;
    font-size: var(--ui-text-xl);
    font-weight: var(--ui-font-bold);
    color: var(--ui-primary);
}

.wf-stat-label {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* ─── Home layout ─── */
.wf-home-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-5);
}

/* ─── Map container ─── */
.wf-map-container {
    width: 100%;
    height: 450px;
    border-radius: var(--ui-radius-lg);
    border: 1px solid var(--ui-gray-200);
    box-shadow: var(--ui-shadow-md);
    overflow: hidden;
    z-index: 1;
}

.wf-map-fallback {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--ui-gray-400);
    gap: var(--ui-space-2);
}

.wf-map-fallback i { font-size: 3rem; }

/* Deployment marker dot */
.wf-marker {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--ui-white);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* Legend overlay */
.wf-map-legend {
    background: var(--ui-white);
    border-radius: var(--ui-radius-md);
    box-shadow: var(--ui-shadow-md);
    padding: var(--ui-space-2) var(--ui-space-3);
    font-size: var(--ui-text-xs);
    line-height: 1.8;
}

.wf-legend-title {
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-700);
    margin-bottom: var(--ui-space-1);
    font-size: var(--ui-text-2xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.wf-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--ui-gray-600);
}

.wf-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* Card list items */
.wf-card-item {
    padding: var(--ui-space-2) 0;
    border-bottom: 1px solid var(--ui-gray-100);
}

.wf-card-item:last-child { border-bottom: none; }

.wf-card-item-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
}

.wf-card-item-meta {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    margin-top: 2px;
}

/* Provider detail sections */
.wf-provider-section {
    margin-top: var(--ui-space-5);
    padding-top: var(--ui-space-4);
    border-top: 1px solid var(--ui-gray-100);
}

/* ─── Timeline (governance) ─── */
.wf-timeline {
    position: relative;
    padding-left: var(--ui-space-6);
}

.wf-timeline::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--ui-gray-200);
}

.wf-timeline-item {
    position: relative;
    padding-bottom: var(--ui-space-4);
}

.wf-timeline-item::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--ui-space-6) + 8px);
    top: 4px;
    width: 10px;
    height: 10px;
    border-radius: var(--ui-radius-full);
    background: var(--ui-primary);
    border: 2px solid var(--ui-white);
    box-shadow: var(--ui-shadow-sm);
}

/* ─── Empty state ─── */
.wf-empty-state {
    text-align: center;
    padding: var(--ui-space-8);
    color: var(--ui-gray-400);
}

.wf-empty-state i {
    font-size: 3rem;
    margin-bottom: var(--ui-space-3);
    display: block;
}

/* ─── Deadline countdown ─── */
.wf-deadline {
    font-size: var(--ui-text-xs);
    font-weight: var(--ui-font-semibold);
    padding: 2px 8px;
    border-radius: var(--ui-radius-sm);
}

.wf-deadline-urgent {
    background: color-mix(in srgb, #ef4444 15%, transparent);
    color: #991b1b;
}

.wf-deadline-soon {
    background: color-mix(in srgb, #f59e0b 15%, transparent);
    color: #92400e;
}

.wf-deadline-normal {
    background: color-mix(in srgb, var(--ui-primary) 12%, transparent);
    color: var(--ui-primary-700);
}

/* ─── Filter controls ─── */
.wf-filter-group {
    padding: var(--ui-space-3);
    border-bottom: 1px solid var(--ui-gray-100);
}

.wf-filter-label {
    display: block;
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--ui-space-2);
}

.wf-filter-select {
    width: 100%;
    padding: var(--ui-space-2);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-md);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-700);
    background: var(--ui-white);
    outline: none;
    transition: border-color 0.15s;
}

.wf-filter-select:focus {
    border-color: var(--ui-primary);
}

/* ─── Domain color tokens ─── */
.wessforum-app {
    /* Technology categories */
    --wf-cat-biological: hsl(165, 70%, 32%);
    --wf-cat-membrane: hsl(191, 88%, 37%);
    --wf-cat-chemical: hsl(263, 70%, 50%);
    --wf-cat-hybrid: hsl(37, 88%, 44%);
    --wf-cat-nature-based: hsl(145, 63%, 40%);
    --wf-cat-mechanical: hsl(239, 84%, 67%);
    --wf-cat-other: var(--ui-gray-500);

    /* Site request statuses */
    --wf-status-open: hsl(165, 70%, 32%);
    --wf-status-shortlisted: hsl(37, 88%, 44%);
    --wf-status-awarded: hsl(191, 88%, 37%);
    --wf-status-closed: var(--ui-gray-500);

    /* Programme types */
    --wf-prog-derisking: hsl(191, 88%, 37%);
    --wf-prog-sensors: hsl(165, 70%, 32%);
    --wf-prog-classification: hsl(263, 70%, 50%);
    --wf-prog-iso-30500: hsl(37, 88%, 44%);
    --wf-prog-field-testing: hsl(350, 83%, 50%);

    /* Opportunity types */
    --wf-type-tender: hsl(350, 83%, 50%);
    --wf-type-rfp: hsl(263, 70%, 50%);
    --wf-type-rfi: hsl(191, 88%, 37%);
    --wf-type-eoi: hsl(165, 70%, 32%);
    --wf-type-grant: hsl(37, 88%, 44%);
    --wf-type-partnership: hsl(239, 84%, 67%);

    /* Governance types */
    --wf-gov-minutes: var(--ui-primary);
    --wf-gov-resolution: hsl(350, 83%, 50%);
    --wf-gov-charter: hsl(165, 70%, 32%);
    --wf-gov-policy: hsl(263, 70%, 50%);
    --wf-gov-report: hsl(37, 88%, 44%);

    /* Article categories */
    --wf-art-company-news: var(--ui-primary);
    --wf-art-sector-update: var(--ui-secondary-600);
    --wf-art-programme: var(--ui-accent-600);
    --wf-art-governance: var(--ui-gray-600);
    --wf-art-engineering: hsl(191, 88%, 37%);
    --wf-art-finance: hsl(37, 88%, 44%);
    --wf-art-tender: hsl(350, 83%, 50%);
    --wf-art-event-report: hsl(263, 70%, 50%);

    /* Semantic danger */
    --wf-danger: hsl(350, 83%, 50%);
}

/* ─── Layout utilities ─── */
.wf-col-stack {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-4);
}

.wf-col-stack-sm {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-2);
}

.wf-col-stack-lg {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-5);
    max-width: 800px;
}

.wf-grid-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ui-space-2);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
}

.wf-accent-border {
    border-left: 3px solid var(--ui-primary);
}

.wf-hidden {
    display: none;
}

.wf-mt-4 { margin-top: var(--ui-space-4); }
.wf-mb-4 { margin-bottom: var(--ui-space-4); }
.wf-mt-3 { margin-top: var(--ui-space-3); }

/* ─── Section subtitle (micro label) ─── */
.wf-section-subtitle {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: var(--ui-space-3) 0;
}

.wf-section-subtitle-spaced {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: var(--ui-space-3) 0;
    margin-top: var(--ui-space-4);
}

/* ─── Bar chart ─── */
.wf-bar-chart-row {
    display: flex;
    align-items: center;
    gap: var(--ui-space-3);
    margin-bottom: var(--ui-space-3);
}

.wf-bar-label {
    width: 100px;
    font-size: var(--ui-text-sm);
    font-weight: var(--ui-font-medium);
    color: var(--ui-gray-700);
    text-align: right;
    flex-shrink: 0;
}

.wf-bar-track {
    flex: 1;
    background: var(--ui-gray-100);
    border-radius: var(--ui-radius-full);
    height: 24px;
    overflow: hidden;
    position: relative;
}

.wf-bar-fill {
    height: 100%;
    border-radius: var(--ui-radius-full);
    transition: width 0.3s ease;
}

.wf-bar-score {
    width: 40px;
    font-size: var(--ui-text-sm);
    font-weight: var(--ui-font-bold);
    text-align: right;
    flex-shrink: 0;
}

/* ─── Breakdown row (finance) ─── */
.wf-breakdown-row {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: var(--ui-space-2);
}

.wf-breakdown-label {
    width: 150px;
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-600);
    flex-shrink: 0;
}

.wf-breakdown-bar {
    flex: 1;
    background: var(--ui-gray-100);
    border-radius: var(--ui-radius-sm);
    height: 20px;
    overflow: hidden;
}

.wf-breakdown-bar-fill {
    height: 100%;
    border-radius: var(--ui-radius-sm);
}

.wf-breakdown-value {
    width: 90px;
    font-size: var(--ui-text-xs);
    font-weight: var(--ui-font-semibold);
    text-align: right;
    flex-shrink: 0;
    color: var(--ui-gray-700);
}

.wf-breakdown-total {
    display: flex;
    justify-content: space-between;
    padding-top: var(--ui-space-2);
    border-top: 1px solid var(--ui-gray-200);
    margin-top: var(--ui-space-2);
    font-size: var(--ui-text-sm);
}

.wf-breakdown-total-label {
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-800);
}

.wf-breakdown-total-value {
    font-weight: var(--ui-font-bold);
    color: var(--ui-primary);
}

/* ─── OPEX bar (thin) ─── */
.wf-opex-row {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: 2px;
}

.wf-opex-year {
    width: 35px;
    font-size: var(--ui-text-2xs);
    color: var(--ui-gray-500);
    text-align: right;
}

.wf-opex-track {
    flex: 1;
    background: var(--ui-gray-100);
    border-radius: var(--ui-radius-sm);
    height: 16px;
    overflow: hidden;
}

.wf-opex-fill {
    background: var(--ui-primary-300);
    height: 100%;
    border-radius: var(--ui-radius-sm);
}

.wf-opex-value {
    width: 80px;
    font-size: var(--ui-text-2xs);
    color: var(--ui-gray-600);
    text-align: right;
}

/* ─── Detail grid (marketplace) ─── */
.wf-detail-header {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: var(--ui-space-3);
}

.wf-detail-icon {
    font-size: var(--ui-text-lg);
}

.wf-detail-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-base);
}

.wf-detail-desc {
    margin-top: var(--ui-space-3);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
}

.wf-detail-contact {
    margin-top: var(--ui-space-2);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
}

/* ─── Count chip (programme sidebar) ─── */
.wf-count-chip {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-600);
}

.wf-count-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.wf-count-value {
    margin-left: auto;
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-800);
}

/* ─── Card section header (finance/suitability) ─── */
.wf-card-header-inline {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    margin-bottom: var(--ui-space-3);
}

.wf-card-header-inline i {
    color: var(--ui-primary);
}

/* ─── Recommendation card ─── */
.wf-recommendation {
    border-left: 3px solid var(--ui-primary);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    line-height: 1.6;
}

/* ─── Factor breakdown ─── */
.wf-factor-item {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    font-size: var(--ui-text-xs);
}

.wf-factor-label {
    color: var(--ui-gray-600);
}

.wf-factor-score {
    font-weight: var(--ui-font-semibold);
}

/* ─── Charter highlight ─── */
.wf-charter-header {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: var(--ui-space-2);
}

.wf-charter-icon {
    color: var(--ui-primary);
    font-size: var(--ui-text-lg);
}

.wf-charter-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-base);
}

.wf-charter-date {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
}

.wf-charter-excerpt {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    margin-top: var(--ui-space-2);
}

/* ─── Timeline item content ─── */
.wf-timeline-header {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: var(--ui-space-1);
}

.wf-timeline-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
}

.wf-timeline-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ui-space-2);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    margin-bottom: var(--ui-space-1);
}

.wf-timeline-excerpt {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-600);
    line-height: 1.5;
}

/* ─── Pending content ─── */
.wf-no-pending {
    padding: var(--ui-space-4);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-500);
}

/* ─── Range input row ─── */
.wf-range-row {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
}

.wf-range-row input[type="range"] {
    flex: 1;
    accent-color: var(--ui-primary);
}

.wf-range-value {
    font-size: var(--ui-text-sm);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-primary);
    min-width: 60px;
    text-align: right;
}

/* ─── HH metrics grid ─── */
.wf-hh-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ui-space-3);
}

.wf-hh-metric {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-600);
}

.wf-hh-value {
    font-weight: var(--ui-font-bold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
}

.wf-hh-value-accent {
    font-weight: var(--ui-font-bold);
    font-size: var(--ui-text-sm);
    color: var(--ui-primary);
}

/* ─── Docs hint ─── */
.wf-docs-hint {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    padding: var(--ui-space-1) 0;
}

.wf-docs-hint i {
    color: var(--ui-primary);
}

/* ─── Payback note ─── */
.wf-payback-note {
    margin-top: var(--ui-space-3);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
}

/* ─── Input tabular nums ─── */
.wf-filter-select.wf-tabular {
    font-variant-numeric: tabular-nums;
}

/* ─── Submit button full width ─── */
.wf-submit-btn {
    width: 100%;
    margin-top: var(--ui-space-3);
}

/* ─── Panel container (tools) ─── */
.wf-panel-container {
    padding: var(--ui-space-4) 0;
}

/* ─── Tools tab navigation area ─── */
.wf-marker-lg {
    width: 18px;
    height: 18px;
    border: 3px solid var(--ui-white);
}

/* ─── Newsletter tab ─── */
.wf-newsletter-wrap {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.wf-newsletter-content {
    flex: 1;
    min-height: 0;
}

.wf-newsletter-content-grid {
    overflow-y: auto;
    padding: var(--ui-space-5) var(--ui-space-6);
}

.wf-newsletter-content-reader {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.wf-newsletter-reader-container {
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.wf-newsletter-banner {
    background: linear-gradient(135deg, hsl(190, 65%, 25%), hsl(190, 65%, 35%));
    padding: var(--ui-space-5) var(--ui-space-6);
    flex-shrink: 0;
}

.wf-newsletter-banner-inner {
    display: flex;
    align-items: center;
    gap: var(--ui-space-4);
}

.wf-newsletter-banner-title {
    font-family: 'Poppins', sans-serif;
    font-size: var(--ui-text-xl);
    font-weight: var(--ui-font-bold);
    color: var(--ui-white);
    margin: 0;
}

.wf-newsletter-banner-title i {
    margin-right: var(--ui-space-2);
    opacity: 0.8;
}

.wf-newsletter-banner-sub {
    font-size: var(--ui-text-sm);
    color: hsla(0, 0%, 100%, 0.75);
    margin: var(--ui-space-1) 0 0;
}

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

.wf-newsletter-card {
    background: var(--ui-white);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-lg);
    box-shadow: var(--ui-shadow-sm);
    padding: var(--ui-space-5);
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.2s, transform 0.2s;
}

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

.wf-newsletter-card-published {
    border-color: var(--ui-primary-200);
    background: linear-gradient(180deg, color-mix(in srgb, var(--ui-primary-50) 40%, var(--ui-white)), var(--ui-white));
}

.wf-newsletter-card-cta {
    border-style: dashed;
    border-color: var(--ui-primary-300);
    background: color-mix(in srgb, var(--ui-primary-50) 20%, var(--ui-white));
}

.wf-nl-card-header {
    display: flex;
    align-items: flex-start;
    gap: var(--ui-space-3);
    margin-bottom: var(--ui-space-3);
}

.wf-nl-issue-num {
    width: 44px;
    height: 44px;
    border-radius: var(--ui-radius-lg);
    background: var(--ui-primary);
    color: var(--ui-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--ui-text-lg);
    flex-shrink: 0;
}

.wf-newsletter-card-cta .wf-nl-issue-num {
    background: hsl(var(--hp-hue-accent), 80%, 48%);
}

.wf-nl-card-meta {
    flex: 1;
    min-width: 0;
}

.wf-nl-card-issue {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.wf-nl-card-title {
    font-family: 'Poppins', sans-serif;
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-base);
    color: var(--ui-gray-800);
    line-height: 1.3;
}

.wf-nl-card-subtitle {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    margin-top: 2px;
}

.wf-nl-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 10px;
    border-radius: var(--ui-radius-full);
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    white-space: nowrap;
    flex-shrink: 0;
}

.wf-nl-badge-published {
    background: color-mix(in srgb, var(--ui-primary) 12%, transparent);
    color: var(--ui-primary-700);
}

.wf-nl-badge-planning {
    background: color-mix(in srgb, var(--ui-accent) 12%, transparent);
    color: hsl(var(--hp-hue-accent), 80%, 30%);
}

.wf-nl-card-desc {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    line-height: 1.6;
    margin: 0 0 var(--ui-space-3);
    flex: 1;
}

.wf-nl-article-count {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    margin-bottom: var(--ui-space-3);
}

.wf-nl-article-count i {
    color: var(--ui-primary);
    margin-right: 4px;
}

.wf-nl-themes {
    margin-bottom: var(--ui-space-3);
}

.wf-nl-themes-label {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--ui-space-1);
}

.wf-nl-theme-item {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-600);
    padding: 2px 0;
}

.wf-nl-theme-item i {
    color: var(--ui-primary);
    margin-right: 4px;
    font-size: 0.6em;
}

.wf-nl-card-action {
    margin-top: auto;
    padding-top: var(--ui-space-3);
    border-top: 1px solid var(--ui-gray-100);
}

.wf-nl-read-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--ui-space-2);
    padding: var(--ui-space-2) var(--ui-space-4);
    background: var(--ui-primary);
    color: var(--ui-white);
    border: none;
    border-radius: var(--ui-radius-md);
    font-size: var(--ui-text-sm);
    font-weight: var(--ui-font-semibold);
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
}

.wf-nl-read-btn:hover {
    background: var(--ui-primary-600);
    transform: translateY(-1px);
}

.wf-nl-coming {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
}

.wf-nl-coming i {
    color: hsl(var(--hp-hue-accent), 70%, 45%);
    margin-right: 4px;
}

.wf-nl-contact {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
}

.wf-nl-contact i {
    color: var(--ui-primary);
    margin-right: var(--ui-space-1);
}

/* Newsletter back bar */
.wf-newsletter-backbar {
    padding: var(--ui-space-2) var(--ui-space-4);
    border-bottom: 1px solid var(--ui-gray-200);
    flex-shrink: 0;
}

.wf-nl-back-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--ui-space-2);
    padding: var(--ui-space-1) var(--ui-space-3);
    background: none;
    border: 1px solid var(--ui-gray-300);
    border-radius: var(--ui-radius-md);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    cursor: pointer;
    transition: background 0.15s;
}

.wf-nl-back-btn:hover {
    background: var(--ui-gray-50);
}

/* ─── Home: Hero ─── */
.wf-home-hero {
    background: linear-gradient(135deg, var(--ui-primary-600), var(--ui-primary-800));
    border-radius: var(--ui-radius-lg);
    padding: var(--ui-space-7) var(--ui-space-6);
    color: var(--ui-white);
}

.wf-home-hero-title {
    font-family: 'Poppins', sans-serif;
    font-size: var(--ui-text-2xl);
    font-weight: var(--ui-font-bold);
    margin: 0 0 var(--ui-space-2) 0;
    display: flex;
    align-items: center;
    gap: var(--ui-space-3);
}

.wf-home-hero-sub {
    font-size: var(--ui-text-base);
    opacity: 0.85;
    margin: 0;
}

/* ─── Home: Grid ─── */
.wf-home-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: var(--ui-space-5);
}

@media (max-width: 900px) {
    .wf-home-grid { grid-template-columns: 1fr; }
}

.wf-home-section {
    background: var(--ui-white);
    border-radius: var(--ui-radius-lg);
    border: 1px solid var(--ui-gray-200);
    padding: var(--ui-space-4);
    margin-bottom: var(--ui-space-4);
}

/* ─── Home: Article cards ─── */
.wf-home-article-list {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-2);
}

.wf-home-article-card {
    padding: var(--ui-space-3);
    border-radius: var(--ui-radius-md);
    border: 1px solid var(--ui-gray-100);
    transition: background 0.15s, border-color 0.15s;
}

.wf-home-article-card:hover {
    background: var(--ui-primary-50);
    border-color: var(--ui-primary-200);
}

.wf-home-article-card-open {
    border-color: var(--ui-primary-300);
    background: var(--ui-primary-50);
}

.wf-home-article-meta {
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
    margin-bottom: var(--ui-space-1);
}

.wf-home-article-cat {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-primary-700);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.wf-home-article-date {
    font-size: var(--ui-text-2xs);
    color: var(--ui-gray-400);
}

.wf-home-article-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
    margin-bottom: var(--ui-space-1);
}

.wf-home-article-excerpt {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    line-height: 1.5;
}

.wf-home-article-expanded {
    margin-top: var(--ui-space-3);
    padding-top: var(--ui-space-3);
    border-top: 1px solid var(--ui-gray-200);
}

.wf-home-article-body {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-700);
    line-height: 1.7;
}

.wf-home-article-footer {
    display: flex;
    gap: var(--ui-space-4);
    margin-top: var(--ui-space-3);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-400);
}

.wf-home-article-footer i {
    margin-right: var(--ui-space-1);
}

.wf-home-view-all {
    margin-top: var(--ui-space-3);
    padding-top: var(--ui-space-2);
    border-top: 1px solid var(--ui-gray-100);
    font-size: var(--ui-text-sm);
    color: var(--ui-primary);
    font-weight: var(--ui-font-medium);
    display: flex;
    justify-content: flex-end;
}

.wf-home-view-all:hover {
    color: var(--ui-primary-700);
}

/* ─── Home: Newsletter highlight ─── */
.wf-home-nl-card {
    display: flex;
    align-items: center;
    gap: var(--ui-space-3);
    padding: var(--ui-space-3);
    border-radius: var(--ui-radius-md);
    border: 1px solid var(--ui-primary-200);
    background: var(--ui-primary-50);
    transition: background 0.15s, box-shadow 0.15s;
}

.wf-home-nl-card:hover {
    background: var(--ui-primary-100);
    box-shadow: var(--ui-shadow-sm);
}

.wf-home-nl-icon {
    font-size: var(--ui-text-xl);
    color: var(--ui-primary);
    flex-shrink: 0;
}

.wf-home-nl-issue {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
}

.wf-home-nl-desc {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    line-height: 1.5;
    margin-top: var(--ui-space-1);
}

/* ─── Home: Quick links ─── */
.wf-home-quick-links {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-1);
}

.wf-home-quick-link {
    padding: var(--ui-space-2) var(--ui-space-3);
    border-radius: var(--ui-radius-md);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    transition: background 0.15s, color 0.15s;
    display: flex;
    align-items: center;
    gap: var(--ui-space-2);
}

.wf-home-quick-link:hover {
    background: var(--ui-primary-50);
    color: var(--ui-primary-700);
}

.wf-home-quick-link i {
    width: 20px;
    text-align: center;
    color: var(--ui-primary);
}

/* ─── Combined News tab layout ─── */
.wf-news-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-6);
}

.wf-news-newsletter-section {
    margin-bottom: var(--ui-space-2);
}

.wf-news-articles-section {
    margin-top: var(--ui-space-2);
}

.wf-news-articles-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ui-space-3);
    margin-bottom: var(--ui-space-3);
}

.wf-news-articles-header .wf-section-title {
    margin-bottom: 0;
}

.wf-news-articles-header .wf-filter-select {
    padding: var(--ui-space-1) var(--ui-space-3);
    border-radius: var(--ui-radius-md);
    border: 1px solid var(--ui-gray-300);
    font-size: var(--ui-text-sm);
    background: var(--ui-white);
}

/* ─── News cards ─── */
.wf-news-list {
    display: flex;
    flex-direction: column;
    gap: var(--ui-space-3);
}

.wf-news-card {
    background: var(--ui-white);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-lg);
    padding: var(--ui-space-4);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.wf-news-card:hover {
    border-color: var(--ui-primary-300);
    box-shadow: var(--ui-shadow-sm);
}

.wf-news-card-open {
    border-color: var(--ui-primary-400);
    box-shadow: var(--ui-shadow-md);
}

.wf-news-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--ui-space-3);
    margin-bottom: var(--ui-space-2);
}

.wf-news-card-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-base);
    color: var(--ui-gray-800);
    flex: 1;
}

.wf-news-card-badge {
    font-size: var(--ui-text-2xs);
    font-weight: var(--ui-font-semibold);
    color: var(--ui-white);
    padding: 2px 8px;
    border-radius: var(--ui-radius-full);
    white-space: nowrap;
    flex-shrink: 0;
}

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

.wf-news-card-excerpt {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-600);
    line-height: 1.6;
}

.wf-news-card-expanded {
    margin-top: var(--ui-space-4);
    padding-top: var(--ui-space-4);
    border-top: 1px solid var(--ui-gray-200);
}

.wf-news-card-body {
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-700);
    line-height: 1.7;
}

.wf-news-card-footer {
    display: flex;
    gap: var(--ui-space-4);
    margin-top: var(--ui-space-3);
    padding-top: var(--ui-space-2);
    border-top: 1px solid var(--ui-gray-100);
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-400);
}

.wf-news-card-footer i {
    margin-right: var(--ui-space-1);
}

/* ─── Newsletter: Publications grid ─── */
.wf-nl-publications {
    margin-top: var(--ui-space-5);
    padding-top: var(--ui-space-5);
    border-top: 1px solid var(--ui-gray-200);
}

.wf-nl-pub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--ui-space-3);
}

.wf-nl-pub-card {
    display: flex;
    align-items: flex-start;
    gap: var(--ui-space-3);
    padding: var(--ui-space-3);
    border: 1px solid var(--ui-gray-200);
    border-radius: var(--ui-radius-lg);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.wf-nl-pub-card:hover {
    border-color: var(--ui-primary-300);
    box-shadow: var(--ui-shadow-sm);
}

.wf-nl-pub-icon {
    font-size: var(--ui-text-xl);
    color: var(--ui-primary);
    flex-shrink: 0;
    margin-top: 2px;
}

.wf-nl-pub-title {
    font-weight: var(--ui-font-semibold);
    font-size: var(--ui-text-sm);
    color: var(--ui-gray-800);
}

.wf-nl-pub-desc {
    font-size: var(--ui-text-xs);
    color: var(--ui-gray-500);
    line-height: 1.5;
    margin-top: var(--ui-space-1);
}
