@font-face {
    font-family: 'Crimson Pro';
    src: url('fonts/crimsonpro-regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Crimson Pro';
    src: url('fonts/crimsonpro-italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    background: #fff;
    color: #444;
    font-family: 'Crimson Pro', serif;
    font-size: 20px;
    line-height: 1.4;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ---- Site header ---- */
.site-header {
    background: #f0eee4;
    border-bottom: 1px solid #9d8b50;
    padding: 20px 0;
}
.site-header-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 20px;
}
.site-logo { display: block; }
.site-logo img { max-width: 340px; width: 100%; height: auto; }

/* ---- Container ---- */
.container {
    max-width: 900px;
    margin: 0 auto;
    padding: 3em 20px 4em;
    flex: 1;
}

/* ---- Site footer ---- */
.site-footer {
    background: #f0eee4;
    border-top: 1px solid #9d8b50;
    padding: 0;
    margin-top: 3rem;
    width: 100%;
}
.site-footer-inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 40px;
    align-items: start;
}
.footer-links {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.footer-links a {
    font-family: 'Hind', sans-serif;
    font-size: 17px;
    font-weight: 400;
    color: #d4710a;
    text-decoration: none;
    line-height: 1.5;
}
.footer-links a:hover { color: #b85e08; }
.footer-tekst {
    font-family: 'Hind', sans-serif;
    font-size: 17px;
    font-weight: 400;
    color: #444;
    line-height: 1.5;
    hyphens: auto;
}
.footer-tekst a { color: #d4710a; text-decoration: none; }
.footer-tekst a:hover { color: #b85e08; }

/* ---- Ovcheck basis ---- */
#ovcheck * { box-sizing: border-box; font-family: 'Crimson Pro', serif; color: #444; hyphens: auto; line-height: 1.4; font-variant-numeric: oldstyle-nums; }
#ovcheck a { text-decoration: none; color: #d4710a; }
#ovcheck .invoer-wrapper * { border: none; }

/* Header */
#ovcheck .header { padding: 0 0 1.5rem; margin-bottom: 1rem; }
#ovcheck .header-titel { font-family: 'Hind', sans-serif; font-size: 24px; font-weight: 600; line-height: 1.3; margin-bottom: 4px; }
#ovcheck .brand { font-size: 20px; font-style: italic; line-height: 1.4; }

/* Doelgroep */
#ovcheck .doelgroep-row { display: flex; align-items: center; gap: 12px; margin-bottom: 1rem; flex-wrap: wrap; position: relative; }
#ovcheck .doelgroep-label { font-family: 'Crimson Pro', serif; font-size: 20px; font-weight: 400; }
#ovcheck .doelgroep-select { font-family: 'Crimson Pro', serif; font-size: 20px; color: #444; background-color: #f5f5f5; border: none; border-radius: 16px; padding: 8px 14px; cursor: pointer; position: relative; display: inline-flex; align-items: center; justify-content: space-between; gap: 10px; user-select: none; min-width: 160px; }
#ovcheck .doelgroep-select svg { flex-shrink: 0; }
#ovcheck .doelgroep-opties { display: none; position: absolute; top: calc(100% + 4px); left: 0; background: #fff; border-radius: 12px; box-shadow: 0 4px 16px rgba(0,0,0,0.12); list-style: none; padding: 0; min-width: 100%; z-index: 100; overflow: hidden; }
#ovcheck .doelgroep-opties li { font-family: 'Crimson Pro', serif; font-size: 20px; color: #444; padding: 3px 18px; cursor: pointer; white-space: nowrap; }
#ovcheck .doelgroep-opties li:hover { background: #f5f5f5; }

/* Invoer */
#ovcheck .invoer-wrapper { position: relative; }
#ovcheck textarea { display: block; width: 100%; height: 180px; resize: none; font-size: 20px; line-height: 1.4; padding: 21px 28px; border: none; border-radius: 12px 12px 0 0; background: #f5f5f5; color: #444; font-family: 'Crimson Pro', serif; outline: none; overflow-y: scroll; scrollbar-width: thin; scrollbar-color: #ccc #f5f5f5; }
#ovcheck textarea:focus { outline: none; background: #f5f5f5; }
#ovcheck .invoer-balk { background: #f5f5f5; border-radius: 0 0 12px 12px; padding: 6px 12px; }
#ovcheck .wordcount { font-size: 14px; color: #999; font-style: italic; text-align: right; }
#ovcheck .privacy { font-size: 18px; margin-top: 6px; line-height: 1.4; font-style: italic; text-align: right; margin-right: 10px; }
#ovcheck-wordcount { font-feature-settings: "onum" 1; font-variant-numeric: oldstyle-nums; }

/* Bot-veld */
#ovcheck .bot-veld { display: none; }

/* Knoppen */
#ovcheck .btn-row { display: flex; gap: 8px; margin-top: 1rem; }
#ovcheck button.primary { background: #d4710a; color: #fff; border: none; border-radius: 12px; padding: 8px 20px 5px; font-size: 17px; font-weight: 400; cursor: pointer; font-family: 'Hind', sans-serif; }
#ovcheck button.primary:hover { background: #b85e08; }
#ovcheck button.primary:disabled { opacity: 1; cursor: not-allowed; background: #d4710a; }
#ovcheck button.secondary { background: #d4710a; color: #fff; border: 1px solid #d4710a; border-radius: 12px; padding: 8px 20px 5px; font-size: 17px; font-weight: 400; cursor: pointer; font-family: 'Hind', sans-serif; min-width: 4em; }
#ovcheck button.secondary:hover { background: #b85e08; }
#ovcheck .foutmelding { display: none; font-size: 20px; color: #c0392b; margin-top: 1rem; padding: 12px; background: #fdf0ed; border-radius: 12px; }

/* Loading */
#ovcheck .loading { display: none; font-size: 20px; padding: 3rem 0 2rem; text-align: left; line-height: 1.4; }
#ovcheck .loading-tekst { margin-bottom: 1em; }
#ovcheck .loading-balk { background: #e0e0e0; border-radius: 12px; height: 6px; overflow: hidden; }
#ovcheck .loading-balk-inner { height: 100%; width: 30%; background: #d4710a; border-radius: 12px; animation: ovcheck-laden 3s ease-in-out infinite; }
@keyframes ovcheck-laden { 0% { transform: translateX(-100%); } 100% { transform: translateX(400%); } }
#ovcheck .results { display: none; margin-top: 4rem; }

/* Totaalscore */
#ovcheck .totaal-kop { font-family: 'Hind', sans-serif; font-size: 22px; font-weight: 600; text-align: center; margin-bottom: 10px; }
#ovcheck .totaal { background: #f5f5f5; border-radius: 12px; padding: 1.75rem 2rem; margin-bottom: 1.5rem; }
#ovcheck .totaal-midden { display: flex; flex-direction: row; align-items: center; gap: 20px; margin-bottom: 1.25rem; justify-content: center; }
#ovcheck .score-cirkel { width: 110px !important; height: 110px !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0; background: #ccc; margin-top: -6px; }
#ovcheck .score-cirkel span { font-family: 'Hind', sans-serif; font-size: 34px; font-weight: 700; color: #fff !important; }
#ovcheck .score-cirkel.groen { background: #4a9e1a !important; }
#ovcheck .score-cirkel.oranje { background: #ff8800 !important; }
#ovcheck .score-cirkel.rood { background: #E24B4A !important; }
#ovcheck .score-label { font-size: 24px; line-height: 1.3; font-family: 'Hind', sans-serif; font-weight: 600; }
#ovcheck .samenvatting { font-size: 20px; line-height: 1.4; }
#ovcheck .score-label.groen { color: #4a9e1a; }
#ovcheck .score-label.oranje { color: #ff8800; }
#ovcheck .score-label.rood { color: #E24B4A; }

/* Criteria */
#ovcheck .criteria-titel { font-family: 'Hind', sans-serif; font-size: 22px; font-weight: 600; text-align: center; margin-top: 2.5em; margin-bottom: 1em; }
#ovcheck .criteria-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-bottom: 1.5rem; }
@media (max-width: 600px) { #ovcheck .criteria-grid, #ovcheck .bevindingen-grid { grid-template-columns: 1fr; } }

#ovcheck .criterium { position: relative; background: #f5f5f5; border-radius: 12px; padding: 24px 21px 24px 34px; overflow: hidden; }
#ovcheck .criterium::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 12px; border-radius: 12px 0 0 12px; background: #ccc; }
#ovcheck .criterium.groen::before { background: #4a9e1a; }
#ovcheck .criterium.oranje::before { background: #ff8800; }
#ovcheck .criterium.rood::before { background: #E24B4A; }
#ovcheck .crit-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
#ovcheck .dot { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; margin-bottom: 2px; }
#ovcheck .dot.groen { background: #4a9e1a; }
#ovcheck .dot.oranje { background: #ff8800; }
#ovcheck .dot.rood { background: #E24B4A; }
#ovcheck .crit-naam { font-family: 'Hind', sans-serif; font-size: 17px; font-weight: 600; flex: 1; }
#ovcheck .crit-tekst { font-size: 20px; line-height: 1.4; }
#ovcheck .crit-toggle { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: #bbb; color: #fff; font-family: 'Hind', sans-serif; font-size: 13px; cursor: pointer; flex-shrink: 0; user-select: none; padding-top: 2px; }
#ovcheck .crit-toggle:hover { background: #888; }

/* Bevindingen */
#ovcheck .bevindingen-titel { font-family: 'Hind', sans-serif; font-size: 22px; font-weight: 600; text-align: center; margin-top: 2.5em; margin-bottom: 1em; }
#ovcheck .bevindingen-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-bottom: 1.5rem; }
#ovcheck .bevinding { border: none; border-radius: 12px; padding: 20px 28px 28px; background: #f5f5f5; position: relative; }
#ovcheck .bev-tag-cirkel { display: none; }
#ovcheck .bev-tag { font-size: 17px; font-family: 'Hind', sans-serif; font-weight: 600; flex: 1; margin-bottom: 1em; }
#ovcheck .bev-zin { font-size: 20px; font-style: italic; margin: 0 0 20px 0; line-height: 1.4; }
#ovcheck .bev-probleem { font-size: 20px; margin-bottom: 1em; line-height: 1.4; }
#ovcheck .bev-suggestie { font-size: 20px; position: relative; background: #eaeaea; border-radius: 12px; padding: 12px 18px 12px 34px; }
#ovcheck .bev-suggestie::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 12px; border-radius: 12px 0 0 12px; background: #4a9e1a; }

/* Donatie & feedback */
#ovcheck .donatie { font-size: 20px; line-height: 1.4; margin: 2.5em 0 1.5em; }
#ovcheck .feedback { font-size: 20px; margin-top: 1.5em; }
#ovcheck .feedback-btns { display: flex; gap: 8px; margin-top: 0.75em; }
#ovcheck button.secondary.ja { background: #4a9e1a; border-color: #4a9e1a; }
#ovcheck button.secondary.nee { background: #E24B4A; border-color: #E24B4A; }
#ovcheck .feedback label { font-size: 20px; }
#ovcheck #ovcheck-feedback-extra { margin-bottom: 1.5em; }
#ovcheck .pdf-tekst { font-size: 20px; line-height: 1.4; }
.grecaptcha-badge { visibility: hidden !important; }