/* =============================================================
   Græsmarken — cookie-samtykke (banner + modal)
   Bruger child theme'ets design-tokens (blød, varm stil).
   Banner skjult som default; vises via .graesmarken-cookie--visible.
   ============================================================= */

/* ---- Banner ---- */
.graesmarken-cookie {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: var(--z-toast, 2000);
    padding: var(--space-md, 1.25rem);
    transform: translateY(120%);
    transition: transform var(--dur-slow, 400ms) var(--ease-out, ease);
    pointer-events: none;
}
.graesmarken-cookie--visible {
    transform: translateY(0);
    pointer-events: auto;
}
.graesmarken-cookie__inner {
    max-width: var(--container-max, 1200px);
    margin-inline: auto;
    background: var(--color-bg-card, #fff);
    color: var(--color-text, #1f1b14);
    border: var(--border-card, 1px solid rgba(46,74,52,0.14));
    border-top-left-radius: var(--radius-lg, 14px);
    border-top-right-radius: var(--radius-lg, 14px);
    border-bottom-right-radius: var(--radius-lg, 14px);
    border-bottom-left-radius: var(--radius-lg, 14px);
    box-shadow: var(--shadow-lg, 0 18px 38px rgba(26,42,32,0.14));
    padding: var(--space-lg, 2rem);
    display: flex;
    flex-direction: column;
    gap: var(--space-md, 1.25rem);
}
@media (min-width: 768px) {
    .graesmarken-cookie__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}
.graesmarken-cookie__text {
    margin: 0;
    font-family: var(--font-body, sans-serif);
    font-size: var(--fs-body, 1rem);
    line-height: var(--lh-body, 1.65);
    color: var(--color-text-soft, #4a453a);
    max-width: 60ch;
}
.graesmarken-cookie__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm, 0.75rem);
    flex-shrink: 0;
}

/* Knapper — genbruger btn-stilen fra designsystemet */
.graesmarken-cookie button,
.graesmarken-cookie-modal button {
    font-family: var(--font-body, sans-serif);
    font-size: var(--fs-body, 1rem);
    font-weight: var(--fw-semibold, 600);
    line-height: 1;
    padding: 0.85em 1.4em;
    cursor: pointer;
    border: var(--border-width-regular, 1.5px) solid transparent;
    border-top-left-radius: var(--radius-md, 10px);
    border-top-right-radius: var(--radius-md, 10px);
    border-bottom-right-radius: var(--radius-md, 10px);
    border-bottom-left-radius: var(--radius-md, 10px);
    transition: var(--tr-base, all 220ms ease);
}
.graesmarken-cookie__accept-all,
.graesmarken-cookie-modal__save {
    background: var(--color-btn-bg, #2e4a34);
    color: var(--color-btn-text, #f7f2e8);
    border-color: var(--color-btn-bg, #2e4a34);
}
.graesmarken-cookie__accept-all:hover,
.graesmarken-cookie-modal__save:hover {
    background: var(--color-btn-bg-hover, #1a2a20);
    border-color: var(--color-btn-bg-hover, #1a2a20);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md, 0 4px 12px rgba(26,42,32,0.08));
}
.graesmarken-cookie__reject-all,
.graesmarken-cookie__settings-btn {
    background: transparent;
    color: var(--color-green-900, #1a2a20);
    border-color: var(--color-green-700, #2e4a34);
}
.graesmarken-cookie__reject-all:hover,
.graesmarken-cookie__settings-btn:hover {
    background: var(--color-bg-accent, #e5ecdf);
}
.graesmarken-cookie button:focus-visible,
.graesmarken-cookie-modal button:focus-visible,
.graesmarken-cookie-modal__toggle:focus-visible {
    outline: var(--focus-ring, 3px solid #2e4a34);
    outline-offset: var(--focus-ring-offset, 2px);
}

/* ---- Modal ---- */
.graesmarken-cookie-modal {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-toast, 2000) + 1);
    display: none;
}
.graesmarken-cookie-modal--open {
    display: block;
}
.graesmarken-cookie-modal__backdrop {
    position: absolute;
    inset: 0;
    background: var(--color-overlay-strong, rgba(26,42,32,0.62));
    backdrop-filter: blur(var(--blur-sm, 2px));
}
.graesmarken-cookie-modal__dialog {
    position: relative;
    max-width: 36rem;
    margin: clamp(2rem, 8vh, 6rem) auto;
    max-height: 86vh;
    overflow-y: auto;
    background: var(--color-bg-card, #fff);
    color: var(--color-text, #1f1b14);
    border-top-left-radius: var(--radius-lg, 14px);
    border-top-right-radius: var(--radius-lg, 14px);
    border-bottom-right-radius: var(--radius-lg, 14px);
    border-bottom-left-radius: var(--radius-lg, 14px);
    box-shadow: var(--shadow-lg, 0 18px 38px rgba(26,42,32,0.14));
    padding: var(--space-xl, 2.5rem);
}
.graesmarken-cookie-modal__close {
    position: absolute;
    top: var(--space-sm, 0.75rem);
    right: var(--space-sm, 0.75rem);
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    font-size: 1.5rem;
    line-height: 1;
    background: transparent;
    border: 0;
    color: var(--color-text-soft, #4a453a);
    cursor: pointer;
    border-radius: var(--radius-full, 50%);
}
.graesmarken-cookie-modal__close:hover {
    background: var(--color-bg-accent, #e5ecdf);
}
.graesmarken-cookie-modal__title {
    font-family: var(--font-heading, serif);
    font-size: var(--fs-h3, 1.5rem);
    color: var(--color-heading, #1a2a20);
    margin: 0 0 var(--space-sm, 0.75rem) 0;
}
.graesmarken-cookie-modal__intro {
    margin: 0 0 var(--space-lg, 2rem) 0;
    color: var(--color-text-soft, #4a453a);
    font-size: var(--fs-body, 1rem);
    line-height: var(--lh-body, 1.65);
}
.graesmarken-cookie-modal__category {
    padding: var(--space-md, 1.25rem) 0;
    border-top: var(--border-divider, 1px solid rgba(46,74,52,0.14));
}
.graesmarken-cookie-modal__cat-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm, 0.75rem);
    cursor: pointer;
    font-family: var(--font-body, sans-serif);
    font-weight: var(--fw-semibold, 600);
    font-size: var(--fs-body, 1rem);
    color: var(--color-green-900, #1a2a20);
}
.graesmarken-cookie-modal__cat-badge {
    font-size: var(--fs-accent, 0.78rem);
    font-weight: var(--fw-semibold, 600);
    letter-spacing: var(--ls-accent, 0.14em);
    text-transform: uppercase;
    color: var(--color-green-700, #2e4a34);
}
.graesmarken-cookie-modal__cat-desc {
    margin: var(--space-2xs, 0.25rem) 0 0 0;
    font-size: var(--fs-body, 1rem);
    line-height: var(--lh-body, 1.65);
    color: var(--color-text-soft, #4a453a);
    max-width: 52ch;
}
.graesmarken-cookie-modal__toggle {
    width: 1.4em;
    height: 1.4em;
    flex-shrink: 0;
    accent-color: var(--color-green-700, #2e4a34);
    cursor: pointer;
}
.graesmarken-cookie-modal__footer {
    margin-top: var(--space-lg, 2rem);
    display: flex;
    justify-content: flex-end;
}

/* ---- Cookie-tabel (cookiepolitik-side, shortcode) ---- */
.graesmarken-cookie-table__group {
    margin-bottom: var(--space-xl, 2.5rem);
}
.graesmarken-cookie-table__cat {
    font-family: var(--font-heading, serif);
    font-size: var(--fs-h3, 1.5rem);
    color: var(--color-heading, #1a2a20);
    margin: 0 0 var(--space-sm, 0.75rem) 0;
}
.graesmarken-cookie-table__table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-body, 1rem);
}
.graesmarken-cookie-table__table th,
.graesmarken-cookie-table__table td {
    text-align: left;
    padding: 0.7em 0.6em;
    border-bottom: var(--border-divider, 1px solid rgba(46,74,52,0.14));
    vertical-align: top;
}
.graesmarken-cookie-table__table th {
    font-size: var(--fs-accent, 0.78rem);
    font-weight: var(--fw-semibold, 600);
    letter-spacing: var(--ls-accent, 0.14em);
    text-transform: uppercase;
    color: var(--color-green-700, #2e4a34);
}
.graesmarken-cookie-table__table code {
    font-family: var(--font-mono, monospace);
    font-size: 0.92em;
}

@media (max-width: 600px) {
    .graesmarken-cookie-table__table thead { display: none; }
    .graesmarken-cookie-table__table tr {
        display: block;
        margin-bottom: var(--space-md, 1.25rem);
        border: var(--border-divider, 1px solid rgba(46,74,52,0.14));
        border-radius: var(--radius-md, 10px);
        padding: var(--space-sm, 0.75rem);
    }
    .graesmarken-cookie-table__table td {
        display: flex;
        justify-content: space-between;
        gap: var(--space-md, 1.25rem);
        border: 0;
        padding: 0.35em 0;
    }
    .graesmarken-cookie-table__table td::before {
        content: attr(data-label);
        font-weight: var(--fw-semibold, 600);
        color: var(--color-green-700, #2e4a34);
    }
}

/* ---- Reduceret bevægelse ---- */
@media (prefers-reduced-motion: reduce) {
    .graesmarken-cookie { transition: none; }
    .graesmarken-cookie__accept-all:hover,
    .graesmarken-cookie-modal__save:hover { transform: none; }
}
