/* ============================================================
   Rijksoverheid Huisstijl — Samenwerking Rijk Noord
   Gedeelde chrome: tokens, basis, header, nav, footer, knoppen
   (Fonts komen uit srn-fonts.css, dat als dependency vooraf laadt)
   ============================================================ */

:root {
    /* Primair */
    --srn-blauw:          #154273;
    --srn-hemelblauw:     #007bc7;
    --srn-donkerblauw:    #01689b;

    /* Communicatiekleuren */
    --srn-paars:          #42145f;
    --srn-violet:         #a90061;
    --srn-robijnrood:     #ca005d;
    --srn-rood:           #d52b1e;
    --srn-oranje:         #e17000;
    --srn-groen:          #39870c;
    --srn-donkergroen:    #2b6a09;

    /* Accentkleuren */
    --srn-geel:           #f9e11e;
    --srn-donkergeel:     #ffb612;
    --srn-lichtblauw:     #8fcae7;
    --srn-mintgroen:      #76d2b6;
    --srn-roze:           #f092cd;

    /* Neutraal */
    --srn-wit:            #ffffff;
    --srn-paginabg:       #e6ecf0;
    --srn-lichtblauw-bg:  #e5eef4;
    --srn-lichtgrijs:     #f3f5f7;
    --srn-grijs:          #cfd6dd;
    --srn-donkergrijs:    #535353;
    --srn-zwart:          #1a1a1a;

    /* Typografie */
    --srn-font-tekst:     'RO Sans', Arial, sans-serif;
    --srn-font-heading:   'RO Sans Heading', Arial, sans-serif;
    --srn-font-serif:     'RO Serif', Georgia, serif;

    /* Spacing */
    --srn-ruimte-xs:      0.5rem;
    --srn-ruimte-sm:      1rem;
    --srn-ruimte-md:      1.5rem;
    --srn-ruimte-lg:      2.5rem;
    --srn-ruimte-xl:      4rem;

    /* Layout */
    --srn-max-breedte:    1240px;
    --srn-radius:         4px;
}

/* ============================================================
   Reset & basis
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; }

body {
    font-family: var(--srn-font-tekst);
    font-size: 1.0625rem;
    line-height: 1.6;
    color: var(--srn-zwart);
    background: var(--srn-paginabg);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main { flex: 1 0 auto; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--srn-font-heading);
    font-weight: 700;
    line-height: 1.15;
    color: var(--srn-blauw);
}

h1 { font-size: 2.4rem; }
h2 { font-size: 1.6rem; }
h3 { font-size: 1.3rem; }

p { margin: 0 0 1rem; }
p:last-child { margin-bottom: 0; }

a { color: var(--srn-hemelblauw); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--srn-donkerblauw); }

img { max-width: 100%; height: auto; }
strong { font-weight: 700; }

/* ============================================================
   Layout
   ============================================================ */
.srn-container {
    max-width: var(--srn-max-breedte);
    margin: 0 auto;
    padding: 0 var(--srn-ruimte-md);
    width: 100%;
}

.srn-sectie { padding: var(--srn-ruimte-lg) 0; }

/* Witte kaart als algemene contentcontainer */
.srn-paneel {
    background: var(--srn-wit);
    border-radius: var(--srn-radius);
    box-shadow: 0 1px 2px rgba(21,66,115,0.06), 0 4px 16px rgba(21,66,115,0.05);
}

/* ============================================================
   Header — Rijksoverheid logo, gecentreerd, witte balk
   ============================================================ */
.srn-header {
    background: var(--srn-wit);
    border-bottom: 1px solid #e3e8ec;
}
.srn-header-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1.1rem 0;
}
.srn-logo { display: inline-flex; align-items: center; gap: 0.85rem; text-decoration: none; }
.srn-logo svg { display: block; height: 66px; width: auto; }
.srn-logo .srn-logo-woord {
    font-family: var(--srn-font-heading);
    font-weight: 700;
    font-size: 1.35rem;
    color: var(--srn-blauw);
    letter-spacing: 0.01em;
}

/* ============================================================
   Navigatie — blauwe balk
   ============================================================ */
.srn-nav { background: var(--srn-blauw); }
.srn-nav-inner {
    max-width: var(--srn-max-breedte);
    margin: 0 auto;
    padding: 0 var(--srn-ruimte-md);
}
.srn-nav ul { display: flex; list-style: none; flex-wrap: wrap; }
.srn-nav a {
    display: block;
    padding: 0.95rem 1.35rem;
    color: var(--srn-wit);
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    border-bottom: 3px solid transparent;
    transition: background .12s, border-color .12s;
}
.srn-nav li:first-child a { padding-left: 0; }
.srn-nav a:hover { background: rgba(255,255,255,0.10); color: var(--srn-wit); }
.srn-nav a.actief { border-bottom-color: var(--srn-wit); color: var(--srn-wit); }

/* ============================================================
   Knoppen
   ============================================================ */
.srn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.7rem 1.5rem;
    font-family: var(--srn-font-tekst);
    font-size: 1rem;
    font-weight: 700;
    text-decoration: none;
    border: 2px solid transparent;
    border-radius: var(--srn-radius);
    cursor: pointer;
    transition: background .15s, border-color .15s;
    line-height: 1.2;
}
.srn-btn-primary { background: var(--srn-groen); color: var(--srn-wit); border-color: var(--srn-groen); }
.srn-btn-primary:hover { background: var(--srn-donkergroen); border-color: var(--srn-donkergroen); color: var(--srn-wit); }

.srn-btn-secondary { background: #eceff2; color: var(--srn-blauw); border-color: #dde3e8; }
.srn-btn-secondary:hover { background: #dfe4e9; color: var(--srn-blauw); }

.srn-btn-blauw { background: var(--srn-hemelblauw); color: var(--srn-wit); border-color: var(--srn-hemelblauw); }
.srn-btn-blauw:hover { background: var(--srn-donkerblauw); border-color: var(--srn-donkerblauw); color: var(--srn-wit); }

.srn-btn-groot { padding: 0.85rem 1.8rem; font-size: 1.05rem; }

/* ============================================================
   Tags / labels
   ============================================================ */
.srn-tag {
    display: inline-block;
    padding: 0.28rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: var(--srn-lichtblauw-bg);
    color: var(--srn-blauw);
    border-radius: 3px;
    line-height: 1.3;
    white-space: nowrap;
}
.srn-tag-blauw { background: var(--srn-blauw); color: var(--srn-wit); }
.srn-taggroep { display: flex; gap: 0.45rem; flex-wrap: wrap; align-items: center; }

/* ============================================================
   Zoekbalk
   ============================================================ */
.srn-zoekbalk { display: flex; gap: 0; width: 100%; max-width: 620px; }
.srn-zoekbalk input {
    flex: 1;
    padding: 0.8rem 1rem;
    font-family: var(--srn-font-tekst);
    font-size: 1rem;
    border: 1px solid var(--srn-grijs);
    border-right: none;
    border-radius: var(--srn-radius) 0 0 var(--srn-radius);
    outline: none;
    background: #fff;
}
.srn-zoekbalk input::placeholder { color: #8a949c; font-style: italic; }
.srn-zoekbalk input:focus { border-color: var(--srn-hemelblauw); box-shadow: 0 0 0 3px rgba(0,123,199,0.15); }
.srn-zoekbalk button {
    padding: 0.8rem 1.8rem;
    background: var(--srn-groen);
    color: var(--srn-wit);
    font-family: var(--srn-font-tekst);
    font-size: 1rem;
    font-weight: 700;
    border: none;
    border-radius: 0 var(--srn-radius) var(--srn-radius) 0;
    cursor: pointer;
    transition: background .15s;
}
.srn-zoekbalk button:hover { background: var(--srn-donkergroen); }

/* ============================================================
   Footer
   ============================================================ */
.srn-footer {
    flex-shrink: 0;
    background: var(--srn-blauw);
    color: var(--srn-wit);
    padding: 3.2rem 0 3.5rem;
    margin-top: 3rem;
}
.srn-footer-inner {
    max-width: var(--srn-max-breedte);
    margin: 0 auto;
    padding: 0 var(--srn-ruimte-md);
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: var(--srn-ruimte-lg);
    align-items: start;
}
.srn-footer-tagline {
    font-family: var(--srn-font-serif);
    font-style: italic;
    font-size: 1.9rem;
    line-height: 1.25;
    color: var(--srn-wit);
    max-width: 22ch;
}
.srn-footer h4 {
    color: var(--srn-wit);
    font-family: var(--srn-font-heading);
    font-size: 1.15rem;
    margin-bottom: var(--srn-ruimte-md);
}
.srn-footer ul { list-style: none; }
.srn-footer ul li { margin-bottom: 0.7rem; }
.srn-footer a { color: var(--srn-wit); font-size: 1rem; text-decoration: none; }
.srn-footer a:hover { color: var(--srn-lichtblauw); text-decoration: underline; }

/* ============================================================
   Responsief
   ============================================================ */
@media (max-width: 900px) {
    .srn-footer-inner { grid-template-columns: 1fr 1fr; }
    .srn-footer-tagline { grid-column: 1 / -1; font-size: 1.6rem; margin-bottom: 1rem; }
}
@media (max-width: 768px) {
    h1 { font-size: 1.8rem; }
    h2 { font-size: 1.35rem; }
    .srn-nav-inner { padding: 0 var(--srn-ruimte-sm); }
    .srn-nav li:first-child a { padding-left: 1rem; }
    .srn-nav a { padding: 0.75rem 1rem; font-size: 0.92rem; }
    .srn-footer-inner { grid-template-columns: 1fr; gap: var(--srn-ruimte-md); }
    .srn-logo svg { height: 54px; }
}
