/* ==========================================================================
   Custom Properties
   ========================================================================== */

:root {
    /* Typography */
    --font-family: "Open Sans", sans-serif;
    --font-weight-body: 400;
    --font-weight-ui: 600;
    --font-weight-heading: 800;

    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-md: 1.125rem;
    --font-size-lg: 1.25rem;
    --font-size-xl: 1.75rem;
    --font-size-2xl: 2.8125rem;

    /* Spacing */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 1rem;
    --space-4: 1.5rem;
    --space-5: 2rem;
    --space-6: 3rem;

    /* Layout */
    --content-width: 77.25rem;

    /* Colors – background */
    --color-bg: #fff;
    --color-bg-page: #ebebeb;
    --color-bg-muted: #f5f5f5;
    --color-bg-subtle: #f8f9fa;
    --color-bg-overlay: rgba(255, 255, 255, 0.97);
    --color-bg-blue: #dbeff8;
    --color-bg-purple: #e1d1e8;
    --color-bg-green: #b8e1c8;
    --color-bg-pink: #f8ccdc;

    /* Colors – text */
    --color-text: #333;
    --color-text-muted: #666;
    --color-text-light: #595959;
    --color-text-inverse: #fff;

    /* Colors – primary / links */
    --color-primary: #005799;
    --color-primary-hover: #e8f0f8;
    --color-primary-dark: #004578;

    /* Colors – Göteborg */
    --color-gbg-blue: #0077bc;

    /* Colors – complement (strong) */
    /* --color-complement-gbg-blue: #0077bc;
    --color-complement-dark-blue: #3f5564;
    --color-complement-teal: #008391;
    --color-complement-green-dark: #008767;
    --color-complement-yellow: #ffcd37;
    --color-complement-red: #d24723;
    --color-complement-pink: #d53878;
    --color-complement-purple: #674b99; */

    /* Colors – complement (light / pastel) */
    --color-complement-green: #b8e1c8;
    --color-complement-gray: #d1d9dc;
    --color-complement-light-blue: #c0e4f2;
    --color-complement-light-green: #b8e1c8;
    --color-complement-light-yellow: #fff3b0;
    --color-complement-peach: #fbcfb9;
    --color-complement-light-pink: #f8ccdc;
    --color-complement-violet: #e1d1e8;

    /* Colors – borders */
    --color-border: #e5e5e5;
    --color-border-light: #f0f0f0;
    --color-border-input: #ddd;

    /* Colors – shadows */
    --color-shadow-card: rgba(0, 0, 0, 0.08);
    --color-shadow-a11y: rgba(0, 0, 0, 0.6);

    /* Colors – footer */
    --color-footer-bg: #333;
    --color-footer-text: #ccc;
    --color-footer-link: #fff;
    --color-footer-copy: #ccc;

    /* Colors – accessibility */
    --color-a11y-focus-bg: #f1f1f1;
    --color-a11y-focus-text: #21759b;
}

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

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

body {
    margin: 0;
    font-family: var(--font-family);
    font-weight: var(--font-weight-body);
    font-size: var(--font-size-sm);
    line-height: 1.65;
    color: var(--color-text);
    background: var(--color-bg-muted);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


h1, h2, h3, h4, h5, h6 {
    font-weight: var(--font-weight-heading);
}

h1 {
    font-size: var(--font-size-2xl);
}

h2 {
    font-size: var(--font-size-lg);
}

@media (max-width: 1024px) {
    h1 {
        font-size: var(--font-size-xl);
    }
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: var(--color-primary);
    text-decoration: underline;
}

a:hover,
a:focus {
    text-decoration: none;
}

/* ==========================================================================
   Layout
   ========================================================================== */

.container {
    width: 100%;
    max-width: var(--content-width);
    margin-inline: auto;
    padding-inline: var(--space-4);
}

.site-content {
    padding-block: 0;
}

.site-content > .site-main {
    background: var(--color-bg);
    padding: var(--space-4);
}

/* ==========================================================================
   Hero
   ========================================================================== */

.hero {
    position: relative;
    padding: 4rem 0 6rem;
    overflow: hidden;
}

/* Brand colors: Pink */
.hero--pink-light  { background: #F8CCDC; color: #6C1C3D; --hero-text: #333333; }
.hero--pink-dark   { background: #6C1C3D; color: #F8CCDC; --hero-text: #ffffff; }

/* Brand colors: Green */
.hero--green-light { background: #C0E4F2; color: #03434A; --hero-text: #333333; }
.hero--green-dark  { background: #03434A; color: #C0E4F2; --hero-text: #ffffff; }

/* Brand colors: Violet */
.hero--violet-light { background: #E1D1E8; color: #34274D; --hero-text: #333333; }
.hero--violet-dark  { background: #34274D; color: #E1D1E8; --hero-text: #ffffff; }

/* Legacy fallbacks */
.hero--peach        { background: #F8CCDC; color: #6C1C3D; }
.hero--light-pink   { background: #F8CCDC; color: #6C1C3D; }
.hero--light-green  { background: #C0E4F2; color: #03434A; }
.hero--light-blue   { background: #C0E4F2; color: #03434A; }
.hero--violet       { background: #E1D1E8; color: #34274D; }
.hero--gray         { background: #E1D1E8; color: #34274D; }

.hero__pattern {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    pointer-events: none;
}

.hero__pattern svg {
    height: clamp(180px, 20vw, 280px);
    width: auto;
}

.hero__inner {
    position: relative;
    z-index: 1;
}

.hero__title {
    max-width: 55%;
    margin: 0;
    color: var(--hero-text, #333333);
}

.hero__subtitle {
    max-width: 55%;
    margin: var(--space-2) 0 0;
    font-size: var(--font-size-base);
    color: var(--hero-text, #333333);
}

@media (max-width: 1024px) {
    .hero {
        padding: var(--space-6) 0;
    }

    .hero__title,
    .hero__subtitle {
        max-width: 60%;
    }

}

@media (max-width: 640px) {
    .hero {
        display: flex;
        flex-direction: column;
        padding: var(--space-5) 0 0;
    }

    .hero__pattern {
        position: relative;
        inset: auto;
        align-self: flex-end;
        margin-top: var(--space-3);
    }

    .hero__title,
    .hero__subtitle {
        max-width: 100%;
    }
}

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

.site-header {
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 100;
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding-block: var(--space-3);
}

.site-branding {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.site-branding__logo {
    height: 2.5rem;
    width: auto;
    flex-shrink: 0;
}

.site-branding__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-ui);
    color: var(--color-text);
    line-height: 1.2;
    padding-left: var(--space-3);
    border-left: 1px solid var(--color-border);
}

.site-branding .site-description {
    margin: var(--space-1) 0 0;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

/* ==========================================================================
   Navigation – Desktop
   ========================================================================== */

.main-navigation ul {
    display: flex;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.main-navigation a {
    display: block;
    color: var(--color-text);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-body);
    line-height: 1;
    padding: 0.75rem;
    border: 1px solid transparent;
    text-decoration: none;
    transition: color 0.2s, background-color 0.2s, border-color 0.2s;
}

/* Outlined */
.main-navigation a:hover,
.main-navigation a:focus-visible {
    color: var(--color-primary);
    border-color: var(--color-primary);
    text-decoration: none;
}

.main-navigation a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

/* Filled */
.main-navigation .current-menu-item > a {
    color: var(--color-text-inverse);
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.main-navigation .current-menu-item > a:hover,
.main-navigation .current-menu-item > a:focus-visible {
    color: var(--color-text-inverse);
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

.nav-overlay {
    display: contents;
}

/* ==========================================================================
   Navigation – Hamburger toggle
   ========================================================================== */

.menu-toggle {
    display: none;
    align-items: center;
    gap: var(--space-2);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem 0;
    font-family: inherit;
}

.menu-toggle:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.menu-toggle__label {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-body);
    color: var(--color-text);
}

.menu-toggle__icon {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 24px;
    height: 20px;
}

.menu-toggle__bar {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--color-text);
    border-radius: 1px;
    transition: transform 0.3s ease, opacity 0.3s ease;
    transform-origin: center;
}

.main-navigation.toggled .menu-toggle__bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.main-navigation.toggled .menu-toggle__bar:nth-child(2) {
    opacity: 0;
}

.main-navigation.toggled .menu-toggle__bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* ==========================================================================
   Navigation – Mobile overlay
   ========================================================================== */

@media (max-width: 1024px) {
    .site-header__inner {
        padding-block: var(--space-3);
        padding-inline: var(--space-4);
    }

    .site-branding__title {
        display: none;
    }

    .menu-toggle {
        display: flex;
    }

    .nav-overlay {
        display: flex;
        align-items: center;
        justify-content: center;
        position: fixed;
        inset: 0;
        z-index: 200;
        background: var(--color-bg-overlay);
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.3s ease, visibility 0.3s ease;
    }

    .main-navigation.toggled .nav-overlay {
        opacity: 1;
        visibility: visible;
    }

    .nav-overlay__inner {
        text-align: center;
    }

    .nav-overlay ul {
        flex-direction: column;
        gap: 0;
    }

    .nav-overlay li {
        opacity: 0;
        transform: translateY(12px);
        transition: opacity 0.3s ease, transform 0.3s ease;
    }

    .main-navigation.toggled .nav-overlay li {
        opacity: 1;
        transform: translateY(0);
    }

    .main-navigation.toggled .nav-overlay li:nth-child(1) { transition-delay: 0.1s; }
    .main-navigation.toggled .nav-overlay li:nth-child(2) { transition-delay: 0.15s; }
    .main-navigation.toggled .nav-overlay li:nth-child(3) { transition-delay: 0.2s; }

    .nav-overlay a {
        display: block;
        font-size: var(--font-size-lg);
        font-weight: var(--font-weight-ui);
        padding: var(--space-3) var(--space-4);
    }

    .menu-toggle {
        position: relative;
        z-index: 300;
    }
}

/* ==========================================================================
   News Search
   ========================================================================== */

.news-search {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.news-search__input {
    flex: 1;
    padding: 0.625rem var(--space-3);
    border: 1px solid var(--color-border-input);
    border-radius: 0;
    font-family: inherit;
    font-size: var(--font-size-sm);
    background: var(--color-bg);
    color: var(--color-text);
}

.news-search__input::placeholder {
    color: var(--color-text-muted);
}

.news-search__input:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.news-search__btn {
    padding: 0.625rem var(--space-4);
    border: 1px solid var(--color-primary);
    border-radius: 0;
    background: var(--color-primary);
    color: #fff;
    font-family: inherit;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-ui);
    cursor: pointer;
    white-space: nowrap;
}

.news-search__btn:hover {
    opacity: 0.9;
}

.news-search__btn:focus-visible {
    outline: 2px solid var(--color-text);
    outline-offset: 2px;
}

/* ==========================================================================
   Filter Bar
   ========================================================================== */

.filter-bar {
    margin-bottom: var(--space-5);
}

.filter-bar__fields {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
}

.filter-dropdown {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.filter-dropdown__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.625rem var(--space-3);
    border: 1px solid var(--color-border-input);
    border-radius: 0;
    font-family: inherit;
    font-size: var(--font-size-sm);
    background: var(--color-bg);
    color: var(--color-text);
    cursor: pointer;
    gap: var(--space-2);
    text-align: left;
}

.filter-dropdown__trigger:hover {
    border-color: var(--color-text-muted);
}

.filter-dropdown__trigger:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.filter-dropdown__chevron {
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.filter-dropdown.is-open .filter-dropdown__chevron {
    transform: rotate(180deg);
}

.filter-dropdown__panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 100;
    background: var(--color-bg);
    border: 1px solid var(--color-border-input);
    border-radius: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    max-height: 280px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.filter-dropdown__option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.625rem var(--space-3);
    min-height: 44px;
    cursor: pointer;
    font-size: var(--font-size-sm);
    gap: var(--space-2);
    user-select: none;
}

.filter-dropdown__option:hover,
.filter-dropdown__option:focus-visible {
    background: var(--color-bg-subtle);
}

.filter-dropdown__option:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.filter-dropdown__option-text {
    flex: 1;
    min-width: 0;
}

.filter-dropdown__count {
    color: var(--color-text-muted);
    margin-left: 0.25em;
}

.filter-dropdown__checkbox {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 2px solid var(--color-text-muted);
    border-radius: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.filter-dropdown__checkbox svg {
    opacity: 0;
    transition: opacity 0.15s ease;
}

.filter-dropdown__option[aria-selected="true"] .filter-dropdown__checkbox {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.filter-dropdown__option[aria-selected="true"] .filter-dropdown__checkbox svg {
    opacity: 1;
    color: #fff;
}

.filter-dropdown__option[aria-selected="true"] {
    font-weight: var(--font-weight-ui);
}

.filter-bar__tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

.filter-bar__tags[hidden] {
    display: none;
}

.filter-bar__tag-list {
    display: contents;
    list-style: none;
    margin: 0;
    padding: 0;
}

.filter-bar__tag-list li {
    display: contents;
}

.filter-bar__tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 0.375rem 0.625rem;
    min-height: 36px;
    background: #dbeff8;
    border: 1px solid #dbeff8;
    border-radius: 0;
    font-family: inherit;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    cursor: pointer;
    white-space: nowrap;
}

.filter-bar__tag:hover {
    background: #c5e4f2;
    border-color: #c5e4f2;
}

.filter-bar__tag:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.filter-bar__tag svg {
    flex-shrink: 0;
}

.filter-bar__reset {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 0.375rem 0.625rem;
    min-height: 36px;
    border: none;
    border-radius: 0;
    background: none;
    font-family: inherit;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    cursor: pointer;
    white-space: nowrap;
}

.filter-bar__reset:hover {
    text-decoration: underline;
}

.filter-bar__reset:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.posts-grid[aria-busy="true"] {
    pointer-events: none;
}

@media (max-width: 768px) {
    .filter-bar {
        position: relative;
    }

    .filter-bar__fields {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .filter-dropdown {
        flex: 0 0 auto;
        min-width: 160px;
        position: static;
    }

    .filter-dropdown__panel {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        margin-top: var(--space-2);
        max-height: 50vh;
        z-index: 200;
    }
}

/* ==========================================================================
   Posts Grid
   ========================================================================== */

.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 2rem;
}

/* ==========================================================================
   Post Card
   ========================================================================== */

.post-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg);
    overflow: hidden;
    transition: box-shadow 0.2s;
}

.post-card:hover {
    box-shadow: 0 4px 12px var(--color-shadow-card);
}

.post-card__thumbnail img {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.post-card__body {
    padding: 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.post-card__title {
    font-size: var(--font-size-lg);
    line-height: 1.3;
    margin: 0 0 0.5rem;
}

.post-card__title a {
    color: var(--color-text);
}

.post-card__title a:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.post-card__date {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
}

.post-card__excerpt {
    margin-top: var(--space-2);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.post-card__excerpt p {
    margin: 0;
}

/* ==========================================================================
   Avtalsinformation (Single Post Fields)
   ========================================================================== */

.avtalsinformation {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin: 0 0 var(--space-5);
    padding: var(--space-4);
    background: var(--color-bg-subtle);
    border-radius: 6px;
}

.avtalsinformation__item {
}

.avtalsinformation__item dt {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-ui);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-1);
}

.avtalsinformation__item dd {
    margin: 0;
    font-size: var(--font-size-sm);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.copy-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    border: none;
    background: none;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: 4px;
    transition: color 0.15s, background 0.15s;
}

.copy-btn:hover {
    color: var(--color-text);
    background: var(--color-bg-muted);
}

.copy-btn.copied {
    color: var(--color-text-muted);
}

/* ==========================================================================
   Single / Page Content
   ========================================================================== */

.entry-header {
    margin-bottom: 2rem;
}

.entry-title {
    font-size: var(--font-size-2xl);
    line-height: 1.15;
    margin: 0;
}

@media (max-width: 1024px) {
    .entry-title {
        font-size: var(--font-size-xl);
    }
}

.entry-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.75rem;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.entry-thumbnail {
    margin: 0 0 2rem;
}

.entry-thumbnail img {
    border-radius: 8px;
}

.entry-content {
    max-width: 720px;
}

.entry-content > *:first-child {
    margin-top: 0;
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
    margin-top: 2rem;
}

.entry-content p {
    margin-block: 1.25rem;
}

.entry-content ul {
    background: var(--color-bg-blue);
    border-left: 2.5px solid var(--color-gbg-blue);
    padding: 1.25rem 1.5rem 1.25rem 2.5rem;
    margin-block: 1.25rem;
}

.entry-content ul li {
    padding: 0.25rem 0;
}

.entry-content blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.5rem;
    border-left: 4px solid var(--color-gbg-blue);
    background: var(--color-bg-blue);
}

.entry-footer {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* ==========================================================================
   Page Header (Archives / Search)
   ========================================================================== */

.page-header {
    margin-bottom: 2rem;
}

.page-title {
    font-size: var(--font-size-2xl);
    line-height: 1.15;
    margin: 0;
}

@media (max-width: 1024px) {
    .page-title {
        font-size: var(--font-size-xl);
    }
}

.archive-description {
    margin-top: 0.5rem;
    color: var(--color-text-muted);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.pagination,
.nav-links {
    margin-top: var(--space-6);
    display: flex;
    justify-content: center;
    gap: 0.5rem;
}

.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    height: 2.5rem;
    padding: 0 var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    transition: background 0.15s;
}

.pagination .page-numbers:hover {
    background: var(--color-bg-subtle);
    text-decoration: none;
}

.pagination .page-numbers.current {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-bg);
}

/* ==========================================================================
   Post Navigation (prev/next on single)
   ========================================================================== */

.post-navigation {
    margin-top: var(--space-6);
    padding-top: 2rem;
    border-top: 1px solid var(--color-border);
}

.post-navigation .nav-links {
    display: flex;
    justify-content: space-between;
    gap: 2rem;
}

.post-navigation .nav-subtitle {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-ui);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-light);
    margin-bottom: 0.25rem;
}

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

.widget-area .widget {
    margin-bottom: 2rem;
}

.widget-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-heading);
    margin: 0 0 1rem;
}

/* ==========================================================================
   Single Post
   ========================================================================== */

.single-post {
    background: var(--color-bg-muted);

}

.single-post__inner {
    display: grid;
    grid-template-columns: 1fr 20rem;
    gap: var(--space-3);
    align-items: start;
    padding-top: var(--space-5);
    padding-bottom: var(--space-5);
}

.single-post .entry-content {
    max-width: none;
}


.single-post__header-inner {
    padding: var(--space-5) 0 var(--space-3);
    margin-top: var(--space-5);
}

.single-post__back {
    display: inline-block;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

.single-post__back:hover {
    text-decoration: none;
}

.single-post__back:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.single-post__content {
    background: var(--color-bg);
    padding: var(--space-5);
}

.single-post__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-heading);
    line-height: 1.15;
    margin: 0 0 var(--space-3);
}

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

.single-post__tag {
    padding: 0.2rem 0.625rem;
    border: 1px solid transparent;
    border-radius: 0;
    font-size: var(--font-size-xs);
    line-height: 1.4;
    color: var(--color-text);
}

.single-post__tag--nyhetskategori {
    background: var(--color-complement-green);
}

.single-post__tag--avtalskategori {
    background: var(--color-bg);
    border-color: #e2e2e2;
}

.single-post__tag--malgrupp {
    background: var(--color-bg-blue);
}

.single-post__tag--archived {
    background: #fff;
    border-color: #c0392b;
    color: #c0392b;
    font-weight: var(--font-weight-ui);
}

.single-post__dates {
    display: flex;
    gap: var(--space-4);
    font-size: var(--font-size-xs);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
}

.single-post__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.single-post__sidebar-box {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    padding: var(--space-4);
}

.single-post__sidebar-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-heading);
    margin: 0 0 var(--space-3);
}

.single-post__sidebar-box p {
    margin: 0 0 var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--color-text);
}

.single-post__sidebar-box p:last-child {
    margin-bottom: 0;
}

.single-post__sidebar-label {
    display: block;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    font-weight: var(--font-weight-ui);
}

.single-post__related {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.single-post__related a {
    display: block;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

.single-post__related a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.single-post__related time {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text);
    margin-top: 0.125rem;
}

@media (max-width: 768px) {
    .single-post__inner {
        grid-template-columns: 1fr;
    }

    .single-post__title {
        font-size: var(--font-size-xl);
    }

    .single-post__dates {
        flex-direction: column;
        gap: 0;
    }

    .single-post__sidebar {
        order: 2;
    }
}

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

.search-form {
    display: flex;
    max-width: 480px;
}

.search-form label {
    flex: 1;
}

.search-field {
    width: 100%;
    padding: 0.625rem 1rem;
    border: 1px solid var(--color-border-input);
    border-right: none;
    border-radius: 6px 0 0 6px;
    font-size: var(--font-size-base);
    transition: border-color 0.2s;
}

.search-field:focus-visible {
    border-color: var(--color-primary);
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.search-submit:focus-visible {
    outline: 2px solid var(--color-text);
    outline-offset: 2px;
}

.search-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1rem;
    background: var(--color-primary);
    color: var(--color-bg);
    border: 1px solid var(--color-primary);
    border-radius: 0 6px 6px 0;
    cursor: pointer;
    transition: background 0.2s;
}

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

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

.comments-area {
    margin-top: var(--space-6);
    padding-top: 2rem;
    border-top: 1px solid var(--color-border);
}

.comment-list {
    list-style: none;
    padding: 0;
}

.comment-list .comment {
    padding: 1rem 0;
    border-bottom: 1px solid var(--color-border-light);
}

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

.site-footer {
    padding-block: var(--space-5);
    background: var(--color-footer-bg);
    color: #fff;
    line-height: 1.65;
}

.site-footer a {
    color: var(--color-footer-link);
}

.site-footer a:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}

.site-footer__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.site-footer__columns {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
}

.site-footer__columns > .widget {
    margin: 0;
}

.site-footer__columns a {
    color: var(--color-footer-link);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.15em;
}

.site-footer__columns .textwidget,
.site-footer__columns .textwidget div {
    line-height: 1.65;
}

.site-footer__columns .textwidget strong:not(.title) {
    font-weight: var(--font-weight-ui);
}

.site-footer__columns ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer__columns li {
    padding: 0;
}

.site-footer__columns a.footer__link {
    text-decoration: none;
}

.site-footer__columns .widget-title {
    margin-bottom: var(--space-4);
}

.site-footer address {
    font-style: normal;
}

.site-footer .footer__logo {
    display: inline-block;
    margin-bottom: var(--space-2);
}

.site-footer__columns a:hover,
.site-footer__columns a:focus {
    color: var(--color-footer-text);
}

.site-footer__columns a.footer__link:hover,
.site-footer__columns a.footer__link:focus {
    text-decoration: underline;
}

#footer-menu {
    display: flex;
    list-style: none;
    gap: var(--space-4);
    margin: 0;
    padding: 0;
    font-size: var(--font-size-sm);
}


@media (max-width: 768px) {
    .site-footer__columns {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
}

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

.error-404 {
    text-align: center;
    padding-block: 4rem;
}

.error-404 .page-content {
    max-width: 480px;
    margin-inline: auto;
}

.error-404 .search-form {
    margin-inline: auto;
    margin-top: 1.5rem;
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

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

.screen-reader-text:focus {
    background: var(--color-a11y-focus-bg);
    border-radius: 3px;
    box-shadow: 0 0 2px 2px var(--color-shadow-a11y);
    clip: auto !important;
    clip-path: none;
    color: var(--color-a11y-focus-text);
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-ui);
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 0.75rem 1.5rem;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

.skip-link:focus {
    position: fixed;
    top: 0.5rem;
    left: 0.5rem;
    z-index: 999;
    padding: 0.75rem 1rem;
    background: var(--color-primary);
    color: var(--color-bg);
    border-radius: 4px;
}

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

.alignwide {
    max-width: 1100px;
    margin-inline: auto;
}

.alignfull {
    max-width: none;
    margin-inline: calc(-50vw + 50%);
    width: 100vw;
}

.alignleft {
    float: left;
    margin: 0.5rem 1.5rem 1rem 0;
}

.alignright {
    float: right;
    margin: 0.5rem 0 1rem 1.5rem;
}

.aligncenter {
    display: block;
    margin-inline: auto;
}

/* ==========================================================================
   WordPress Block Styles
   ========================================================================== */

.wp-block-image figcaption {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-align: center;
    margin-top: 0.5rem;
}

/* ==========================================================================
   Global Focus Styles
   ========================================================================== */

:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

:focus:not(:focus-visible) {
    outline: none;
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

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

/* ==========================================================================
   News Grid
   ========================================================================== */

.news-grid {
    background: var(--color-bg-muted);
}

.news-grid__inner {
    max-width: var(--content-width);
    margin-inline: auto;
}

.news-grid__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.news-grid__views { display: flex; }

.news-grid__view-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 0.5rem 0.875rem;
    border: 1px solid var(--color-border);
    background: var(--color-bg);
    font-family: inherit;
    font-size: var(--font-size-sm);
    font-weight: normal;
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.news-grid__view-btn:first-child { border-radius: 0; }
.news-grid__view-btn:last-child  { border-radius: 0; border-left: 0; }

.news-grid__view-btn--active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.news-grid__view-btn:hover:not(.news-grid__view-btn--active) {
    background: var(--color-bg-subtle);
}

.news-grid__view-btn:focus-visible,
.news-grid__sort:focus-visible,
.news-grid__load-more:focus-visible,
.news-card__title a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.news-grid__view-btn--active:focus-visible {
    outline-color: var(--color-text);
}

.news-grid__meta {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-left: auto;
}

.news-grid__count {
    font-size: var(--font-size-xs);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.news-grid__sort {
    padding: 0.625rem var(--space-3);
    padding-right: 2.25rem;
    border: 1px solid var(--color-border-input);
    border-radius: 0;
    font-family: inherit;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    background: var(--color-bg);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23333' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    cursor: pointer;
}

.news-grid__cards--grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

.news-grid__cards--list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.news-grid__cards--list .news-card__excerpt { display: none; }

.news-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 0;
    padding: var(--space-4);
    position: relative;
}

.news-card h3 { margin: 0 0 0.25rem; }
.news-card p  { margin: 0.25rem 0 0; }

.news-card__dates {
    display: flex;
    gap: var(--space-3);
    font-size: var(--font-size-xs);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.news-card__title a {
    color: var(--color-text);
    text-decoration: underline;
}

.news-card__title a::after {
    content: "";
    position: absolute;
    inset: 0;
}

.news-card:hover {
    border-color: var(--color-text);
}

.news-card:hover .news-card__title a {
    text-decoration: none;
}

.news-card__excerpt {
    font-size: var(--font-size-sm);
    color: var(--color-text);
    line-height: 1.55;
    flex: 1;
}

.news-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-3);
    list-style: none;
    padding: 0;
}

.news-grid__cards--list .news-card__tags { margin-top: var(--space-2); }

.news-card__tag {
    padding: 0.2rem 0.625rem;
    border: 1px solid transparent;
    border-radius: 0;
    font-size: var(--font-size-xs);
    line-height: 1.4;
    color: var(--color-text);
    position: relative;
}

.news-card__tag--nyhetskategori {
    background: var(--color-complement-green);
}

.news-card__tag--avtalskategori {
    background: var(--color-bg);
    border-color: #e2e2e2;
}

.news-card__tag--malgrupp {
    background: var(--color-bg-blue);
}

.news-card__tag--archived {
    background: #E2E2E2;
    border: none;
    color: var(--color-text);
}

.news-card--archived {
    background: #fafafa;
}

.news-grid__footer {
    display: flex;
    justify-content: center;
    margin-top: var(--space-5);
}

.news-grid__load-more {
    padding: 0.625rem 2rem;
    border: 1px solid var(--color-text);
    border-radius: 0;
    background: transparent;
    font: var(--font-weight-body) var(--font-size-sm) var(--font-family);
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.news-grid__load-more:hover {
    background: var(--color-text);
    color: var(--color-text-inverse);
}

.news-grid__empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--space-6);
    color: var(--color-text-muted);
}

@media (max-width: 768px) {
    .news-grid__cards--grid { grid-template-columns: 1fr; }

    .news-grid__cards--grid .news-card {
        min-height: 14rem;
        justify-content: space-between;
    }

    .news-card__dates {
        flex-direction: column;
        gap: 0;
    }

    .news-grid__cards--list { gap: var(--space-3); }
    .news-grid__cards--list .news-card { padding: var(--space-3); }

    .news-grid__view-btn {
        padding: 0.5rem;
    }

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

    .news-grid__view-btn svg {
        font-size: 1rem;
    }
}

/* ==========================================================================
   Hitta avtal
   ========================================================================== */

.hitta-avtal {
    background: var(--color-bg-muted);
    padding: var(--space-5) 0 var(--space-6);
}

.hitta-avtal__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.hitta-avtal__callout {
    background: var(--color-bg-blue);
    border-radius: 0.25rem;
    padding: var(--space-5);
}

.hitta-avtal__callout-title {
    margin: 0 0 var(--space-2);
}

.hitta-avtal__callout p {
    margin: 0 0 var(--space-3);
}

.hitta-avtal__callout-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: var(--font-weight-ui);
    color: var(--color-primary);
}

.hitta-avtal__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

a.hitta-avtal__card,
a.hitta-avtal__card:hover,
a.hitta-avtal__card:focus {
    display: block;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    padding: var(--space-4);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

a.hitta-avtal__card:hover {
    border-color: var(--color-primary);
}

a.hitta-avtal__card:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.hitta-avtal__card-title {
    margin: 0 0 var(--space-2);
    text-decoration: underline;
    color: var(--color-text);
}

.hitta-avtal__card p {
    margin: 0;
    color: var(--color-text);
}

@media (max-width: 768px) {
    .hitta-avtal__cards {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Breadcrumb
   ========================================================================== */

.breadcrumb {
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-xs);
}

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

.breadcrumb__item:not(:last-child)::after {
    content: "/";
    margin-left: var(--space-1);
    color: var(--color-text-light);
}

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

.breadcrumb__current {
    color: var(--color-text);
}

/* ==========================================================================
   Avtal Page (child pages with sidebar)
   ========================================================================== */

.avtal-page {
    background: var(--color-bg-muted);
    padding-bottom: var(--space-6);
}

.avtal-page__inner {
    display: grid;
    grid-template-columns: 1fr 20rem;
    gap: var(--space-4);
    align-items: start;
    padding-top: var(--space-5);
}

.avtal-page__main {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.avtal-page__callout {
    background: var(--color-bg-blue);
    border-left: 4px solid var(--color-gbg-blue);
    border-radius: 0.25rem;
    padding: var(--space-4);
}

.avtal-page__callout p {
    margin: 0;
    line-height: 1.55;
}

.avtal-page__content {
    background: var(--color-bg);
    padding: var(--space-5);
}

.avtal-page .entry-content {
    max-width: none;
}

.avtal-page .entry-content a[target="_blank"]::after {
    content: "";
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-left: 0.3em;
    vertical-align: middle;
    background: var(--color-text);
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");
    mask-size: contain;
    mask-repeat: no-repeat;
}

.avtal-page__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.avtal-page__sidebar-box {
    background: var(--color-bg-blue);
    padding: var(--space-4);
}

.avtal-page__sidebar-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-heading);
    margin: 0 0 var(--space-3);
}

.avtal-page__sidebar-box p {
    margin: 0 0 var(--space-2);
    font-size: var(--font-size-sm);
    line-height: 1.55;
}

.avtal-page__sidebar-box p:last-child {
    margin-bottom: 0;
}

.avtal-page__sidebar-box a {
    color: var(--color-primary);
}

.avtal-page__sidebar-text {
    margin: 0 0 var(--space-3);
}

.avtal-page__sidebar-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.avtal-page__sidebar-links a {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

.avtal-page__sidebar-file-info {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

@media (max-width: 768px) {
    .avtal-page__inner {
        grid-template-columns: 1fr;
    }

    .avtal-page__sidebar {
        order: 2;
    }
}

/* ==========================================================================
   Contact Card (reusable bottom card)
   ========================================================================== */

.contact-card {
    background: var(--color-bg-blue);
    border-radius: 0.25rem;
    padding: var(--space-5);
    margin-top: var(--space-4);
}

.contact-card__content h2 {
    font-size: var(--font-size-lg);
    margin: var(--space-5) 0 var(--space-2);
}

.contact-card__content > *:first-child,
.contact-card__content h2:first-child {
    margin-top: 0;
}

.contact-card__content p {
    margin: 0 0 var(--space-2);
    line-height: 1.55;
}

.contact-card__content p:last-child {
    margin-bottom: 0;
}

.contact-card__content a {
    color: var(--color-primary);
}

.contact-card__content a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ==========================================================================
   Page Sidebar (reusable)
   ========================================================================== */

.page-sidebar {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.page-sidebar__box {
    background: var(--color-bg-blue);
    padding: var(--space-4);
}

.page-sidebar__box:not(:last-child) {
    padding-bottom: 0;
}

.page-sidebar__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-heading);
    margin: 0 0 var(--space-3);
}

.page-sidebar__box p {
    margin: 0 0 var(--space-2);
    font-size: var(--font-size-sm);
    line-height: 1.55;
}

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

.page-sidebar__box a {
    color: var(--color-primary);
}

.page-sidebar__text {
    margin: 0 0 var(--space-3);
}

.page-sidebar__links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.page-sidebar__links a {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
}

.page-sidebar__links a:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.page-sidebar__file-info {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

.wp-block-file {
    font-size: var(--font-size-base);
}

.page-sidebar__link--excel,
.newsletter-boxes__link--excel,
a.excel-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.excel-icon {
    flex-shrink: 0;
    color: #1d6f42;
}

.link-file-label {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    font-weight: normal;
}

/* ==========================================================================
   Stöd och guider (parent page)
   ========================================================================== */

.stod-page {
    background: var(--color-bg-muted);
    padding: var(--space-5) 0 var(--space-6);
}

.stod-page__inner {
    display: flex;
    flex-direction: column;
}

.stod-page__grid {
    display: grid;
    grid-template-columns: 1fr 20rem;
    gap: var(--space-4);
    align-items: start;
}

.stod-page__grid--full {
    grid-template-columns: 1fr;
}

.stod-page__main {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.stod-page__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

a.stod-page__card,
a.stod-page__card:hover,
a.stod-page__card:focus {
    display: block;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    padding: var(--space-4);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

a.stod-page__card:hover {
    border-color: var(--color-primary);
}

a.stod-page__card:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.stod-page__card-title {
    margin: 0 0 var(--space-2);
    text-decoration: underline;
    color: var(--color-text);
}

.stod-page__card p {
    margin: 0;
    color: var(--color-text);
}

.stod-page__callout {
    background: var(--color-bg-blue);
    border-left: 4px solid var(--color-gbg-blue);
    border-radius: 0.25rem;
    padding: var(--space-4);
}

.stod-page__callout p {
    margin: 0;
    line-height: 1.55;
}

.stod-page__content {
    background: var(--color-bg);
    padding: var(--space-5);
}

.stod-page .entry-content {
    max-width: none;
}

@media (max-width: 768px) {
    .stod-page__grid {
        grid-template-columns: 1fr;
    }

    .stod-page__cards {
        grid-template-columns: 1fr;
    }

    .stod-page .page-sidebar {
        order: 2;
    }
}

/* ==========================================================================
   Page with Sidebar (generic, used by page.php)
   ========================================================================== */

.page-with-sidebar {
    background: var(--color-bg-muted);
    padding-bottom: var(--space-6);
}

.page-with-sidebar__grid {
    display: grid;
    grid-template-columns: 1fr 20rem;
    gap: var(--space-4);
    align-items: start;
    padding-top: var(--space-5);
}

.page-with-sidebar__main {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-top: var(--space-5);
}

.page-with-sidebar__grid .page-with-sidebar__main {
    padding-top: 0;
}

.page-with-sidebar__callout {
    background: var(--color-bg-blue);
    border-left: 4px solid var(--color-gbg-blue);
    border-radius: 0.25rem;
    padding: var(--space-4);
    line-height: 1.55;
}

.page-with-sidebar__callout > *:first-child {
    margin-top: 0;
}

.page-with-sidebar__callout > *:last-child {
    margin-bottom: 0;
}

.page-with-sidebar__callout p {
    margin: 0 0 var(--space-2);
}

.page-with-sidebar__callout a {
    color: var(--color-primary);
}

.page-with-sidebar__content {
    background: var(--color-bg);
    padding: var(--space-5);
}

.page-with-sidebar .entry-content {
    max-width: none;
}

@media (max-width: 768px) {
    .page-with-sidebar__grid {
        grid-template-columns: 1fr;
    }

    .page-with-sidebar .page-sidebar {
        order: 2;
    }
}

/* ==========================================================================
   Child Cards (reusable)
   ========================================================================== */

.child-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

a.child-cards__card,
a.child-cards__card:hover,
a.child-cards__card:focus {
    display: block;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    padding: var(--space-4);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

a.child-cards__card:hover {
    border-color: var(--color-primary);
}

a.child-cards__card:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.child-cards__title {
    margin: 0 0 var(--space-2);
    text-decoration: underline;
    color: var(--color-text);
}

.child-cards__card p {
    margin: 0;
    color: var(--color-text);
}

@media (max-width: 768px) {
    .child-cards {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Newsletter / Subscription Boxes
   ========================================================================== */

.newsletter-boxes {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.newsletter-boxes__card {
    padding: var(--space-5);
    border-radius: 0.25rem;
    display: flex;
    flex-direction: column;
}

.newsletter-boxes__title {
    margin: 0 0 var(--space-2);
    font-size: var(--font-size-lg);
}

.newsletter-boxes__text {
    margin: 0 0 var(--space-3);
    flex: 1;
}

.newsletter-boxes__links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.newsletter-boxes__link {
    color: var(--color-primary);
    font-weight: var(--font-weight-ui);
    text-decoration: none;
}

.newsletter-boxes__link:hover {
    text-decoration: underline;
}

@media (max-width: 768px) {
    .newsletter-boxes {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Copy Button & Tooltip
   ========================================================================== */

.copy-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    padding: 0.25rem;
    margin-left: 0.25rem;
    cursor: pointer;
    color: var(--color-text-muted);
    border-radius: 0.25rem;
    transition: color 0.15s;
    vertical-align: middle;
}

.copy-btn:hover {
    color: var(--color-primary);
}

.copy-btn__icon-check {
    display: none;
}

.copy-btn.copied .copy-btn__icon-copy {
    display: none;
}

.copy-btn.copied .copy-btn__icon-check {
    display: block;
    color: var(--color-primary);
}

.copy-btn__tooltip {
    position: absolute;
    bottom: calc(100% + 0.5rem);
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-footer-bg);
    color: var(--color-text-inverse);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-body);
    white-space: nowrap;
    padding: 0.3rem 0.6rem;
    border-radius: 0.25rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s;
}

.copy-btn__tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--color-footer-bg);
}

.copy-btn:hover .copy-btn__tooltip,
.copy-btn:focus-visible .copy-btn__tooltip,
.copy-btn.copied .copy-btn__tooltip {
    opacity: 1;
}
