/**
 * Arkivlexikon CSS
 *
 * Färgsystem följer kaskaden:
 *   1. --al-* (egna override-variabler)
 *   2. --accent, --contrast, --base, --base-2, --base-3 (GeneratePress)
 *   3. Neutrala fallbacks
 *
 * Varje kategori har egen accent som overridas via .al-cat-{slug}-klass.
 */

.arkivlexikon {
    /* Default-variabler (overridable per kategori) */
    --al-accent:           var(--gp-search-accent, var(--accent, #6b1f3a));
    --al-accent-soft:      color-mix(in srgb, var(--al-accent) 14%, transparent);
    --al-text:             var(--contrast, #1a1a1a);
    --al-text-soft:        var(--contrast-2, #555);
    --al-bg:               var(--base, #fff);
    --al-bg-soft:          var(--base-2, #f7f5f1);
    --al-bg-soft-2:        var(--base-3, #efeae0);
    --al-border:           color-mix(in srgb, var(--al-accent) 18%, var(--al-bg-soft-2));
    --al-radius:           6px;
    --al-radius-sm:        4px;
    --al-shadow:           0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --al-shadow-hover:     0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.05);
    --al-font-serif:       Georgia, "Times New Roman", serif;
    --al-font-sans:        -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

    max-width: 880px;
    margin: 0 auto;
    color: var(--al-text);
    font-family: inherit;
}

/* Kategori-specifika accent-overrides */
.al-cat-yrken          { --al-accent: #8b5a3c; }
.al-cat-datum          { --al-accent: #7c4a8c; }
.al-cat-matt           { --al-accent: #4a7c5a; }
.al-cat-forkortningar  { --al-accent: #3a5fa8; }
.al-cat-latin          { --al-accent: #a83a5f; }
.al-cat-slakt          { --al-accent: #3a7c8c; }
.al-cat-sjukdomar      { --al-accent: #8c3a3a; }
.al-cat-fraser         { --al-accent: #6a5a4c; }
.al-cat-begrepp        { --al-accent: #5a3a7c; }

/* ============================================================
 * HEADER & TYPOGRAFI
 * ============================================================ */

.arkivlexikon .al-header {
    margin: 0 0 2rem;
    padding: 0 0 1.5rem;
    border-bottom: 1px solid var(--al-border);
}
.arkivlexikon .al-header h1 {
    font-family: var(--al-font-serif);
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    margin: 0 0 .5rem;
    color: var(--al-text);
    line-height: 1.2;
}
.arkivlexikon .al-lead {
    font-size: 1.1em;
    color: var(--al-text-soft);
    margin: 0;
    line-height: 1.55;
}
.arkivlexikon .al-meta {
    font-size: .9em;
    color: var(--al-text-soft);
    margin: .5rem 0 0;
}

/* ============================================================
 * BREADCRUMB
 * ============================================================ */

.arkivlexikon .al-breadcrumb {
    font-size: .9em;
    color: var(--al-text-soft);
    margin: 0 0 1.5rem;
}
.arkivlexikon .al-breadcrumb a {
    color: var(--al-accent);
    text-decoration: none;
}
.arkivlexikon .al-breadcrumb a:hover {
    text-decoration: underline;
}
.arkivlexikon .al-breadcrumb span[aria-hidden] {
    margin: 0 .4em;
    opacity: .5;
}

/* ============================================================
 * SÖKRUTA + LIVE-RESULTAT
 * ============================================================ */

.arkivlexikon .al-search-wrap,
.arkivlexikon-inline .al-search-wrap {
    position: relative;
    margin: 0 0 2rem;
}
.arkivlexikon .al-search,
.arkivlexikon-inline .al-search {
    width: 100%;
    padding: .75rem 1rem .75rem 2.75rem;
    font-size: 1.05em;
    line-height: 1.4;
    border: 2px solid var(--al-border);
    border-radius: var(--al-radius);
    background: var(--al-bg);
    color: var(--al-text);
    transition: border-color .15s, box-shadow .15s;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: .75rem center;
    background-size: 1.1em;
}
.arkivlexikon .al-search:focus,
.arkivlexikon-inline .al-search:focus {
    outline: none;
    border-color: var(--al-accent);
    box-shadow: 0 0 0 3px var(--al-accent-soft);
}
.arkivlexikon .al-search-results,
.arkivlexikon-inline .al-search-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    margin-top: 4px;
    background: var(--al-bg);
    border: 1px solid var(--al-border);
    border-radius: var(--al-radius);
    box-shadow: var(--al-shadow-hover);
    max-height: 60vh;
    overflow-y: auto;
    z-index: 100;
}
.arkivlexikon .al-search-results .al-result,
.arkivlexikon-inline .al-search-results .al-result {
    display: block;
    padding: .8rem 1rem;
    text-decoration: none;
    color: var(--al-text);
    border-bottom: 1px solid var(--al-bg-soft-2);
    transition: background .12s;
}
.arkivlexikon .al-search-results .al-result:last-child,
.arkivlexikon-inline .al-search-results .al-result:last-child {
    border-bottom: none;
}
.arkivlexikon .al-search-results .al-result:hover,
.arkivlexikon .al-search-results .al-result.is-active,
.arkivlexikon-inline .al-search-results .al-result:hover,
.arkivlexikon-inline .al-search-results .al-result.is-active {
    background: var(--al-bg-soft);
}
.al-result-name {
    font-weight: 600;
    color: var(--al-text);
    display: block;
    margin-bottom: .15rem;
}
.al-result-name mark {
    background: var(--al-accent-soft);
    color: var(--al-text);
    padding: 0 .15em;
    border-radius: 2px;
}
.al-result-meta {
    font-size: .8em;
    color: var(--al-text-soft);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-left: .5em;
}
.al-result-short {
    font-size: .9em;
    color: var(--al-text-soft);
    line-height: 1.4;
    margin: 0;
}
.al-no-results {
    padding: 1rem;
    color: var(--al-text-soft);
    text-align: center;
    font-style: italic;
}

/* ============================================================
 * KATEGORI-KORT (huvudsida)
 * ============================================================ */

.al-categories h2 {
    font-family: var(--al-font-serif);
    font-size: 1.5em;
    margin: 0 0 1rem;
    color: var(--al-text);
}
.al-cat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
    margin: 0 0 3rem;
}
.al-cat-card {
    display: block;
    padding: 1.25rem;
    background: var(--al-bg);
    border: 1px solid var(--al-border);
    border-top: 4px solid var(--al-accent);
    border-radius: var(--al-radius);
    text-decoration: none;
    color: var(--al-text);
    transition: transform .15s, box-shadow .15s, border-color .15s;
    box-shadow: var(--al-shadow);
}
.al-cat-card:hover,
.al-cat-card:focus {
    transform: translateY(-2px);
    box-shadow: var(--al-shadow-hover);
    text-decoration: none;
}
.al-cat-card h3 {
    font-family: var(--al-font-serif);
    font-size: 1.15em;
    margin: 0 0 .35rem;
    color: var(--al-accent);
}
.al-cat-card p {
    font-size: .9em;
    color: var(--al-text-soft);
    line-height: 1.45;
    margin: 0 0 .75rem;
}
.al-cat-count {
    font-size: .8em;
    color: var(--al-text-soft);
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
}

/* ============================================================
 * A-Ö-LISTA
 * ============================================================ */

.al-alphabetical h2 {
    font-family: var(--al-font-serif);
    font-size: 1.5em;
    margin: 0 0 1rem;
    color: var(--al-text);
}
.al-jump-nav {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    padding: .75rem;
    background: var(--al-bg-soft);
    border-radius: var(--al-radius);
    margin: 0 0 2rem;
    position: sticky;
    top: 0;
    z-index: 5;
}
.al-jump-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.8em;
    height: 1.8em;
    padding: 0 .35em;
    font-weight: 600;
    font-size: .9em;
    color: var(--al-accent);
    background: var(--al-bg);
    border: 1px solid var(--al-border);
    border-radius: var(--al-radius-sm);
    text-decoration: none;
    transition: background .12s, color .12s;
}
.al-jump-nav a:hover {
    background: var(--al-accent);
    color: var(--al-bg);
}
.al-letter-group {
    margin: 0 0 2rem;
    scroll-margin-top: 4rem;
}
.al-letter {
    font-family: var(--al-font-serif);
    font-size: 1.8em;
    color: var(--al-accent);
    margin: 0 0 .5rem;
    border-bottom: 2px solid var(--al-border);
    padding-bottom: .25rem;
}
.al-term-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: .25rem;
}
.al-term-list > li {
    padding: .75rem;
    background: var(--al-bg);
    border: 1px solid var(--al-bg-soft-2);
    border-radius: var(--al-radius-sm);
    transition: border-color .12s, background .12s;
}
.al-term-list > li:hover {
    border-color: var(--al-border);
    background: var(--al-bg-soft);
}
.al-term-list > li > a {
    text-decoration: none;
    color: var(--al-text);
    display: flex;
    align-items: baseline;
    gap: .5em;
    margin-bottom: .15rem;
}
.al-term-list > li > a strong {
    color: var(--al-accent);
    font-family: var(--al-font-serif);
    font-size: 1.05em;
}
.al-term-cat {
    font-size: .75em;
    color: var(--al-text-soft);
    text-transform: uppercase;
    letter-spacing: .04em;
    background: var(--al-bg-soft-2);
    padding: 0 .5em;
    border-radius: 999px;
    line-height: 1.6;
}
.al-term-short {
    display: block;
    font-size: .9em;
    color: var(--al-text-soft);
    line-height: 1.45;
}

/* ============================================================
 * TERM-SIDA
 * ============================================================ */

.arkivlexikon-term .al-term-header {
    margin: 0 0 2rem;
    padding: 0 0 1.5rem;
    border-bottom: 1px solid var(--al-border);
}
.arkivlexikon-term .al-term-header h1 {
    font-family: var(--al-font-serif);
    font-size: clamp(2rem, 5vw, 2.8rem);
    margin: 0 0 .75rem;
    color: var(--al-text);
    line-height: 1.1;
}
.al-term-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.al-term-cat-pill {
    display: inline-block;
    background: var(--al-accent);
    color: var(--al-bg);
    padding: .25em .75em;
    border-radius: 999px;
    font-size: .85em;
    font-weight: 600;
}
.al-term-cat-pill a {
    color: inherit;
    text-decoration: none;
}
.al-term-period,
.al-term-doctype {
    font-size: .9em;
    color: var(--al-text-soft);
    background: var(--al-bg-soft);
    padding: .25em .75em;
    border-radius: var(--al-radius-sm);
}
.arkivlexikon-term .al-term-content {
    font-size: 1.05em;
    line-height: 1.65;
}
.arkivlexikon-term .al-term-content .al-term-short {
    font-size: 1.15em;
    font-weight: 500;
    color: var(--al-text);
    margin: 0 0 1.5rem;
    padding: 0 0 0 1rem;
    border-left: 3px solid var(--al-accent);
    line-height: 1.5;
}
.arkivlexikon-term .al-term-long p {
    margin: 0 0 1em;
}
.arkivlexikon-term .al-term-modern {
    background: var(--al-bg-soft);
    border-left: 4px solid var(--al-accent);
    padding: 1rem 1.25rem;
    margin: 1.5rem 0;
    border-radius: 0 var(--al-radius-sm) var(--al-radius-sm) 0;
}
.arkivlexikon-term .al-term-modern h2 {
    font-family: var(--al-font-serif);
    font-size: 1em;
    margin: 0 0 .25rem;
    color: var(--al-accent);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.arkivlexikon-term .al-term-modern p {
    margin: 0;
}
.arkivlexikon-term .al-term-example {
    background: var(--al-bg-soft-2);
    border-radius: var(--al-radius);
    padding: 1rem 1.25rem;
    margin: 1.5rem 0;
}
.arkivlexikon-term .al-term-example h2 {
    font-family: var(--al-font-serif);
    font-size: 1em;
    margin: 0 0 .5rem;
    color: var(--al-text-soft);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.arkivlexikon-term .al-term-example p {
    font-style: italic;
    color: var(--al-text);
    margin: 0;
}
.arkivlexikon-term .al-term-related {
    margin: 2rem 0 1rem;
    padding: 1.5rem 0 0;
    border-top: 1px solid var(--al-border);
}
.arkivlexikon-term .al-term-related h2 {
    font-family: var(--al-font-serif);
    font-size: 1.2em;
    margin: 0 0 1rem;
    color: var(--al-text);
}
.arkivlexikon-term .al-term-related ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: .5rem;
}
.arkivlexikon-term .al-term-related li a {
    display: block;
    padding: .75rem .9rem;
    background: var(--al-bg);
    border: 1px solid var(--al-bg-soft-2);
    border-radius: var(--al-radius-sm);
    text-decoration: none;
    color: var(--al-text);
    transition: border-color .12s, background .12s;
}
.arkivlexikon-term .al-term-related li a:hover {
    border-color: var(--al-accent);
    background: var(--al-bg-soft);
}
.arkivlexikon-term .al-term-related li a strong {
    display: block;
    color: var(--al-accent);
    font-family: var(--al-font-serif);
    margin-bottom: .15rem;
}
.arkivlexikon-term .al-term-related li a span {
    display: block;
    font-size: .85em;
    color: var(--al-text-soft);
    line-height: 1.4;
}
.al-term-footer {
    margin: 2rem 0 0;
    padding: 1.5rem 0 0;
    border-top: 1px solid var(--al-border);
}
.al-back-link {
    color: var(--al-accent);
    text-decoration: none;
    font-weight: 500;
}
.al-back-link:hover {
    text-decoration: underline;
}

/* ============================================================
 * PÅSK-KALKYLATOR
 * ============================================================ */

.al-easter-calc {
    background: var(--al-bg-soft);
    border: 1px solid var(--al-border);
    border-radius: var(--al-radius);
    padding: 1.5rem;
    margin: 0 0 2rem;
}
.al-easter-calc h2 {
    font-family: var(--al-font-serif);
    font-size: 1.3em;
    margin: 0 0 .5rem;
    color: var(--al-text);
}
.al-easter-calc p {
    margin: 0 0 1rem;
    color: var(--al-text-soft);
    line-height: 1.55;
}
.al-easter-input {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
    margin: 0 0 1rem;
}
.al-easter-input label {
    font-weight: 600;
    color: var(--al-text);
}
.al-easter-input input[type="number"] {
    padding: .5rem .75rem;
    font-size: 1.05em;
    border: 1px solid var(--al-border);
    border-radius: var(--al-radius-sm);
    background: var(--al-bg);
    color: var(--al-text);
    width: 9ch;
}
.al-easter-input input[type="number"]:focus {
    outline: none;
    border-color: var(--al-accent);
    box-shadow: 0 0 0 2px var(--al-accent-soft);
}
.al-easter-input button {
    padding: .5rem 1.25rem;
    font-size: 1em;
    font-weight: 600;
    background: var(--al-accent);
    color: #fff;
    border: none;
    border-radius: var(--al-radius-sm);
    cursor: pointer;
    transition: filter .12s;
}
.al-easter-input button:hover {
    filter: brightness(0.92);
}
.al-easter-output {
    background: var(--al-bg);
    border: 1px solid var(--al-bg-soft-2);
    border-radius: var(--al-radius-sm);
    padding: 1rem;
    min-height: 2em;
}
.al-easter-output:empty {
    display: none;
}
.al-easter-output table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}
.al-easter-output th,
.al-easter-output td {
    text-align: left;
    padding: .35rem .5rem;
    border-bottom: 1px solid var(--al-bg-soft-2);
    font-size: .95em;
}
.al-easter-output th {
    background: var(--al-bg-soft);
    color: var(--al-text-soft);
    font-weight: 600;
    font-size: .85em;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.al-easter-output tr:last-child td {
    border-bottom: none;
}

/* ============================================================
 * SHORTCODE INLINE-VARIANTER
 * ============================================================ */

.arkivlexikon-inline {
    max-width: 100%;
    margin: 1.5em 0;
    background: var(--al-bg);
    border: 1px solid var(--al-border);
    border-left: 4px solid var(--al-accent);
    border-radius: 0 var(--al-radius) var(--al-radius) 0;
    padding: 1rem 1.25rem;
    box-shadow: var(--al-shadow);
}
.arkivlexikon-inline h3 {
    font-family: var(--al-font-serif);
    font-size: 1.15em;
    margin: 0 0 .35rem;
    color: var(--al-accent);
}
.arkivlexikon-inline h3 a {
    color: inherit;
    text-decoration: none;
}
.arkivlexikon-inline h3 a:hover {
    text-decoration: underline;
}
.arkivlexikon-inline .al-inline-name a:hover {
    text-decoration: underline;
}
.arkivlexikon-inline .al-inline-period {
    font-size: .85em;
    color: var(--al-text-soft);
    margin: 0 0 .5rem;
    font-style: italic;
}
.arkivlexikon-inline .al-inline-short {
    margin: 0 0 .75rem;
    color: var(--al-text);
    line-height: 1.5;
}
.arkivlexikon-inline .al-inline-link {
    margin: 0;
    font-size: .9em;
}
.arkivlexikon-inline .al-inline-link a {
    color: var(--al-accent);
    text-decoration: none;
    font-weight: 600;
}
.arkivlexikon-inline .al-inline-link a:hover {
    text-decoration: underline;
}
.arkivlexikon-inline .al-inline-list {
    list-style: none;
    padding: 0;
    margin: 0 0 .75rem;
}
.arkivlexikon-inline .al-inline-list li {
    padding: .35rem 0;
    border-bottom: 1px solid var(--al-bg-soft-2);
}
.arkivlexikon-inline .al-inline-list li:last-child {
    border-bottom: none;
}
.arkivlexikon-inline .al-inline-list li a {
    text-decoration: none;
    color: var(--al-text);
    display: flex;
    flex-direction: column;
    gap: .15rem;
}
.arkivlexikon-inline .al-inline-list li a strong {
    color: var(--al-accent);
    font-family: var(--al-font-serif);
}
.arkivlexikon-inline .al-inline-list li a span {
    font-size: .85em;
    color: var(--al-text-soft);
    line-height: 1.4;
}
.arkivlexikon-error {
    padding: .75rem 1rem;
    background: #fff3cd;
    border-left: 4px solid #f59e0b;
    color: #663c00;
    margin: 1em 0;
}

/* ============================================================
 * MOBIL-ANPASSNINGAR
 * ============================================================ */

@media (max-width: 600px) {
    .al-cat-grid {
        grid-template-columns: 1fr;
    }
    .arkivlexikon-term .al-term-related ul {
        grid-template-columns: 1fr;
    }
    .al-jump-nav {
        position: static;
    }
    .al-term-list > li > a {
        flex-direction: column;
        align-items: flex-start;
        gap: .25em;
    }
}

/* ============================================================
 * PRINT
 * ============================================================ */

@media print {
    .arkivlexikon .al-search-wrap,
    .arkivlexikon .al-jump-nav,
    .arkivlexikon .al-easter-calc,
    .arkivlexikon .al-back-link {
        display: none;
    }
    .arkivlexikon {
        max-width: none;
    }
    .al-cat-card {
        box-shadow: none;
        page-break-inside: avoid;
    }
    .al-letter-group {
        page-break-inside: avoid;
    }
}

/* ============================================================
   v1.5.0 - Utökad termrendering
   ============================================================ */

/* Hero med lead-text */
.arkivlexikon-term .al-term-header h1 {
    margin-bottom: .5rem;
}
.arkivlexikon-term .al-term-lead {
    font-size: 1.18em;
    line-height: 1.5;
    color: var(--al-text);
    margin: .5rem 0 1.5rem;
    font-family: var(--al-font-serif);
    font-style: italic;
    padding: 0 0 1rem;
    border-bottom: 1px solid var(--al-bg-soft-2);
}

.arkivlexikon-term .al-term-modern-pill {
    display: inline-block;
    padding: 3px 12px;
    background: var(--al-bg-soft);
    border: 1px solid var(--al-border);
    border-radius: 12px;
    font-size: .88em;
    color: var(--al-text);
}

/* TOC */
.al-term-toc {
    background: var(--al-bg-soft);
    border: 1px solid var(--al-border);
    border-radius: var(--al-radius);
    padding: .8rem 1.2rem;
    margin: 1.5rem 0 2rem;
    font-size: .94em;
}
.al-term-toc strong {
    color: var(--al-accent);
    margin-right: 1rem;
}
.al-term-toc ul {
    display: inline;
    padding: 0;
    margin: 0;
    list-style: none;
}
.al-term-toc li {
    display: inline;
    margin-right: 1rem;
}
.al-term-toc a {
    color: var(--al-text);
    text-decoration: none;
    border-bottom: 1px dotted var(--al-text-soft);
}
.al-term-toc a:hover {
    color: var(--al-accent);
    border-bottom-color: var(--al-accent);
}

/* Sections */
.al-section {
    margin: 2.5rem 0;
}
.al-section h2 {
    color: var(--al-accent);
    border-bottom: 2px solid var(--al-bg-soft-2);
    padding-bottom: .4rem;
    margin-bottom: 1rem;
    font-family: var(--al-font-serif);
}

.al-section-tips ul,
.al-section-search ul {
    padding-left: 1.5rem;
}
.al-section-tips li,
.al-section-search li {
    margin-bottom: .6rem;
    line-height: 1.55;
}

/* Example quote */
.al-example-quote {
    border-left: 4px solid var(--al-accent);
    padding: .8rem 1.2rem;
    background: var(--al-bg-soft);
    margin: 1rem 0;
    font-family: Georgia, serif;
    font-style: italic;
    color: var(--al-text);
}

/* Related list - utökad layout */
.al-related-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
}
.al-related-list li {
    margin: 0;
}
.al-related-link {
    display: block;
    background: var(--al-bg);
    border: 1px solid var(--al-bg-soft-2);
    border-radius: var(--al-radius);
    padding: 12px 14px;
    text-decoration: none;
    color: var(--al-text);
    transition: border-color .15s, transform .15s;
}
.al-related-link:hover {
    border-color: var(--al-accent);
    transform: translateY(-1px);
}
.al-related-link strong {
    display: block;
    color: var(--al-accent);
    margin-bottom: 2px;
}
.al-related-cat {
    font-size: .82em;
    color: var(--al-text-soft);
    margin-left: 4px;
}
.al-related-short {
    display: block;
    font-size: .9em;
    color: var(--al-text-soft);
    margin-top: 4px;
    line-height: 1.4;
}

/* FAQ */
.al-faq-list {
    margin-top: 1rem;
}
.al-faq-item {
    border: 1px solid var(--al-bg-soft-2);
    border-radius: var(--al-radius);
    margin-bottom: .8rem;
    background: var(--al-bg);
}
.al-faq-item summary {
    padding: .9rem 1.2rem;
    cursor: pointer;
    font-weight: 600;
    color: var(--al-accent);
    font-family: var(--al-font-serif);
    list-style: none;
    position: relative;
    padding-right: 2.5rem;
}
.al-faq-item summary::-webkit-details-marker { display: none; }
.al-faq-item summary::after {
    content: '+';
    position: absolute;
    right: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.4em;
    line-height: 1;
    color: var(--al-text-soft);
}
.al-faq-item[open] summary::after {
    content: '−';
}
.al-faq-answer {
    padding: 0 1.2rem 1rem;
    color: var(--al-text);
    line-height: 1.6;
}

/* Cat sample grid */
.al-cat-sample-grid {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 10px;
}
.al-cat-sample-grid li {
    margin: 0;
}
.al-cat-sample-grid a {
    display: block;
    padding: 10px 12px;
    background: var(--al-bg-soft);
    border-radius: var(--al-radius-sm);
    text-decoration: none;
    color: var(--al-text);
    transition: background .15s;
}
.al-cat-sample-grid a:hover {
    background: var(--al-bg-soft-2);
}
.al-cat-sample-grid strong {
    display: block;
    color: var(--al-accent);
    margin-bottom: 2px;
    font-size: .96em;
}
.al-cat-sample-grid span {
    font-size: .85em;
    color: var(--al-text-soft);
    line-height: 1.35;
}
.al-see-all {
    text-align: right;
    margin-top: 1rem;
}

/* Term footer - flera back-links */
.al-term-footer {
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--al-bg-soft-2);
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
.al-term-footer .al-back-link {
    color: var(--al-text-soft);
    text-decoration: none;
}
.al-term-footer .al-back-link:hover {
    color: var(--al-accent);
}

/* Mobil */
@media (max-width: 600px) {
    .al-term-toc ul { display: block; margin-top: .5rem; }
    .al-term-toc li { display: block; margin: 4px 0; }
    .al-related-list,
    .al-cat-sample-grid { grid-template-columns: 1fr; }
}
