/* ==========================================================================
   Mijn-APK - designsysteem (1:1 naar de designmasterprompt)
   ========================================================================== */

:root{
  --petrol:#0E3A53;        /* primair */
  --petrol-dark:#082A3D;   /* primair donker */
  --accent:#1192C9;        /* primair licht / accentlijn */
  --green:#16A34A;         /* goedgekeurd */
  --green-soft:#E9F7EE;    /* groen zacht */
  --amber:#F59E0B;         /* let op */
  --amber-soft:#FFF7E6;    /* amber zacht */
  --red:#DC2626;           /* verlopen/afgekeurd */
  --red-soft:#FDECEC;      /* rood zacht */
  --bg:#F4F7F9;            /* achtergrond zacht */
  --line:#E2E8F0;          /* lijn en rand */
  --ink:#0F172A;           /* tekst donker */
  --muted:#5B6B7A;         /* tekst gedempt */
  --white:#FFFFFF;

  --radius:12px;
  --radius-sm:8px;
  --radius-pill:999px;
  --shadow:0 1px 2px rgba(8,42,61,.06),0 4px 16px rgba(8,42,61,.06);
  --shadow-lg:0 8px 30px rgba(8,42,61,.12);
  --read:760px;            /* leesbreedte tekst */
  --wide:1180px;           /* brede container */
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.font-tabular{font-variant-numeric:tabular-nums}

/* ---------- containers ---------- */
.wrap{max-width:var(--wide);margin:0 auto;padding:0 20px}
.read{max-width:var(--read);margin:0 auto;padding:0 20px}

/* ---------- typografie ---------- */
h1,h2,h3,h4{color:var(--ink);letter-spacing:-.3px;line-height:1.15}
h1{font-size:34px;font-weight:800;letter-spacing:-.6px;margin:.2em 0 .5em}
h2{font-size:26px;font-weight:700;margin:1.6em 0 .5em}
h3{font-size:19px;font-weight:600;margin:1.3em 0 .4em}
p{margin:0 0 1em}
ul,ol{padding-left:22px}
li{margin:.35em 0}
strong{color:var(--petrol-dark)}
small,.label{font-size:13px;font-weight:600;letter-spacing:.02em}

@media(min-width:760px){
  h1{font-size:40px}
  h2{font-size:28px}
  h3{font-size:20px}
}

/* ---------- knoppen ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-size:16px;font-weight:700;
  border:none;border-radius:var(--radius-sm);
  padding:13px 20px;cursor:pointer;text-decoration:none;
  transition:background .15s,box-shadow .15s,transform .05s;
  line-height:1.1;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--petrol);color:#fff}
.btn-primary:hover{background:var(--petrol-dark);color:#fff}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#138a3e;color:#fff}
.btn-outline{background:#fff;color:var(--petrol);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--petrol);color:var(--petrol)}
.btn-ghost{background:transparent;color:var(--petrol)}
.btn-lg{padding:15px 26px;font-size:17px}
.btn-block{display:flex;width:100%}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ==========================================================================
   HEADER + MEGA-MENU
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:1000;background:var(--petrol);color:#fff}
.site-header a{color:#fff}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:20px;letter-spacing:-.4px;flex-shrink:0}
.brand:hover{text-decoration:none}
.brand .mark{background:#fff;color:var(--petrol);border-radius:7px;padding:3px 9px;font-weight:800;line-height:1}
.brand .mark.green{background:var(--green);color:#fff}

.primary-nav{display:none}
@media(min-width:1000px){.primary-nav{display:block}}
.primary-nav>ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.primary-nav>ul>li{position:relative}
.primary-nav>ul>li>a{
  display:inline-flex;align-items:center;gap:5px;
  padding:10px 13px;font-size:15px;font-weight:600;border-radius:8px;opacity:.96
}
.primary-nav>ul>li>a:hover,.primary-nav>ul>li.open>a{background:rgba(255,255,255,.12);text-decoration:none}
.primary-nav .has-children>a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.7}

/* mega panel */
.primary-nav .sub-menu{
  list-style:none;margin:0;padding:10px;
  position:absolute;left:0;top:calc(100% + 6px);min-width:260px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s;
}
.primary-nav>ul>li:hover>.sub-menu,
.primary-nav>ul>li.open>.sub-menu{opacity:1;visibility:visible;transform:none}
.primary-nav .sub-menu a{
  display:block;color:var(--ink);padding:9px 12px;border-radius:8px;font-size:15px;font-weight:500
}
.primary-nav .sub-menu a:hover{background:var(--bg);color:var(--petrol);text-decoration:none}

.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.header-cta .btn{padding:10px 16px;font-size:15px}
.nav-toggle{display:inline-flex;flex-direction:column;gap:4px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:22px;height:2px;background:#fff;border-radius:2px}
@media(min-width:1000px){.nav-toggle{display:none}}

/* mobiel menu */
.mobile-nav{display:none;background:var(--petrol-dark);border-top:1px solid rgba(255,255,255,.12)}
.mobile-nav.open{display:block}
.mobile-nav ul{list-style:none;margin:0;padding:0}
.mobile-nav>ul{padding:8px 0}
.mobile-nav>ul>li{border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-nav>ul>li>a{display:block;padding:13px 20px;font-weight:600;font-size:16px}
.mobile-nav .sub-menu{padding:0 0 10px}
.mobile-nav .sub-menu a{display:block;padding:9px 20px 9px 34px;font-size:15px;opacity:.85}
.mobile-nav .m-cta{padding:14px 20px}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{background:linear-gradient(180deg,var(--petrol),#0c4a68);color:#fff}
.hero-inner{padding:42px 0 48px;text-align:center}
.hero h1{color:#fff;margin:0 auto .5em;max-width:760px}
.hero p.lead{color:rgba(255,255,255,.9);font-size:19px;max-width:640px;margin:0 auto 26px}
.hero .checker-widget{max-width:520px;margin:0 auto}

/* ==========================================================================
   KENTEKENTOOL-WIDGET
   ========================================================================== */
.kenteken-form{display:flex;gap:10px;align-items:stretch}
.kenteken-plate{
  display:flex;align-items:stretch;background:#FCD116;border:2px solid #11100c;border-radius:8px;overflow:hidden;flex:1;min-width:0;
  box-shadow:0 1px 0 rgba(0,0,0,.2)
}
.kenteken-plate .nl-strip{
  background:#1d4ed8;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:30px;flex-shrink:0;font-size:9px;font-weight:700;gap:2px;padding-top:4px
}
.kenteken-plate .nl-strip .stars{font-size:8px;line-height:1}
.kenteken-plate input{
  flex:1;min-width:0;border:0;background:transparent;
  font-family:"Kenteken",Inter,sans-serif;font-weight:800;
  font-size:26px;letter-spacing:2px;text-transform:uppercase;
  text-align:center;color:#11100c;padding:8px 6px
}
.kenteken-plate input::placeholder{color:#7a6b18}
.kenteken-plate input:focus{outline:none}
.kenteken-form .btn{flex-shrink:0}
@media(max-width:560px){
  .kenteken-form{flex-direction:column}
  .kenteken-plate input{font-size:22px}
}
.checker-widget .hint{font-size:13px;color:var(--muted);margin:8px 2px 0}
.hero .checker-widget .hint{color:rgba(255,255,255,.75)}

/* ==========================================================================
   STATUSLABEL (pil)
   ========================================================================== */
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  border-radius:var(--radius-pill);padding:8px 16px;font-weight:700;font-size:15px;line-height:1
}
.status-pill::before{content:"";width:9px;height:9px;border-radius:50%;background:currentColor}
.status-green{background:var(--green-soft);color:#0f7a37}
.status-amber{background:var(--amber-soft);color:#9a6206}
.status-red{background:var(--red-soft);color:#b3201f}
.status-neutral{background:var(--bg);color:var(--muted)}

/* ==========================================================================
   ANTWOORDBLOK / AANDACHTSBLOK
   ========================================================================== */
.answer-block{
  background:#fff;border:1px solid var(--line);border-left:5px solid var(--accent);
  border-radius:var(--radius);padding:20px 22px;margin:0 0 28px;box-shadow:var(--shadow)
}
.answer-block p:last-child{margin-bottom:0}
.notice{border-radius:var(--radius);padding:16px 18px;margin:22px 0;display:flex;gap:12px;align-items:flex-start}
.notice .ico{flex-shrink:0;margin-top:2px}
.notice p:last-child{margin-bottom:0}
.notice-amber{background:var(--amber-soft);border:1px solid #f3dca0}
.notice-red{background:var(--red-soft);border:1px solid #f3c0c0}
.notice-green{background:var(--green-soft);border:1px solid #b8e6c8}
.notice-petrol{background:#eef4f8;border:1px solid #cfe0ea}

/* ==========================================================================
   KAARTEN / INFORMATIEKAART
   ========================================================================== */
.card-grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

.info-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);transition:box-shadow .15s,transform .1s;
  display:block;color:var(--ink)
}
a.info-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);text-decoration:none}
.info-card .ico{width:38px;height:38px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--petrol);margin-bottom:12px}
.info-card h3{margin:0 0 4px;font-size:18px}
.info-card p{color:var(--muted);font-size:15px;margin:0}

/* ==========================================================================
   SECTIES
   ========================================================================== */
.section{padding:48px 0}
.section.alt{background:var(--bg)}
.section-head{text-align:center;max-width:620px;margin:0 auto 30px}
.section-head h2{margin:0 0 8px}
.section-head p{color:var(--muted);margin:0}

/* feiten-blok */
.facts{display:grid;gap:14px}
.fact{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.fact .k{font-weight:700;color:var(--petrol)}
.fact .src{font-size:13px;color:var(--muted)}

/* tabellen */
.content table,table.data{width:100%;border-collapse:collapse;margin:18px 0;font-size:16px;font-variant-numeric:tabular-nums}
.content th,.content td,table.data th,table.data td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.content th,table.data th{background:var(--bg);font-weight:700}
.table-scroll{overflow-x:auto}

/* ==========================================================================
   FAQ-ACCORDION
   ========================================================================== */
.faq{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.faq details{border-bottom:1px solid var(--line)}
.faq details:last-child{border-bottom:0}
.faq summary{
  list-style:none;cursor:pointer;padding:16px 18px;font-weight:600;font-size:17px;
  display:flex;justify-content:space-between;align-items:center;gap:12px
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--accent);font-weight:400;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq .faq-body{padding:0 18px 18px;color:var(--ink)}
.faq .faq-body p:last-child{margin-bottom:0}

/* ==========================================================================
   VERTROUWENSBLOK
   ========================================================================== */
.trust{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;margin:36px 0 0;font-size:14px;color:var(--muted)
}
.trust .row{display:flex;flex-wrap:wrap;gap:8px 20px;align-items:center}
.trust .badge{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--petrol)}
.trust .badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.trust .src{margin-top:8px}
.trust a{color:var(--petrol);text-decoration:underline}

/* ==========================================================================
   BROODKRUIMELS
   ========================================================================== */
.breadcrumbs{font-size:14px;color:var(--muted);padding:16px 0 0}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0}
.breadcrumbs li::after{content:"›";margin-left:6px;color:var(--line)}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--petrol)}
.breadcrumbs li[aria-current]{color:var(--ink);font-weight:600}

/* ==========================================================================
   CONTENT (geïmporteerde pagina's)
   ========================================================================== */
.page-head{padding:8px 0 0}
.page-head .lead{font-size:20px;color:var(--muted);max-width:680px}
.content{font-size:18px}
.content h2{scroll-margin-top:90px}
.content a{color:var(--accent);text-decoration:underline}
.content a:hover{color:var(--petrol)}
.content ul li::marker{color:var(--accent)}
.content figure{margin:1.4em 0}
.featured-img{border-radius:var(--radius);margin:0 0 24px;width:100%;box-shadow:var(--shadow)}

/* "lees ook" / verwante */
.related{margin-top:36px}
.related h2{font-size:20px}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--petrol);color:rgba(255,255,255,.82);margin-top:64px}
.site-footer a{color:rgba(255,255,255,.82)}
.site-footer a:hover{color:#fff}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px;padding:48px 0 36px}
@media(max-width:860px){.footer-cols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-cols{grid-template-columns:1fr}}
.footer-cols h4{color:#fff;font-size:15px;margin:0 0 14px}
.footer-cols ul{list-style:none;margin:0;padding:0}
.footer-cols li{margin:8px 0;font-size:15px}
.footer-brand .brand{margin-bottom:12px}
.footer-brand p{font-size:15px;line-height:1.55}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);font-size:13px;color:rgba(255,255,255,.65)}
.footer-bottom .wrap{padding-top:18px;padding-bottom:24px;display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:space-between}
.footer-disclaimer{max-width:760px}

/* ==========================================================================
   GARAGEZOEKER + KAART
   ========================================================================== */
.map-layout{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
@media(max-width:860px){.map-layout{grid-template-columns:1fr}}
#apk-map,.apk-map{height:560px;border-radius:var(--radius);border:1px solid var(--line);z-index:1}
@media(max-width:860px){#apk-map,.apk-map{height:360px;order:-1}}
.map-side{display:flex;flex-direction:column;min-height:0}
.map-search{position:relative;margin-bottom:12px}
.map-search input{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;font-size:16px;font-family:inherit}
.map-search input:focus{outline:none;border-color:var(--accent)}
.place-list{border:1px solid var(--line);border-radius:var(--radius);overflow-y:auto;max-height:500px;background:#fff}
.place-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer;width:100%;text-align:left;background:none;border-left:0;border-right:0;border-top:0;font:inherit;color:var(--ink)}
.place-item:first-child{border-top:0}
.place-item:last-child{border-bottom:0}
.place-item:hover{background:var(--bg);text-decoration:none}
.place-item .cnt{font-weight:700;color:var(--petrol);font-variant-numeric:tabular-nums;background:var(--bg);border-radius:var(--radius-pill);padding:2px 10px;font-size:13px}

/* ==========================================================================
   PLAATSPAGINA
   ========================================================================== */
.garage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.garage-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.garage-grid{grid-template-columns:1fr}}
.garage-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.garage-card .gn{font-weight:700;color:var(--ink);font-size:16px;margin-bottom:4px}
.garage-card .ga{color:var(--muted);font-size:14px;line-height:1.45;margin-bottom:10px}
.garage-badge{display:inline-flex;align-items:center;gap:6px;background:var(--green-soft);color:#0f7a37;font-size:12px;font-weight:700;border-radius:var(--radius-pill);padding:4px 10px}
.nearby-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:860px){.nearby-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.nearby-grid{grid-template-columns:1fr}}
.nearby-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.nearby-card:hover{border-color:var(--petrol);text-decoration:none}
.nearby-card .cnt{font-weight:700;color:var(--petrol);font-size:14px}

/* ==========================================================================
   TOOLS: checker resultaat
   ========================================================================== */
.result-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-top:24px}
.result-head{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:6px}
.result-plate{font-family:"Kenteken",Inter;font-weight:800;letter-spacing:2px;background:#FCD116;border:2px solid #11100c;border-radius:6px;padding:5px 12px;color:#11100c;font-size:18px}
.result-days{font-size:15px;color:var(--muted);margin:6px 0 18px}
.vehicle-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}
@media(max-width:560px){.vehicle-meta{grid-template-columns:1fr 1fr}}
.vehicle-meta .m{background:var(--bg);border-radius:var(--radius-sm);padding:12px 14px}
.vehicle-meta .m .lbl{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.vehicle-meta .m .val{font-weight:700;font-size:16px;margin-top:2px}
.history-list{list-style:none;padding:0;margin:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.history-list li{padding:11px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:12px;font-size:15px}
.history-list li:last-child{border-bottom:0}
.gebrek-list{margin:8px 0 0;padding-left:20px;font-size:15px;color:var(--ink)}
.next-steps{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
@media(max-width:560px){.next-steps{grid-template-columns:1fr}}
.skeleton{background:linear-gradient(90deg,#eef2f5 25%,#e2e8f0 50%,#eef2f5 75%);background-size:200% 100%;animation:sk 1.2s infinite;border-radius:8px}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--petrol);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.is-hidden{display:none!important}
.loading-row{display:flex;align-items:center;gap:12px;color:var(--muted);padding:18px 0}

/* ==========================================================================
   TOOLS: kostenindicatie
   ========================================================================== */
.tool-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;margin-bottom:6px;font-size:15px}
.field select,.field input[type=text],.field input[type=email]{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font-size:16px;font-family:inherit;background:#fff}
.field select:focus,.field input:focus{outline:none;border-color:var(--accent)}
.fuel-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.fuel-options label{display:flex;align-items:center;gap:10px;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;cursor:pointer;font-weight:600;margin:0}
.fuel-options label:has(input:checked){border-color:var(--petrol);background:#eef4f8}
.fuel-options input{accent-color:var(--petrol)}
.price-band{font-size:30px;font-weight:800;color:var(--petrol);margin:6px 0}

/* ==========================================================================
   TOOLS: checklist
   ========================================================================== */
.checklist-progress{position:sticky;top:72px;z-index:5;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow);margin-bottom:22px}
.checklist-progress .top{display:flex;justify-content:space-between;align-items:center;gap:12px;font-weight:600}
.progress-bar{height:10px;background:var(--bg);border-radius:999px;overflow:hidden;margin-top:10px}
.progress-bar>span{display:block;height:100%;background:var(--green);width:0;transition:width .3s}
.checklist-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.cl-category{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;background:#fff}
.cl-category>summary{list-style:none;cursor:pointer;padding:16px 18px;display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px}
.cl-category>summary::-webkit-details-marker{display:none}
.cl-category>summary .ico{width:34px;height:34px;border-radius:9px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--petrol);flex-shrink:0}
.cl-category>summary .meta{margin-left:auto;font-size:13px;color:var(--muted);font-weight:600}
.cl-category>summary::after{content:"";width:9px;height:9px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);flex-shrink:0;transition:transform .2s}
.cl-category[open]>summary::after{transform:rotate(-135deg)}
.cl-body{padding:0 18px 14px}
.cl-toelichting{color:var(--muted);font-size:15px;margin:0 0 12px}
.cl-item{display:flex;gap:12px;padding:11px 0;border-top:1px solid var(--line)}
.cl-item input[type=checkbox]{width:22px;height:22px;margin-top:2px;flex-shrink:0;accent-color:var(--green);cursor:pointer}
.cl-item .txt label{font-weight:700;cursor:pointer;display:block}
.cl-item .txt .check{color:var(--muted);font-size:15px;margin-top:2px}
.cl-item.done .txt label{color:var(--muted);text-decoration:line-through}
.checklist-done{background:var(--green-soft);border:1px solid #b8e6c8;color:#0f7a37;border-radius:var(--radius);padding:16px 18px;font-weight:600;margin-bottom:20px}

@media print{
  .site-header,.site-footer,.breadcrumbs,.checklist-actions,.checklist-progress .progress-bar,.no-print{display:none!important}
  .cl-category[open]>summary::after,.cl-category>summary::after{display:none}
  body{font-size:12pt}
  .cl-item input[type=checkbox]{-webkit-appearance:none;appearance:none;border:1.5px solid #333;background:#fff}
  .cl-category{break-inside:avoid;border:1px solid #999}
  details.cl-category:not([open])>*:not(summary){display:block!important}
}

/* ==========================================================================
   404
   ========================================================================== */
.error-404{text-align:center;padding:60px 0}
.error-404 .code{font-size:64px;font-weight:800;color:var(--petrol)}

/* utilities */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.text-center{text-align:center}
.muted{color:var(--muted)}
.stack>*+*{margin-top:16px}
.tag{display:inline-block;background:var(--bg);color:var(--muted);font-size:13px;font-weight:600;border-radius:var(--radius-pill);padding:3px 12px}
.meta-row{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:14px;color:var(--muted);margin:8px 0 20px}
