/* =============================================================
   Footer — .footer-graesmarken
   Layout + chrome. Baggrundsfarve styres af Style-kontraktens
   is-bg-* (default is-bg-inverse → mørk grøn). Kun :root-tokens.
   ============================================================= */

.footer-graesmarken {
    padding-block: var(--space-2xl) var(--space-lg);
}

/* ---- Hovedområde ---- */
.footer-graesmarken__main {
    display: grid;
    gap: var(--space-xl);
    grid-template-columns: 1fr;
}
@media (min-width: 768px) {
    .footer-graesmarken__main {
        grid-template-columns: 1.3fr 2fr;
        gap: var(--space-2xl);
    }
}

.footer-graesmarken__logo {
    display: block;
    height: clamp(40px, 6vw, 56px);
    width: auto;
    margin-bottom: var(--space-sm);
}
.footer-graesmarken__brand-name {
    display: block;
    font-family: var(--font-heading);
    font-size: var(--fs-h3);
    font-weight: var(--fw-semibold);
    margin-bottom: var(--space-sm);
}
.footer-graesmarken__tagline {
    margin: 0 0 var(--space-md) 0;
    max-width: 40ch;
    line-height: var(--lh-body);
    opacity: 0.85;
}

.footer-graesmarken__social {
    display: flex;
    gap: var(--space-sm);
}
.footer-graesmarken__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    color: inherit;
    text-decoration: none;
    border-radius: var(--radius-full);
    transition: var(--tr-base);
}
.footer-graesmarken__icon:hover {
    background: color-mix(in oklab, currentColor 14%, transparent);
    transform: translateY(-2px);
}
.footer-graesmarken__icon svg {
    width: 20px;
    height: 20px;
}

/* ---- Kolonner ---- */
.footer-graesmarken__cols {
    display: grid;
    gap: var(--space-xl);
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
}
.footer-graesmarken__col-title {
    font-family: var(--font-body);
    font-size: var(--fs-accent);
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-accent);
    text-transform: uppercase;
    margin: 0 0 var(--space-sm) 0;
    opacity: 0.7;
}
.footer-graesmarken__menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2xs);
}
.footer-graesmarken__menu a,
.footer-graesmarken__clink {
    color: inherit;
    text-decoration: none;
    opacity: 0.85;
    transition: opacity var(--dur-fast) var(--ease-out);
}
.footer-graesmarken__menu a:hover,
.footer-graesmarken__clink:hover {
    opacity: 1;
    text-decoration: underline;
}
.footer-graesmarken__clink {
    display: block;
}
.footer-graesmarken__addr {
    margin: 0 0 var(--space-2xs) 0;
    opacity: 0.85;
    line-height: var(--lh-body);
}

/* ---- Find vej / kort ---- */
.footer-graesmarken__map {
    border-top-left-radius: var(--radius-tl-md);
    border-top-right-radius: var(--radius-tr-md);
    border-bottom-right-radius: var(--radius-br-md);
    border-bottom-left-radius: var(--radius-bl-md);
    overflow: hidden;
    line-height: 0;
}
.footer-graesmarken__map iframe {
    display: block;
    width: 100%;
    min-height: 180px;
    border: 0;
}

/* ---- Bundlinje ---- */
.footer-graesmarken__bar {
    margin-top: var(--space-xl);
    padding-top: var(--space-md);
    border-top: 1px solid color-mix(in oklab, currentColor 18%, transparent);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm) var(--space-md);
    font-size: var(--fs-accent);
}
.footer-graesmarken__copy { opacity: 0.8; }
.footer-graesmarken__legal {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
}
.footer-graesmarken__legal a {
    color: inherit;
    text-decoration: none;
    opacity: 0.8;
    cursor: pointer;
}
.footer-graesmarken__legal a:hover {
    opacity: 1;
    text-decoration: underline;
}
.footer-graesmarken__credit { opacity: 0.7; }
.footer-graesmarken__credit a {
    color: inherit;
    text-decoration: underline;
}

@media (prefers-reduced-motion: reduce) {
    .footer-graesmarken__icon:hover { transform: none; }
}
