/*
Theme Name: Inburgo
Theme URI: https://inburgo.nl/
Description: Thema voor Inburgo — oefenen voor het inburgeringsexamen. Strak, helder, meertalig (fase 3).
Author: Richard
Version: 0.2.0
Requires at least: 5.8
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: inburgo
*/

:root{
  --bg:#eef2f6; --surface:#ffffff; --ink:#1d2733; --ink-soft:#52617a;
  --line:#dfe5ee; --brand:#0f766e; --brand-dark:#0f565e; --brand-tint:#e3f0f1;
  --accent:#14b8a6; --good:#2e7d55; --good-tint:#e6f3ec; --bad:#c0392b;
  --radius:14px; --maxw:1080px;
  --shadow:0 1px 2px rgba(29,39,51,.06),0 8px 24px rgba(29,39,51,.06);
  --sans:"Inter",system-ui,-apple-system,sans-serif;
  --display:"Space Grotesk","Inter",sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--brand-dark)}
h1,h2,h3{font-family:var(--display);line-height:1.2;letter-spacing:-0.02em;margin:0 0 .5em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* knoppen */
.btn{display:inline-block;font-family:var(--display);font-weight:700;font-size:15px;
  border:none;border-radius:10px;padding:12px 22px;cursor:pointer;
  background:var(--brand);color:#fff;transition:background .15s,transform .05s;line-height:1.2}
.btn:hover{background:var(--brand-dark);color:#fff}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:transparent;color:var(--brand);border:1.5px solid var(--line)}
.btn.ghost:hover{background:var(--brand-tint);border-color:var(--brand)}
.btn.light{background:#fff;color:var(--brand-dark)}
.btn.sm{padding:8px 15px;font-size:13.5px}

.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px 12px;border-radius:8px;z-index:100}

/* header */
.site-header{position:sticky;top:0;z-index:30;background:var(--surface);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:18px;min-height:64px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:19px;color:var(--brand-dark)}
.brand:hover{color:var(--brand-dark)}
.primary-nav{margin-left:8px}
.primary-nav .menu{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.primary-nav .menu a{color:var(--ink-soft);font-size:14.5px;font-weight:500}
.primary-nav .menu a:hover{color:var(--brand)}
.header-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
/* taalwisselaar — dropdown (details/summary) */
.langpick{position:relative;margin-right:6px}
.langpick summary{display:flex;align-items:center;gap:6px;cursor:pointer;list-style:none;
  font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink-soft);
  background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 11px}
.langpick summary::-webkit-details-marker{display:none}
.langpick summary:hover{border-color:var(--brand);color:var(--brand)}
.langpick .lang-chev{font-size:10px;transition:transform .15s}
.langpick[open] .lang-chev{transform:rotate(180deg)}
.lang-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:40;min-width:150px;margin:0;padding:5px;
  list-style:none;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}
.lang-item{display:block;padding:8px 10px;border-radius:7px;font-size:14px;color:var(--ink)}
.lang-item:hover{background:var(--brand-tint);color:var(--brand-dark)}
.lang-item.active{font-weight:700;color:var(--brand)}

/* footer */
.site-footer{background:#0f1d1c;color:#cfe3df;margin-top:60px;padding:36px 0}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;gap:16px}
.footer-brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;color:#fff}
.footer-menu{display:flex;gap:16px;list-style:none;margin:0;padding:0}
.footer-menu a{color:#cfe3df;font-size:13.5px}
.footer-menu a:hover{color:#fff}
.footer-note{width:100%;margin:8px 0 0;color:#80a39c;font-size:12.5px}

@media(max-width:780px){
  .primary-nav{display:none}
  .header-inner{gap:10px}
}

/* hero */
.hero{background-size:cover;background-position:center;color:#fff;text-align:center}
.hero-inner{padding:80px 20px 76px;max-width:780px}
.hero .eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  background:rgba(255,255,255,.18);color:#fff;padding:4px 11px;border-radius:99px}
.hero h1{font-size:clamp(28px,4.5vw,40px);margin:16px 0 14px;color:#fff}
.hero p{font-size:17px;color:rgba(255,255,255,.92);margin:0 auto 24px;max-width:52ch}

/* onderdelen */
.onderdelen{padding:46px 0}
.od-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.od{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.od.active{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand),var(--shadow)}
.od-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.od-title{font-family:var(--display);font-weight:700;font-size:17px}
.od p{color:var(--ink-soft);font-size:14px;margin:0 0 10px}
.badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px;background:var(--good-tint);color:var(--good)}
.badge.soon{background:var(--bg);color:var(--ink-soft)}

/* why */
.why{padding:20px 0 50px}
.why-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:28px;align-items:center}
.why-photo{min-height:240px;border-radius:var(--radius);background:linear-gradient(135deg,#cfe3df,#8fb9c9 55%,#6f93b5);
  background-size:cover;background-position:center}
.why-text h2{font-size:24px}
.why-text p{color:var(--ink-soft);margin:0 0 16px}

/* cta band */
.cta-band{background:var(--brand);color:#fff;text-align:center;padding:48px 0}
.cta-band h2{color:#fff;font-size:26px}
.cta-band p{color:rgba(255,255,255,.9);margin:0 0 18px}

@media(max-width:780px){
  .od-grid{grid-template-columns:1fr}
  .why-inner{grid-template-columns:1fr}
}

/* generieke pagina */
.page-main{padding:48px 0 10px}
.page-article{max-width:760px;margin:0 auto}
.page-title{font-size:clamp(26px,4vw,34px);margin-bottom:16px}
.entry{font-size:16.5px}
.entry p{margin:0 0 16px}
.entry h2{margin-top:28px}

/* pagina met de oefen-app (shortcode): vol breedte, plugin regelt eigen breedte */
.page-article.is-app{max-width:none}
.page-article.is-app .entry{font-size:inherit}

/* --- Accounts: kaarten & formulieren --- */
.auth-card{max-width:440px;margin:8px auto 0;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:30px 28px}
.auth-title{font-size:24px;margin:0 0 16px}
.auth-card .auth-alt{margin:16px 0 0;color:var(--ink-soft);font-size:14px}
.auth-card .muted{color:var(--ink-soft);font-size:14px;margin:2px 0 16px}
.auth-card .account-name{margin:0 0 2px}

.auth-form label,.auth-card .login-username,.auth-card .login-password{display:block;margin:0 0 14px;
  font-size:14px;font-weight:600;color:var(--ink)}
.auth-form input,.auth-card input[type=text],.auth-card input[type=email],.auth-card input[type=password]{
  display:block;width:100%;margin-top:6px;padding:11px 13px;font-size:15px;font-family:inherit;
  border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.auth-form input:focus,.auth-card input:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-tint)}
.auth-card .login-remember{font-weight:500;color:var(--ink-soft)}
.auth-card .login-submit input,.auth-form button{margin-top:4px}

.auth-error{background:var(--bad-tint, #fbe9e7);border:1px solid var(--bad);border-radius:10px;
  padding:10px 14px;margin:0 0 16px;color:var(--bad)}
.auth-error ul{margin:0;padding-left:18px;font-size:14px}

/* toegangs-kaart (afgeschermde content) */
.access-card{max-width:520px;margin:10px auto;text-align:center;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:36px 30px}
.access-card .access-ic{font-size:34px;margin-bottom:8px}
.access-card h2{font-size:23px;margin:0 0 8px}
.access-card p{color:var(--ink-soft);margin:0 0 20px}
.access-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
