/*
Theme Name: Gistextract Theme
Theme URI: https://gistextract.local
Author: Gistextract
Description: Licht maatwerkthema voor recepten, kruidenmengsels en producten.
Version: 0.2.0
Requires at least: 6.4
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: gistextract-theme
*/

/* ─────────────────────────────────────────────────────────────
   DESIGN TOKENS
   Mobile-first. Progressively enhanced for tablet (≥640px)
   and desktop (≥1024px).
───────────────────────────────────────────────────────────── */
:root {
    /* Color palette */
    --gx-bg:           #edebdf;
    --gx-surface:      #f7f4ea;
    --gx-surface-soft: #e3dfd0;
    --gx-ink:          #2d2520;
    --gx-muted:        #6a5c54;
    --gx-accent:       #d1381b;
    --gx-accent-2:     #b3341a;
    --gx-nav-cta-bg:           var(--gx-accent);
    --gx-nav-cta-bg-hover:     #8e2310;
    --gx-nav-cta-text:         #ffffff;
    --gx-nav-cta-border:       var(--gx-accent);
    --gx-nav-cta-border-hover: #8e2310;
    --gx-line:         #cfc6b8;

    /* Elevation */
    --gx-shadow-sm:  0 2px 8px rgba(31, 38, 29, 0.06);
    --gx-shadow:     0 8px 28px rgba(31, 38, 29, 0.09);
    --gx-shadow-lg:  0 18px 50px rgba(31, 38, 29, 0.13);

    /* Layout */
    --gx-wrap:        1180px;
    --gx-gap:         clamp(0.75rem, 2vw, 1.25rem);
    --gx-radius:      16px;
    --gx-radius-sm:   8px;

    /* Typography — system stack (zero network cost) */
    --gx-serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Palatino, Georgia, serif;
    --gx-sans:  system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

    /* Transitions */
    --gx-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --gx-duration: 200ms;
}

/* ─────────────────────────────────────────────────────────────
   RESET & BASE  (mobile-first)
───────────────────────────────────────────────────────────── */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    /* Prevent font-size inflation on iOS */
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    scroll-behavior: smooth;
    /* Reserve scrollbar gutter — prevents CLS on page transitions */
    scrollbar-gutter: stable;
}

body {
    margin: 0;
    background:
        radial-gradient(circle at top left, rgba(209, 56, 27, 0.16), transparent 28%),
        radial-gradient(circle at top right, rgba(142, 35, 16, 0.12), transparent 24%),
        var(--gx-bg);
    color: var(--gx-ink);
    font-family: var(--gx-sans);
    font-size: 1rem; /* 16px base — never below 16px on mobile */
    line-height: 1.65;
    /* Improve text rendering */
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* Sensible image defaults */
img,
picture,
video,
canvas,
svg {
    display: block;
    max-width: 100%;
    height: auto;
}

/* Prevent long words from breaking layout on narrow screens */
p, li, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}

a {
    color: var(--gx-accent);
}

a:hover,
a:focus {
    color: var(--gx-accent-2);
}

/* ─────────────────────────────────────────────────────────────
   UTILITIES
───────────────────────────────────────────────────────────── */
.gx-site-shell {
    display: flex;
    flex-direction: column;
    min-height: 100dvh; /* dynamic viewport height — avoids iOS Chrome bar clipping */
}

.gx-wrap {
    width: min(calc(100% - 2rem), var(--gx-wrap));
    margin-inline: auto;
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.alignwide,
.alignfull {
    width: 100%;
}

/* ─────────────────────────────────────────────────────────────
   HEADER  —  sticky, full-width, backdrop blur
   Mobile: logo + hamburger on one row
   Desktop (≥768px): logo + fullnav + search
───────────────────────────────────────────────────────────── */
.gx-site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    /* 'will-change: transform' promotes to GPU layer — avoids repaint during scroll */
    will-change: transform;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background: rgba(246, 241, 231, 0.92);
    border-bottom: 1px solid rgba(216, 206, 185, 0.9);
    /* Contain layout so sticky recalculation doesn't affect the rest of the tree */
    contain: layout style;
}

.gx-header-top {
    border-bottom: 1px solid rgba(216, 206, 185, 0.9);
    background: rgba(251, 247, 240, 0.94);
}

.gx-header-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 42px;
    padding-block: 0.25rem;
}

.gx-top-nav ul,
.gx-top-menu-fallback {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.gx-top-nav a,
.gx-top-account a {
    color: var(--gx-ink);
    text-decoration: none;
    font-size: 0.85rem;
    opacity: 0.9;
}

.gx-top-account {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.gx-top-account__welcome {
    font-size: 0.8rem;
    color: var(--gx-muted);
}

.gx-top-nav a:hover,
.gx-top-nav a:focus-visible,
.gx-top-account a:hover,
.gx-top-account a:focus-visible {
    color: var(--gx-accent);
    opacity: 1;
}

.gx-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    /* Mobile: compact vertical rhythm */
    padding-block: 0.75rem;
    flex-wrap: wrap;
}

/* ── Brand ────────────────────────────────────────────── */
.gx-brand {
    display: inline-flex;
    flex-direction: column;
    gap: 0.1rem;
    text-decoration: none;
    color: var(--gx-ink);
    /* Minimum 44px touch target height */
    min-height: 44px;
    justify-content: center;
}

.gx-brand-logo {
    display: inline-flex;
    align-items: center;
}

.gx-brand-logo .custom-logo {
    display: block;
}

.gx-brand-logo .custom-logo {
    max-height: 82px;
    width: auto;
}

.gx-brand-logo .custom-logo--site-icon {
    max-height: 58px;
    border-radius: 8px;
}

.gx-brand--placeholder {
    width: clamp(150px, 24vw, 260px);
    min-height: 56px;
}

.gx-header-ad {
    flex: 1 1 280px;
    min-width: 220px;
}

.gx-header-ad__inner {
    min-height: 72px;
    border: 1px dashed rgba(209, 56, 27, 0.35);
    border-radius: var(--gx-radius-sm);
    background: rgba(255, 255, 255, 0.55);
    padding: 0.55rem 0.75rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.2rem;
}

.gx-header-ad__inner strong {
    font-size: 0.9rem;
    color: var(--gx-ink);
}

.gx-header-ad__inner span {
    font-size: 0.75rem;
    color: var(--gx-muted);
}

.gx-header-nav-row {
    border-top: 1px solid rgba(216, 206, 185, 0.9);
}

.gx-brand-mark {
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--gx-accent-2);
    line-height: 1;
}

.gx-brand-name {
    font-family: var(--gx-serif);
    font-size: clamp(1.25rem, 5vw, 1.75rem);
    line-height: 1;
}

/* ── Mobile: hamburger button ─────────────────────────── */
.gx-nav-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    /* Minimum 44×44 px touch target per WCAG 2.5.5 */
    width: 44px;
    height: 44px;
    padding: 0;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--gx-radius-sm);
    color: var(--gx-ink);
    cursor: pointer;
    transition: border-color var(--gx-duration) var(--gx-ease),
                background var(--gx-duration) var(--gx-ease);
    /* Flex order: after brand, before nav */
    margin-left: auto;
}

.gx-nav-toggle:hover {
    background: rgba(209, 56, 27, 0.08);
    border-color: var(--gx-line);
}

.gx-nav-toggle:focus-visible {
    outline: 2px solid var(--gx-accent);
    outline-offset: 2px;
}

/* Hamburger icon lines */
.gx-nav-toggle__bar {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--gx-ink);
    border-radius: 2px;
    transition: transform var(--gx-duration) var(--gx-ease),
                opacity   var(--gx-duration) var(--gx-ease);
    transform-origin: center;
}

@media (prefers-reduced-motion: reduce) {
    .gx-nav-toggle__bar {
        transition: none;
    }
    .gx-main-nav {
        transition: none;
    }
}

.gx-nav-toggle__icon {
    display: flex;
    flex-direction: column;
    gap: 5px;
    pointer-events: none;
}

/* Animate to × when open */
[aria-expanded="true"] .gx-nav-toggle__bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

[aria-expanded="true"] .gx-nav-toggle__bar:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}

[aria-expanded="true"] .gx-nav-toggle__bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* ── Primary nav ─────────────────────────────────────── */
/* Mobile: hidden by default, shown when toggle is active */
.gx-main-nav {
    /* Take full width below header on mobile */
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    right: 0;
    background: rgba(246, 241, 231, 0.98);
    border-bottom: 1px solid var(--gx-line);
    /* Animate height */
    overflow: hidden;
    max-height: 0;
    transition: max-height var(--gx-duration) var(--gx-ease);
    /* Visually hidden but not display:none so transitions work */
    visibility: hidden;
    z-index: 99;
}

.gx-main-nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.gx-main-nav-menu {
    flex: 1 1 auto;
    min-width: 0;
}

.gx-main-nav.is-open {
    max-height: min(calc(100dvh - 4rem), 90vh);
    visibility: visible;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.gx-main-nav ul {
    display: flex;
    flex-direction: column;
    gap: 0;
    list-style: none;
    padding: 0.5rem 0;
    margin: 0;
}

.gx-main-nav li {
    border-bottom: 1px solid rgba(216, 206, 185, 0.5);
}

.gx-main-nav li:last-child {
    border-bottom: none;
}

.gx-main-nav a {
    display: block;
    text-decoration: none;
    color: var(--gx-ink);
    /* Mobile: full-width tap target, minimum 44px height */
    padding: 0.85rem 1.25rem;
    min-height: 44px;
    font-size: 1rem;
    transition: background var(--gx-duration) var(--gx-ease),
                color     var(--gx-duration) var(--gx-ease);
}

.gx-main-nav a:hover,
.gx-main-nav a:focus {
    background: rgba(209, 56, 27, 0.07);
    color: var(--gx-accent);
}

.gx-main-nav a:focus-visible {
    outline: 2px solid var(--gx-accent);
    outline-offset: -2px;
}

.gx-nav-cta-enabled .gx-main-nav-menu > ul > li.gx-nav-cta-item > a {
    background: var(--gx-nav-cta-bg);
    color: var(--gx-nav-cta-text);
    border: 2px solid var(--gx-nav-cta-border);
    border-radius: 999px;
}

.gx-nav-cta-enabled .gx-main-nav-menu > ul > li.gx-nav-cta-item > a:hover,
.gx-nav-cta-enabled .gx-main-nav-menu > ul > li.gx-nav-cta-item > a:focus-visible {
    background: var(--gx-nav-cta-bg-hover);
    border-color: var(--gx-nav-cta-border-hover);
    color: var(--gx-nav-cta-text);
}

.gx-nav-search {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
    padding-right: 0.8rem;
}

.gx-nav-search-toggle {
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--gx-radius-sm);
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--gx-ink);
    cursor: pointer;
    opacity: 0.85;
    transition: opacity var(--gx-duration) var(--gx-ease),
                border-color var(--gx-duration) var(--gx-ease),
                background var(--gx-duration) var(--gx-ease);
}

.gx-nav-search-toggle svg {
    width: 26px;
    height: 26px;
}

.gx-nav-search-toggle:hover,
.gx-nav-search-toggle:focus-visible {
    opacity: 1;
    border-color: var(--gx-line);
    background: rgba(209, 56, 27, 0.06);
    outline: 2px solid var(--gx-accent);
    outline-offset: 2px;
}

.gx-nav-search-form {
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    display: flex;
    align-items: center;
    gap: 0.45rem;
    background: var(--gx-surface);
    border: 1px solid var(--gx-line);
    border-radius: var(--gx-radius-sm);
    box-shadow: var(--gx-shadow);
    padding: 0.45rem;
    min-width: min(92vw, 250px);
    max-width: min(92vw, 270px);
    z-index: 130;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px) scale(0.98);
    transition: opacity var(--gx-duration) var(--gx-ease),
                transform var(--gx-duration) var(--gx-ease),
                visibility 0s linear var(--gx-duration);
}

.gx-nav-search-form.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
    transition-delay: 0s;
}

.gx-nav-search-form input[type="search"] {
    width: clamp(120px, 24vw, 170px);
    min-height: 40px;
    border: 1px solid var(--gx-line);
    border-radius: var(--gx-radius-sm);
    padding: 0.5rem 0.7rem;
    font-size: 0.9rem;
    background: #fff;
    color: var(--gx-ink);
}

.gx-nav-search-form input[type="search"]:focus {
    outline: 2px solid var(--gx-accent);
    outline-offset: 1px;
    border-color: var(--gx-accent);
}

.gx-nav-search-submit {
    min-height: 40px;
    border: 0;
    border-radius: var(--gx-radius-sm);
    background: var(--gx-accent);
    color: #fff;
    font-weight: 700;
    padding: 0.5rem 0.8rem;
    cursor: pointer;
}

.gx-nav-search[data-open="true"] .gx-nav-search-toggle svg {
    animation: gx-search-lens-scan 0.95s ease-in-out infinite alternate;
}

.gx-nav-search[data-open="true"] .gx-nav-search-form::before {
    content: "";
    position: absolute;
    left: 0.65rem;
    right: 0.65rem;
    top: 0.55rem;
    bottom: 0.55rem;
    border-radius: 6px;
    border: 1px solid rgba(86, 97, 79, 0.24);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 245, 237, 0.9));
    pointer-events: none;
}

.gx-nav-search[data-open="true"] .gx-nav-search-form::after {
    content: "";
    position: absolute;
    width: 36px;
    height: 36px;
    top: 50%;
    left: 0.72rem;
    margin-top: -18px;
    border: 2px solid rgba(209, 56, 27, 0.34);
    border-radius: 50%;
    box-shadow: 0 0 0 4px rgba(209, 56, 27, 0.08);
    pointer-events: none;
    animation: gx-search-sweep 1.2s ease-in-out infinite alternate;
}

.gx-nav-search[data-open="true"] .gx-nav-search-form > * {
    position: relative;
    z-index: 1;
}

@keyframes gx-search-lens-scan {
    from {
        transform: translateX(-1px) rotate(-4deg);
    }
    to {
        transform: translateX(2px) rotate(5deg);
    }
}

@keyframes gx-search-sweep {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(52px);
    }
}

.gx-nav-search-submit:hover,
.gx-nav-search-submit:focus-visible {
    background: #8e2310;
    outline: 2px solid var(--gx-accent);
    outline-offset: 2px;
}

/* ─────────────────────────────────────────────────────────────
   MAIN CONTENT AREA
───────────────────────────────────────────────────────────── */
.gx-main {
    flex: 1;
    padding-block: 1.25rem 3rem;
}

/* ─────────────────────────────────────────────────────────────
   PANEL / CARD SURFACE
───────────────────────────────────────────────────────────── */
.gx-panel {
    background: rgba(255, 253, 248, 0.9);
    border: 1px solid var(--gx-line);
    border-radius: var(--gx-radius);
    box-shadow: var(--gx-shadow);
    /* Isolate paint — faster compositing on mobile GPU */
    contain: layout style;
}

/* ─────────────────────────────────────────────────────────────
   PAGE & ENTRY LAYOUT
───────────────────────────────────────────────────────────── */
.gx-page {
    padding: 1rem;
}

.gx-page-title,
.gx-entry-title,
.gx-archive-title {
    margin: 0 0 0.6rem;
    font-family: var(--gx-serif);
    /* fluid: 1.75rem on 320px → 3.5rem on wide screens */
    font-size: clamp(1.75rem, 6vw + 0.5rem, 3.5rem);
    line-height: 1.05;
    letter-spacing: -0.025em;
}

.gx-entry-header,
.gx-archive-hero {
    padding: 1rem;
    margin-bottom: 0;
}

.gx-entry-content,
.gx-page-content,
.gx-archive-content {
    padding: 1rem;
}

/* Single-column on mobile; two-column aside layout injected at ≥1024px */
.gx-entry-layout {
    display: grid;
    gap: var(--gx-gap);
}

/* ─────────────────────────────────────────────────────────────
   FEATURED MEDIA
   Explicit aspect-ratio prevents CLS (Cumulative Layout Shift)
───────────────────────────────────────────────────────────── */
.gx-feature-media {
    overflow: hidden;
    border-radius: var(--gx-radius);
    border: 1px solid var(--gx-line);
    background: var(--gx-surface-soft);
    /* Reserve space before image loads — prevents CLS */
    aspect-ratio: 16 / 9;
}

.gx-feature-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ─────────────────────────────────────────────────────────────
   RECIPE META PILLS
───────────────────────────────────────────────────────────── */
.gx-theme-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-block: 0.75rem 0;
}

.gx-theme-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    background: rgba(209, 56, 27, 0.09);
    border: 1px solid rgba(209, 56, 27, 0.14);
    color: var(--gx-accent);
    font-size: 0.85rem;
    white-space: nowrap;
}

/* ─────────────────────────────────────────────────────────────
   ASIDE PANEL
───────────────────────────────────────────────────────────── */
.gx-section-title {
    margin: 0 0 0.65rem;
    font-family: var(--gx-serif);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
}

.gx-entry-aside {
    padding: 1rem;
}

.gx-entry-aside p {
    margin-top: 0;
    color: var(--gx-muted);
    font-size: 0.9375rem;
}

/* ─────────────────────────────────────────────────────────────
   CARD GRID  —  mobile-first, no layout-breaking auto-fit
   Mobile:  1 column
   ≥540px:  2 columns
   ≥1024px: 3 columns
───────────────────────────────────────────────────────────── */
.gx-post-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gx-gap);
}

.gx-card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gx-gap);
}

/* Reserve space for thumbnails — prevents CLS */
.gx-card-thumbnail {
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: var(--gx-radius) var(--gx-radius) 0 0;
    background: var(--gx-surface-soft);
}

.gx-card-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* Smooth reveal on load */
    transition: opacity 300ms var(--gx-ease);
}

.gx-post-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: var(--gx-radius);
    border: 1px solid var(--gx-line);
    background: var(--gx-surface);
    box-shadow: var(--gx-shadow-sm);
    transition: box-shadow var(--gx-duration) var(--gx-ease),
                transform   var(--gx-duration) var(--gx-ease);
    /* Promote to own compositor layer — smoother hover transitions on mobile */
    will-change: transform;
}

.gx-post-card:hover,
.gx-post-card:focus-within {
    box-shadow: var(--gx-shadow);
    transform: translateY(-2px);
}

.gx-card-content {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.gx-card-title {
    margin: 0 0 0.5rem;
    font-family: var(--gx-serif);
    font-size: clamp(1.05rem, 2.5vw, 1.25rem);
    line-height: 1.25;
}

.gx-card-title a {
    text-decoration: none;
    color: var(--gx-ink);
    /* Stretch the anchor to fill the card — easier tap on mobile */
    display: block;
}

.gx-card-title a:hover,
.gx-card-title a:focus {
    color: var(--gx-accent);
}

/* Card link — full card clickable via CSS (no JS needed) */
.gx-card-title a::after {
    content: "";
    position: absolute;
    inset: 0;
}

.gx-post-card {
    position: relative; /* for ::after full-card link */
}

.gx-card-excerpt {
    margin: 0 0 0.75rem;
    color: var(--gx-muted);
    font-size: 0.9375rem;
    /* Clamp to 3 lines — prevents very long excerpts blowing up card height */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gx-post-card h2,
.gx-post-card h3 {
    margin-top: 0;
    font-family: var(--gx-serif);
}

.gx-post-card p {
    color: var(--gx-muted);
}

.gx-post-card-link {
    display: inline-flex;
    margin-top: 0.5rem;
    text-decoration: none;
    font-weight: 600;
}

/* ─────────────────────────────────────────────────────────────
   ENTRY META / ARCHIVE INTRO
───────────────────────────────────────────────────────────── */
.gx-entry-meta,
.gx-archive-intro {
    color: var(--gx-muted);
    font-size: 0.875rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem 1rem;
}

.gx-muted-copy {
    color: var(--gx-muted);
}

/* ─────────────────────────────────────────────────────────────
   PAGINATION
───────────────────────────────────────────────────────────── */
.gx-pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    padding-block: 1.5rem;
}

.gx-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    padding: 0.3rem 0.7rem;
    border-radius: var(--gx-radius-sm);
    border: 1px solid var(--gx-line);
    text-decoration: none;
    color: var(--gx-ink);
    font-size: 0.9rem;
    transition: background var(--gx-duration) var(--gx-ease);
}

.gx-pagination .page-numbers:hover,
.gx-pagination .page-numbers:focus-visible {
    background: rgba(209, 56, 27, 0.1);
    color: var(--gx-accent);
}

.gx-pagination .current {
    background: var(--gx-accent);
    color: #fff;
    border-color: var(--gx-accent);
}

/* ─────────────────────────────────────────────────────────────
   BREADCRUMBS
───────────────────────────────────────────────────────────── */
.gx-breadcrumbs {
    font-size: 0.8rem;
    line-height: 1.25;
    color: var(--gx-muted);
    padding-bottom: 0.4rem;
    margin-bottom: 0.2rem;
}

.gx-breadcrumbs ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0;
}

.gx-breadcrumbs li {
    display: inline-flex;
    align-items: baseline;
    line-height: inherit;
}

.gx-breadcrumbs li + li::before {
    content: '>';
    display: inline-block;
    line-height: 1;
    margin-inline: 0.45rem;
    opacity: 0.55;
}

.gx-breadcrumbs a {
    color: var(--gx-muted);
    text-decoration: none;
    padding: 0;
    line-height: inherit;
}

.gx-breadcrumbs a:hover {
    color: var(--gx-accent);
    text-decoration: underline;
}

.gx-breadcrumb-sep {
    margin-inline: 0.3rem;
    opacity: 0.5;
}

/* ─────────────────────────────────────────────────────────────
   FOOTER
   content-visibility: auto defers paint/layout of offscreen footer
───────────────────────────────────────────────────────────── */
.gx-footer {
    margin-top: auto;
    padding-block: 1.5rem 2.5rem;
    content-visibility: auto;
    contain-intrinsic-size: 0 120px; /* hint to browser for scrollbar calculation */
}

.gx-footer-panel {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.gx-footer-copy {
    color: var(--gx-muted);
    font-size: 0.875rem;
}

.gx-footer-links {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.gx-footer-links a {
    text-decoration: none;
    color: var(--gx-muted);
    font-size: 0.875rem;
    /* 44px touch target */
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

.gx-footer-links a:hover,
.gx-footer-links a:focus-visible {
    color: var(--gx-accent);
    text-decoration: underline;
}

/* ─────────────────────────────────────────────────────────────
   ARCHIVE / HERO SECTION
───────────────────────────────────────────────────────────── */
.gx-archive-stack {
    display: grid;
    gap: var(--gx-gap);
}

/* ─────────────────────────────────────────────────────────────
   BUTTONS & INTERACTIVE ELEMENTS
───────────────────────────────────────────────────────────── */
.gx-btn,
.gx-primary-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    /* Minimum 44px touch target */
    min-height: 44px;
    padding: 0.55rem 1.25rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9375rem;
    cursor: pointer;
    transition: background var(--gx-duration) var(--gx-ease),
                color     var(--gx-duration) var(--gx-ease),
                transform var(--gx-duration) var(--gx-ease);
}

.gx-btn-primary {
    background: var(--gx-accent);
    color: #fff;
    border: 2px solid var(--gx-accent);
}

.gx-btn-primary:hover,
.gx-btn-primary:focus-visible {
    background: #8e2310;
    border-color: #8e2310;
    color: #fff;
}

.gx-btn:active {
    transform: scale(0.98);
}

/* ─────────────────────────────────────────────────────────────
   TABLET BREAKPOINT  (≥540px)
   Two-column card grid
───────────────────────────────────────────────────────────── */
@media (min-width: 540px) {
    .gx-post-grid,
    .gx-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .gx-footer-panel {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-start;
    }
}

/* ─────────────────────────────────────────────────────────────
   SMALL DESKTOP BREAKPOINT  (≥768px)
   Desktop nav replaces hamburger, search visible in header
───────────────────────────────────────────────────────────── */
@media (min-width: 768px) {
    .gx-header-top-row {
        min-height: 38px;
    }

    .gx-top-nav a,
    .gx-top-account a {
        font-size: 0.8rem;
    }

    .gx-header-row {
        flex-wrap: nowrap;
    }

    .gx-brand {
        flex: 0 0 auto;
        max-width: 280px;
    }

    .gx-header-ad {
        flex: 1 1 auto;
    }

    .gx-header-ad__inner {
        min-height: 82px;
    }

    /* Hide hamburger */
    .gx-nav-toggle {
        display: none;
    }

    /* Re-show nav as inline flex — static, no dropdown */
    .gx-main-nav {
        position: static;
        max-height: none;
        overflow: visible;
        visibility: visible;
        background: transparent;
        border: none;
        transition: none;
    }

    .gx-main-nav.is-open {
        max-height: none; /* reset any inline max-height override */
    }

    .gx-main-nav ul {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0;
        padding: 0;
    }

    .gx-main-nav-menu > ul {
        justify-content: flex-start;
    }

    .gx-main-nav li {
        border: none;
    }

    .gx-main-nav a {
        padding: 0.45rem 0.7rem;
        border-radius: 999px;
        min-height: auto;
        font-size: 0.9375rem;
    }

    /* Hide in-nav mobile search (it's now in the header bar) */
    .gx-main-nav-inner {
        padding-right: 0.35rem;
    }

    .gx-header-row {
        padding-block: 0.9rem;
    }

    .gx-brand-name {
        font-size: clamp(1.4rem, 2.4vw, 2rem);
    }


@media (max-width: 767px) {
    .gx-header-top-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
        padding-block: 0.4rem;
    }

    .gx-header-ad {
        width: 100%;
        order: 3;
    }

    .gx-nav-toggle {
        order: 3;
    }

    .gx-brand {
        order: 1;
    }

    .gx-main-nav-inner {
        display: block;
    }

    .gx-nav-search {
        justify-content: flex-start;
        padding: 0.5rem 1.1rem 0.9rem;
    }

    .gx-nav-search-form {
        position: static;
        margin-top: 0.5rem;
        min-width: 100%;
        max-width: 100%;
        box-shadow: none;
        transform: translateY(-4px);
    }

    .gx-nav-search-form input[type="search"] {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .gx-nav-search[data-open="true"] .gx-nav-search-toggle svg,
    .gx-nav-search[data-open="true"] .gx-nav-search-form::after {
        animation: none;
    }

    .gx-nav-search-form,
    .gx-nav-search-form.is-visible {
        transition: none;
        transform: none;
    }
}
    /* Switch content+aside to side-by-side */
    .gx-entry-layout-has-aside {
        grid-template-columns: minmax(0, 1.9fr) minmax(260px, 0.75fr);
        align-items: start;
    }

    .gx-page {
        padding: 1.4rem;
    }

    .gx-entry-header,
    .gx-archive-hero {
        padding: 1.5rem 1.5rem 1rem;
    }

    .gx-entry-content,
    .gx-page-content,
    .gx-archive-content {
        padding: 1.5rem;
    }

    .gx-entry-aside {
        padding: 1.25rem;
    }
}

/* ─────────────────────────────────────────────────────────────
   DESKTOP BREAKPOINT  (≥1024px)
   Three-column card grid, larger typography
───────────────────────────────────────────────────────────── */
@media (min-width: 1024px) {
    .gx-post-grid,
    .gx-card-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .gx-feature-media {
        aspect-ratio: 21 / 9;
    }
}

/* ─────────────────────────────────────────────────────────────
   PRINT STYLES  (completes W3C best-practices)
───────────────────────────────────────────────────────────── */
@media print {
    /* Hide non-essential chrome */
    .gx-site-header,
    .gx-nav-toggle,
    .gx-footer-links,
    .gx-skip-links,
    .gx-pagination,
    .gx-nav-search,
    .gx-entry-aside {
        display: none !important;
    }

    body {
        background: #fff;
        color: #000;
        font-size: 12pt;
    }

    a[href]::after {
        content: " (" attr(href) ")";
        font-size: 0.85em;
        color: #555;
    }

    /* Don't print echo'd absolute URLs for internal links */
    a[href^="/"]:after,
    a[href^="#"]:after {
        content: "";
    }

    .gx-feature-media img {
        max-height: 300px;
    }

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

    /* Avoid page-break inside a card */
    .gx-post-card {
        break-inside: avoid;
    }
}

/* ─────────────────────────────────────────────────────────────
   ARCHIVE HERO COMPONENT  (template-parts/hero.php)
   Mobile-first: compact stacked layout
   ≥768px: wider padding, larger search form
───────────────────────────────────────────────────────────── */
.gx-archive-hero {
    padding: 1.25rem 1rem 1rem;
    border-bottom: 1px solid var(--gx-line);
    margin-bottom: var(--gx-gap);
}

.gx-archive-hero-inner {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.gx-archive-description {
    margin: 0;
    color: var(--gx-muted);
    font-size: 1rem;
    line-height: 1.6;
    max-width: 65ch;
}

/* Hero search form */
.gx-hero-search {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    max-width: 480px;
}

.gx-hero-search input[type="search"] {
    flex: 1;
    padding: 0.6rem 1rem;
    font-size: 1rem;
    border: 1px solid var(--gx-line);
    border-radius: 999px;
    background: var(--gx-surface);
    color: var(--gx-ink);
    min-height: 44px;
    transition: border-color var(--gx-duration) var(--gx-ease);
    -webkit-appearance: none; /* remove iOS default styling */
}

.gx-hero-search input[type="search"]:focus {
    outline: 2px solid var(--gx-accent);
    outline-offset: 1px;
    border-color: var(--gx-accent);
}

.gx-hero-search button[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: var(--gx-accent);
    color: #fff;
    border: none;
    border-radius: 999px;
    cursor: pointer;
    flex-shrink: 0;
    transition: background var(--gx-duration) var(--gx-ease);
}

.gx-hero-search button[type="submit"]:hover {
    background: #8e2310;
}

.gx-hero-search button[type="submit"]:focus-visible {
    outline: 2px solid var(--gx-accent);
    outline-offset: 3px;
}

@media (min-width: 768px) {
    .gx-archive-hero {
        padding: 1.75rem 1.5rem 1.25rem;
    }

    .gx-hero-search {
        max-width: 540px;
    }
}

/* ─────────────────────────────────────────────────────────────
   ARCHIVE BODY  (replaces invalid nested <main>)
───────────────────────────────────────────────────────────── */
.gx-archive-body {
    padding-block: 0.5rem 1rem;
}

/* ─────────────────────────────────────────────────────────────
   EMPTY STATE COMPONENT  (template-parts/empty-state.php)
───────────────────────────────────────────────────────────── */
.gx-empty-state {
    text-align: center;
    padding: 2.5rem 1rem;
    max-width: 480px;
    margin-inline: auto;
}

.gx-empty-state-icon {
    font-size: 2.5rem;
    line-height: 1;
    margin-bottom: 1rem;
}

.gx-empty-state-title {
    margin: 0 0 0.5rem;
    font-family: var(--gx-serif);
    font-size: clamp(1.25rem, 3vw, 1.75rem);
}

.gx-empty-state-message {
    color: var(--gx-muted);
    margin: 0 0 1.5rem;
    line-height: 1.65;
}

.gx-empty-state-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
}

/* ─────────────────────────────────────────────────────────────
   CARD TERM LINKS (taxonomy displays on cards)
───────────────────────────────────────────────────────────── */
.gx-card-terms {
    margin: auto 0 0; /* push to bottom of card */
    padding-top: 0.5rem;
    font-size: 0.8125rem;
    color: var(--gx-muted);
}

.gx-card-term-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--gx-accent);
    text-decoration: none;
    /* Relative so it doesn't get absorbed by the ::after full-card link */
    position: relative;
    z-index: 1;
}

.gx-card-term-badge-visual {
    font-size: 0.875rem;
    width: 0.875rem;
    height: 0.875rem;
    line-height: 0.875rem;
    color: var(--gx-accent);
}

.gx-card-term-badge-image {
    width: 0.875rem;
    height: 0.875rem;
    border-radius: 3px;
    object-fit: cover;
    border: 1px solid color-mix(in srgb, var(--gx-accent) 28%, #fff 72%);
}

.gx-card-term-link:hover {
    text-decoration: underline;
}

/* ─────────────────────────────────────────────────────────────
   FRONT PAGE  (shortcode-driven)
───────────────────────────────────────────────────────────── */
.gx-front-page {
    min-height: 40vh;
}

/* ─────────────────────────────────────────────────────────────
   CATEGORY ARCHIVE PAGE HEADER  (category.php)
   Full-width hero image, centered title, description preview,
   subcategory grid.
───────────────────────────────────────────────────────────── */

.gx-cat-page-header {
    background: var(--gx-cat-bar-color, color-mix(in srgb, var(--gx-accent) 18%, #f5f8f6 82%));
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    padding: 0.8rem 0;
    margin-bottom: var(--gx-gap);
}

.gx-cat-hero-image {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    aspect-ratio: 21 / 9;
    max-height: 420px;
    width: min(100% - 2rem, var(--gx-cat-hero-max-width, 1360px));
    margin: 0 auto;
    background: color-mix(in srgb, var(--gx-accent) 85%, #0b1220 15%);
}

.gx-cat-hero-image.is-no-image {
    min-height: 200px;
}

.gx-cat-hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gx-cat-hero-color-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(8, 16, 22, calc(var(--gx-cat-hero-overlay-opacity, 0.42) * 0.30)) 0%,
        rgba(8, 16, 22, calc(var(--gx-cat-hero-overlay-opacity, 0.42) * 0.75)) 55%,
        rgba(8, 16, 22, var(--gx-cat-hero-overlay-opacity, 0.42)) 100%
    );
}

.gx-cat-hero-content {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    text-align: center;
    padding: 1rem;
}

.gx-cat-hero-title {
    margin: 0;
    color: #fff;
    font-family: var(--gx-serif);
    font-size: max(1.6rem, min(var(--gx-cat-hero-title-size, 48px), 9vw));
    line-height: 1.1;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}

.gx-cat-hero-count {
    margin: 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: clamp(0.85rem, 1.6vw, 1rem);
    font-weight: 500;
    line-height: 1.2;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

.gx-cat-hero-badge {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.35rem 0.7rem;
    background: rgba(255, 255, 255, 0.92);
    border-radius: 999px;
    backdrop-filter: blur(4px);
    z-index: 3;
}

.gx-cat-hero-badge .gx-card-term-badge-visual {
    font-size: 1.25rem;
    width: 1.25rem;
    height: 1.25rem;
    line-height: 1.25rem;
    color: var(--gx-accent);
}

.gx-cat-hero-badge .gx-card-term-badge-image {
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 4px;
}

.gx-cat-description-wrap {
    width: min(100% - 2rem, 1180px);
    margin: var(--gx-gap) auto 0;
}

.gx-cat-description {
    margin-top: 0;
    width: 100%;
}

.gx-cat-description-excerpt {
    margin: 0;
    color: var(--gx-muted);
    font-size: clamp(1rem, 1.3vw, 1.075rem);
    line-height: 1.65;
}

.gx-cat-description-more {
    margin-top: 0.55rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.55rem;
}

.gx-cat-description-more summary {
    order: 1;
    list-style: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.85rem;
    border: 1px solid var(--gx-line);
    border-radius: 999px;
    color: var(--gx-accent);
    cursor: pointer;
    user-select: none;
    transition: background var(--gx-duration) var(--gx-ease), border-color var(--gx-duration) var(--gx-ease);
}

.gx-cat-description-more summary:hover {
    background: rgba(209, 56, 27, 0.06);
    border-color: var(--gx-accent);
}

.gx-cat-description-more summary::-webkit-details-marker {
    display: none;
}

.gx-cat-description-more summary .dashicons {
    font-size: 1rem;
    width: 1rem;
    height: 1rem;
    line-height: 1rem;
    transition: transform var(--gx-duration) var(--gx-ease);
}

.gx-cat-description-more[open] summary .dashicons {
    transform: rotate(180deg);
}

.gx-cat-description-more-label--close {
    display: none;
}

.gx-cat-description-more[open] .gx-cat-description-more-label--open {
    display: none;
}

.gx-cat-description-more[open] .gx-cat-description-more-label--close {
    display: inline;
}

.gx-cat-description-full {
    order: 2;
    margin-top: 0;
    color: var(--gx-muted);
    line-height: 1.7;
}

.gx-cat-description-more[open] summary {
    order: 2;
}

.gx-cat-description-more[open] .gx-cat-description-full {
    order: 1;
}

.gx-cat-description-full p {
    margin: 0 0 0.8rem;
}

.gx-cat-description-full p:last-child {
    margin-bottom: 0;
}

/* ── Subcategory grid ────────────────────────────────────── */

.gx-subcat-section {
    padding: 1.25rem 1rem;
    border-bottom: 1px solid var(--gx-line);
}

.gx-subcat-section-title {
    font-family: var(--gx-serif);
    font-size: clamp(0.85rem, 2vw, 1rem);
    font-weight: 600;
    margin: 0 0 0.85rem;
    color: var(--gx-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.gx-subcat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.85rem;
}

/* Each subcategory card is a link */
.gx-subcat-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--gx-ink);
    border-radius: var(--gx-radius);
    overflow: hidden;
    border: 1px solid var(--gx-line);
    background: var(--gx-surface);
    transition: box-shadow var(--gx-duration) var(--gx-ease),
                transform var(--gx-duration) var(--gx-ease);
}

.gx-subcat-card:hover {
    box-shadow: 0 3px 14px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.gx-subcat-card:focus-visible {
    outline: 2px solid var(--gx-accent);
    outline-offset: 2px;
}

/* Image wrapper with fixed aspect */
.gx-subcat-card-image-wrap {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--gx-surface-soft);
}

/* Placeholder when no image — badge gets centered */
.gx-subcat-card-image-wrap--no-image {
    aspect-ratio: 4 / 3;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gx-surface-soft);
}

.gx-subcat-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--gx-duration) var(--gx-ease);
}

.gx-subcat-card:hover .gx-subcat-card-img {
    transform: scale(1.04);
}

/* Badge chip overlay on card image */
.gx-subcat-card-badge {
    position: absolute;
    bottom: 0.45rem;
    left: 0.45rem;
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.5rem;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 999px;
    backdrop-filter: blur(3px);
}

/* Badge centered inside placeholder (no image) */
.gx-subcat-card-badge--centered {
    position: static;
    background: none;
    backdrop-filter: none;
    padding: 0;
}

/* Scale up badge visuals inside subcategory cards */
.gx-subcat-card-badge .gx-card-term-badge-visual {
    font-size: 1rem;
    width: 1rem;
    height: 1rem;
    line-height: 1rem;
    color: var(--gx-accent);
}

.gx-subcat-card-badge .gx-card-term-badge-image {
    width: 1.1rem;
    height: 1.1rem;
    border-radius: 3px;
}

/* Centered badge (no image): much bigger */
.gx-subcat-card-badge--centered .gx-card-term-badge-visual {
    font-size: 2.5rem;
    width: 2.5rem;
    height: 2.5rem;
    line-height: 2.5rem;
}

.gx-subcat-card-badge--centered .gx-card-term-badge-image {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 6px;
}

/* Category name label at bottom of card */
.gx-subcat-card-name {
    display: block;
    padding: 0.55rem 0.7rem 0.2rem;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.3;
}

.gx-subcat-card-count {
    display: block;
    padding: 0 0.7rem 0.65rem;
    font-size: 0.75rem;
    line-height: 1.25;
    color: var(--gx-muted);
    flex: 1;
}

.gx-term-overview-section {
    margin-top: 1.5rem;
}

.gx-term-overview-title {
    margin: 0 0 1rem;
    font-family: var(--gx-serif);
    font-size: clamp(1.4rem, 3vw, 2rem);
    line-height: 1.15;
}

.gx-term-overview-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}

.gx-term-overview-card {
    min-height: 100%;
}

.gx-term-overview-desc {
    display: block;
    padding: 0 0.7rem 0.85rem;
    font-size: 0.8rem;
    line-height: 1.5;
    color: var(--gx-muted);
}

/* ── Category page responsive tweaks ──────────────────────── */

@media (min-width: 540px) {
    .gx-subcat-grid {
        grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
    }
}

@media (min-width: 768px) {
    .gx-cat-page-header {
        padding-block: 0.85rem 1.1rem;
    }

    .gx-cat-hero-image {
        max-height: 460px;
        width: min(100% - 3rem, var(--gx-cat-hero-max-width));
    }

    .gx-subcat-section {
        width: min(100% - 2rem, 1180px);
        margin: 0 auto;
        padding: 1.5rem 0;
    }

    .gx-subcat-grid {
        grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
        gap: 1rem;
    }
}
