@import url("https://fonts.googleapis.com/css2?family=Jost:wght@400;600;700;800&family=Open+Sans:wght@400;600&display=swap");

/* =========================
   Design tokens
========================= */
:root {
    --maxw: 1100px;
    --pad: 16px;
    --radius: 14px;
    --shadow: 0 2px 8px rgba(0, 0, 0, .06);
    --page: #E9F4EE;
    --brand: #CFE6D8;
    --line: #d8e6de;
    --text: #111;
    --muted: #444;
    --link: #0b5fff;
    --header-h: 64px;
    --card: #fff;

    --ease: cubic-bezier(.22, .61, .36, 1);
    --dur-quick: 180ms;
    --dur-base: 260ms;

    --glass-bg: rgba(255, 255, 255, .74);
    --glass-blur: 8px;
}

/* =========================
   Base
========================= */
* {
    box-sizing: border-box
}

html,
body {
    height: 100%
}

body {
    margin: 0;
    color: var(--text);
    background: var(--page);
    font: 16px/1.6 "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    display: flex;
    flex-direction: column;
    min-height: 100svh;
}

a {
    color: var(--link);
    text-decoration: none
}

a:hover {
    text-decoration: underline
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Jost", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-weight: 800;
}

.wrap {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--pad)
}

main {
    flex: 1 0 auto;
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 12px var(--pad);
}

.hidden {
    display: none !important
}

.page {
    padding: 0 !important
}

/* Minder beweging */
@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
}

/* Focus */
:focus-visible {
    outline: 3px solid color-mix(in oklab, var(--link), white 30%);
    outline-offset: 2px;
    border-radius: 10px;
}

/* =========================
   Header
========================= */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid var(--line);
    background: var(--brand);
    transform: translateY(0);
    transition:
        transform var(--dur-base) var(--ease),
        box-shadow var(--dur-base) var(--ease),
        background-color var(--dur-base) var(--ease);
    will-change: transform;
}

.site-header .bar {
    min-height: var(--header-h);
    display: flex;
    align-items: center;
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--pad);
}

.header-link {
    display: flex;
    align-items: center;
    gap: 12px;
    color: inherit;
    text-decoration: none
}

.site-header .logo {
    height: 32px;
    width: auto;
    object-fit: contain;
    display: block
}

.site-header h1 {
    margin: 0;
    font-weight: 600;
    font-size: 20px;
    line-height: 1;
    letter-spacing: .02em;
    text-transform: uppercase;
    white-space: nowrap;
}

@media (max-width:720px) {
    .site-header .logo {
        height: 28px
    }

    .site-header h1 {
        font-size: 16px
    }
}

.site-header.scrolled {
    box-shadow: 0 8px 18px rgba(0, 0, 0, .08)
}

.site-header.is-hidden {
    transform: translateY(-100%)
}

.site-header.is-active {
    backdrop-filter: blur(var(--glass-blur));
    background-color: var(--glass-bg);
    box-shadow: 0 1px 12px rgba(0, 0, 0, .06);
}

/* =========================
   Footer met reveal
========================= */
.site-footer {
    border-top: 1px solid var(--line);
    background: #fafafa;
    transform: translateY(30px);
    opacity: 0;
    transition:
        transform var(--dur-base) var(--ease),
        opacity var(--dur-base) var(--ease);
}

.site-footer.is-visible {
    transform: translateY(0);
    opacity: 1;
}

.site-footer .wrap {
    padding: 14px var(--pad);
    color: var(--muted);
    font-size: 14px;
}

@media (prefers-reduced-motion: reduce) {
    .site-footer {
        transform: none;
        opacity: 1;
        transition: none
    }
}

/* =========================
   Componenten
========================= */
.tool-embed iframe {
    width: 100%;
    height: 70vh;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.tool-main,
.tool-wrap {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 var(--pad);
}

/* Tools: zelfde top-spacing als home */
.tool-main {
    padding-top: 0
}

.tool-main .section-title {
    margin-top: 0
}

/* container spacing */
#tool-container {
    padding: 12px var(--pad) 16px
}

@media (max-width:720px) {
    .tool-main {
        padding-bottom: 56px
    }

    #tool-container {
        padding: 12px var(--pad) 56px
    }
}

/* Startpagina krijgt extra top-ruimte zodat "Applicaties" mooi centreert */
.home #tool-container {
    padding-top: 10px;
}
/* Actieknoppen */
.tool-actions {
    margin: 24px 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: flex-start;
    padding-bottom: 24px;
}

.tool-actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 16px;
    border: 1px solid #000;
    border-radius: 8px;
    background: #fff;
    font-weight: 600;
    transition: background var(--dur-quick) var(--ease);
    flex: 0 0 auto;
    width: auto;
    white-space: nowrap;
    min-width: max-content;
}

.tool-actions .btn:hover {
    background: #e6f5ed
}

.tool-actions .btn.black {
    background: #000;
    color: #fff;
    border-color: #000;
}

.tool-actions .btn.black:hover {
    background: #222
}

/* Cards */
.card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .05);
    overflow: hidden;
    transition:
        box-shadow var(--dur-quick) var(--ease),
        transform var(--dur-quick) var(--ease);
}

.card:hover {
    box-shadow: 0 8px 22px rgba(0, 0, 0, .10);
    transform: translateY(-1px)
}

/* Sectie titel */
.section-title {
    margin: 8px 0 12px 0;
    font-family: "Jost", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    opacity: .8;
}

/* =========================
   Grid standaard tegels
========================= */
.grid {
    display: grid;
    gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width:1200px) {
    .grid {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media (max-width:900px) {
    .grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media (max-width:560px) {
    .grid {
        grid-template-columns: 1fr
    }
}

/* Vierkante cards op de start */
#tools .card {
    aspect-ratio: 1/1
}

#tools .card-link {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

#tools .illustration {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 0 6px;
    margin: 0;
    background: none;
    border: none;
    box-shadow: none;
}

#tools .illustration svg {
    width: 116px;
    height: 116px;
    opacity: .98;
    transition: transform var(--dur-quick) var(--ease), filter var(--dur-quick) var(--ease);
}

.card:hover .illustration svg {
    transform: scale(1.02);
    filter: saturate(1.06)
}

#tools .card h3 {
    font-family: "Jost", sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 1.22;
    margin: 2px 0 0;
    letter-spacing: -.2px;
}

#tools .card p {
    display: block;
    font-size: 14.5px;
    line-height: 1.42;
    color: var(--muted);
}

/* Mobiel tiles */
@media (max-width:720px) {
    #tools .card {
        height: 92px;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        padding: 0;
        aspect-ratio: auto;
    }

    #tools .card-link {
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        padding: 0 10px 0 14px;
        height: 100%;
        text-align: left;
    }

    #tools .illustration {
        display: none !important
    }

    #tools .card h3 {
        font-size: 16px;
        font-weight: 510;
        margin: 0;
        line-height: 1.22;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: break-word;
    }

    #tools .card p {
        display: none !important
    }

    main {
        padding-bottom: 48px
    }
}

/* =========================
   Micro animaties
========================= */
/* binnenkomst met kleine stagger */
#tools .card.card-in {
    opacity: 0;
    transform: translateY(8px) scale(.995);
    animation: card-in var(--dur-base) var(--ease) forwards;
    animation-delay: var(--in-delay, 0ms);
}

@keyframes card-in {
    to {
        opacity: 1;
        transform: translateY(0) scale(1)
    }
}

/* Skeleton helper indien je tegels async vult */
.skeleton {
    position: relative;
    overflow: hidden;
    background: #f2f4f7
}

.skeleton::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background-image: linear-gradient(90deg, transparent, rgba(255, 255, 255, .6), transparent);
    animation: shimmer 1200ms infinite;
}

@keyframes shimmer {
    to {
        transform: translateX(100%)
    }
}

/* =========================
   Home layout twee kolommen
========================= */
.home-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
}

@media (max-width:980px) {
    .home-layout {
        grid-template-columns: 1fr
    }
}

/* Lijst links met balkjes */
.tool-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.tool-row {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: var(--shadow);
}

.row-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 16px;
    color: inherit;
    text-decoration: none;
}

.row-icon {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: #eef7f2;
}

.row-main {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0
}

.row-title {
    font-family: "Jost", system-ui;
    font-weight: 600;
    font-size: 18px
}

.row-desc {
    font-size: 14.5px;
    color: var(--muted)
}

.row-chevron {
    margin-left: auto;
    font-size: 22px;
    opacity: .5
}

.tool-row:hover {
    box-shadow: 0 10px 24px rgba(0, 0, 0, .08)
}

.tool-row:hover .row-chevron {
    opacity: .8
}

/* Lijst rechts met externe links */
.extern-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.extern-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .04);
}

.extern-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: #f3f6fb;
}

.extern-text {
    font-weight: 600
}

.extern-ext {
    margin-left: auto;
    opacity: .6
}

/* =========================
   Form utilities centraal
========================= */
.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 20px;
}

@media (max-width:980px) {
    .form-grid {
        grid-template-columns: 1fr
    }
}

.field {
    display: flex;
    flex-direction: column;
    gap: 6px
}

.field label {
    font-weight: 600;
    font-size: 14px
}

.field input[type="text"],
.field input[type="date"],
.field input[type="search"],
.field textarea,
.field select {
    font: 400 15px/1.45 "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    color: var(--text);
    transition: border-color var(--dur-quick) var(--ease), box-shadow var(--dur-quick) var(--ease);
}

.field input:hover,
.field textarea:hover,
.field select:hover {
    border-color: color-mix(in oklab, var(--link), white 40%)
}

.field input:focus,
.field textarea:focus,
.field select:focus {
    outline: none;
    border-color: color-mix(in oklab, var(--link), white 20%);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--link), white 70%);
}

.field textarea {
    min-height: 110px;
    resize: vertical
}

/* Secties en preview */
.section {
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
}

.preview {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    padding: 16px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .04);
}

/* =========================
   Floating mail button
========================= */
.fab {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 60;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 999px;
    background: #fff;
    color: #000;
    border: 1px solid #222;
    text-decoration: none;
    font: 600 14px/1 "Open Sans", system-ui;
    box-shadow: 0 8px 18px rgba(0, 0, 0, .12);
    transition: transform var(--dur-quick) var(--ease), background var(--dur-quick) var(--ease);
}

.fab:hover {
    background: #f2f2f2
}

.fab:active {
    transform: translateY(1px)
}

/* =========================
   Toast
========================= */
.toast {
    position: fixed;
    right: 16px;
    bottom: 16px;
    background: #222;
    color: #fff;
    padding: 12px 18px;
    border-radius: 10px;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 220ms ease, transform 220ms ease;
    pointer-events: none;
}

.toast.show {
    opacity: 1;
    transform: translateY(0)
}

/* =========================
   Dark mode
========================= */
body.dark .site-header,
body.dark .site-header h1,
body.dark h2,
body.dark h2.section-title {
    color: #fff !important
}

body.dark .site-footer {
    background: #0f1514 !important;
    border-top: 1px solid #2a3a33 !important;
}

body.dark .site-footer .footer-inner {
    color: #eaf6f0 !important
}

/* ================
   Tool scoped grid
================ */
[data-tool="motiemaker"] .layout,
[data-tool="vragenmaker"] .layout {
  display: grid;
  grid-template-columns: minmax(560px, 1fr) 480px;
  align-items: start;
  gap: 16px;
}

/* Titels en secties over volle breedte binnen de tool grid */
[data-tool="motiemaker"] .layout > h1,
[data-tool="motiemaker"] .layout > .page-title,
[data-tool="motiemaker"] .layout > .section-title,
[data-tool="motiemaker"] .section,
[data-tool="motiemaker"] .card-group,
[data-tool="motiemaker"] .cards,
[data-tool="vragenmaker"] .layout > h1,
[data-tool="vragenmaker"] .layout > .page-title,
[data-tool="vragenmaker"] .layout > .section-title,
[data-tool="vragenmaker"] .section,
[data-tool="vragenmaker"] .card-group,
[data-tool="vragenmaker"] .cards {
  grid-column: 1 / -1;
}

/* Minimale maatvoering voor de linker kolom van de tool */
[data-tool="motiemaker"] .col-main,
[data-tool="vragenmaker"] .col-main {
  min-width: 560px;
}

/* Rechter kolom vast 480px voor consistente preview */
[data-tool="motiemaker"] .col-preview,
[data-tool="vragenmaker"] .col-preview {
  width: 480px;
}

/* Mobiel en tablet terug naar enkelkoloms */
@media (max-width: 980px) {
  [data-tool="motiemaker"] .layout,
  [data-tool="vragenmaker"] .layout {
    display: block;
  }
}

/* Veiligheidje voor titels die per ongeluk in de rechter kolom zouden staan */
[data-tool="motiemaker"] .col-preview h1,
[data-tool="motiemaker"] .col-preview .page-title,
[data-tool="motiemaker"] .col-preview .section-title,
[data-tool="vragenmaker"] .col-preview h1,
[data-tool="vragenmaker"] .col-preview .page-title,
[data-tool="vragenmaker"] .col-preview .section-title {
  grid-column: 1 / -1;
}

/* Vergaderschema layout en componenten */
[data-tool="vergaderschema"] .section-title {
  margin: 8px 0 12px 0;
  font-family: "Jost", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .8;
}

[data-tool="vergaderschema"] .schema-filter {
  margin: 10px 0 12px;
  font-size: 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

[data-tool="vergaderschema"] .schema-filter span {
  font-weight: 600;
}

[data-tool="vergaderschema"] .schema-filter-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

[data-tool="vergaderschema"] .filter-btn {
  border-radius: 999px;
  border: 1px solid var(--line, #d8e6de);
  background: #fff;
  padding: 5px 10px;
  font-size: 13px;
  cursor: pointer;
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

[data-tool="vergaderschema"] .filter-btn:hover {
  background: #f4f7f5;
}

[data-tool="vergaderschema"] .filter-btn.is-active {
  border-color: #0b5fff;
  background: #e0ebff;
}

[data-tool="vergaderschema"] .schema-card {
  background: #fff;
  border: 1px solid var(--line, #d8e6de);
  border-radius: var(--radius, 14px);
  box-shadow: var(--shadow, 0 2px 8px rgba(0, 0, 0, .06));
  padding: 14px;
  margin-bottom: 20px;
}

[data-tool="vergaderschema"] .schema-table-wrapper {
  overflow-x: auto;
  border-radius: 10px;
}

[data-tool="vergaderschema"] table.schema {
  width: 100%;
  border-collapse: collapse;
  min-width: 520px;
  font-size: 14px;
}

[data-tool="vergaderschema"] table.schema thead {
  background: rgba(0, 0, 0, .03);
}

[data-tool="vergaderschema"] table.schema th,
[data-tool="vergaderschema"] table.schema td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(0, 0, 0, .06);
  text-align: left;
  vertical-align: top;
}

[data-tool="vergaderschema"] table.schema th {
  font-weight: 600;
  white-space: nowrap;
}

[data-tool="vergaderschema"] table.schema tr:last-child td {
  border-bottom: none;
}

[data-tool="vergaderschema"] .schema-month-row td {
  padding-top: 14px;
  padding-bottom: 6px;
  border-bottom: none;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #333;
  background: rgba(0, 0, 0, .02);
}

[data-tool="vergaderschema"] .tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  margin-left: 4px;
  white-space: nowrap;
}

[data-tool="vergaderschema"] .tag-raad { background: rgba(0, 120, 80, .08); }
[data-tool="vergaderschema"] .tag-commissie { background: rgba(27, 63, 123, .08); }
[data-tool="vergaderschema"] .tag-presidium { background: rgba(180, 110, 0, .08); }
[data-tool="vergaderschema"] .tag-auditcommissie { background: rgba(120, 60, 150, .08); }

[data-tool="vergaderschema"] .schema-footnote {
  margin-top: 8px;
  font-size: 13px;
  color: var(--muted, #666);
}

@media (max-width: 640px) {
  [data-tool="vergaderschema"] table.schema { min-width: 460px; }
}

/* Titels en secties mogen altijd boven de kaarten staan */
[data-tool="vergaderschema"] .wrap > .section-title,
[data-tool="vergaderschema"] .wrap > .section {
  grid-column: 1 / -1;
}

/* Fallback voor vergaderschema als data-tool ontbreekt */
#tool-container #vergaderingen .schema-filter {
    margin: 10px 0 12px;
    font-size: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

#tool-container #vergaderingen .schema-filter span {
    font-weight: 600;
}

#tool-container #vergaderingen .schema-filter-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

#tool-container #vergaderingen .filter-btn {
    border-radius: 999px;
    border: 1px solid var(--line, #d8e6de);
    background: #fff;
    padding: 5px 10px;
    font-size: 13px;
    cursor: pointer;
    font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

#tool-container #vergaderingen .filter-btn:hover {
    background: #f4f7f5;
}

#tool-container #vergaderingen .filter-btn.is-active {
    border-color: #0b5fff;
    background: #e0ebff;
}

#tool-container #vergaderingen .schema-card,
#tool-container #feestdagen .schema-card {
    background: #fff;
    border: 1px solid var(--line, #d8e6de);
    border-radius: var(--radius, 14px);
    box-shadow: var(--shadow, 0 2px 8px rgba(0, 0, 0, .06));
    padding: 14px;
    margin-bottom: 20px;
}

#tool-container #vergaderingen .schema-table-wrapper,
#tool-container #feestdagen .schema-table-wrapper {
    overflow-x: auto;
    border-radius: 10px;
}

#tool-container #vergaderingen table.schema,
#tool-container #feestdagen table.schema {
    width: 100%;
    border-collapse: collapse;
    min-width: 520px;
    font-size: 14px;
}

#tool-container #vergaderingen table.schema thead,
#tool-container #feestdagen table.schema thead {
    background: rgba(0, 0, 0, .03);
}

#tool-container #vergaderingen table.schema th,
#tool-container #vergaderingen table.schema td,
#tool-container #feestdagen table.schema th,
#tool-container #feestdagen table.schema td {
    padding: 8px 10px;
    border-bottom: 1px solid rgba(0, 0, 0, .06);
    text-align: left;
    vertical-align: top;
}

#tool-container #vergaderingen table.schema th,
#tool-container #feestdagen table.schema th {
    font-weight: 600;
    white-space: nowrap;
}

#tool-container #vergaderingen table.schema tr:last-child td,
#tool-container #feestdagen table.schema tr:last-child td {
    border-bottom: none;
}

#tool-container #vergaderingen .schema-month-row td {
    padding-top: 14px;
    padding-bottom: 6px;
    border-bottom: none;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #333;
    background: rgba(0, 0, 0, .02);
}

#tool-container #vergaderingen .tag {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    margin-left: 4px;
    white-space: nowrap;
}

#tool-container #vergaderingen .tag-raad {
    background: rgba(0, 120, 80, .08);
}

#tool-container #vergaderingen .tag-commissie {
    background: rgba(27, 63, 123, .08);
}

#tool-container #vergaderingen .tag-presidium {
    background: rgba(180, 110, 0, .08);
}

#tool-container #vergaderingen .tag-auditcommissie {
    background: rgba(120, 60, 150, .08);
}

#tool-container #vergaderingen .schema-footnote {
    margin-top: 8px;
    font-size: 13px;
    color: var(--muted, #666);
}

@media (max-width: 640px) {

    #tool-container #vergaderingen table.schema,
    #tool-container #feestdagen table.schema {
        min-width: 460px;
    }
}

/* Tool vanuit de startpagina over de volle breedte tonen */
body.tool-active .home-layout {
  display: block;
}

/* Zorg dat de toolcontainer niet meer in de rechterkolom valt */
body.tool-active #tool-container {
  max-width: var(--maxw);
  margin: 0 auto;
}

/* Veiligheid: als #tool-container toch in een grid staat, span dan alles */
body.tool-active .home-layout #tool-container {
  grid-column: 1 / -1;
}
