/*
Theme Name: KlusPlus
Theme URI: https://klusmetplus.nl
Author: Herman
Author URI: https://klusmetplus.nl
Description: Helder en toegankelijk WordPress-thema voor kennisblogs over klussen en doe-het-zelf. Met homepageslider, configureerbare contentrijen, sidebar, broodkruimels, automatische inhoudsopgave en EEAT-vriendelijke auteurspagina's.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: klusplus
Tags: blog, two-columns, right-sidebar, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
*/

/* ==========================================================================
   1. Design tokens
   ========================================================================== */
:root {
  --kp-ink: #1c1b19;
  --kp-ink-soft: #4a4843;
  --kp-muted: #79756d;
  --kp-paper: #faf8f4;
  --kp-surface: #ffffff;
  --kp-surface-2: #f3efe7;
  --kp-line: #e6e1d6;
  --kp-line-strong: #d6cfc0;
  --kp-accent: #e85c25;
  --kp-accent-dark: #c8470f;
  --kp-accent-soft: #fceee4;
  --kp-slate: #2f4858;
  --kp-slate-soft: #eef2f4;
  --kp-success: #2f7d4f;

  --kp-font-head: "Bricolage Grotesque", "DM Sans", system-ui, sans-serif;
  --kp-font-body: "DM Sans", system-ui, -apple-system, sans-serif;

  --kp-radius: 14px;
  --kp-radius-sm: 9px;
  --kp-shadow: 0 1px 2px rgba(28,27,25,.04), 0 8px 24px rgba(28,27,25,.06);
  --kp-shadow-lg: 0 4px 12px rgba(28,27,25,.06), 0 18px 50px rgba(28,27,25,.10);

  --kp-wrap: 1180px;
  --kp-wrap-narrow: 720px;
}

/* ==========================================================================
   2. Reset & base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--kp-font-body);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--kp-ink);
  background: var(--kp-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--kp-accent-dark); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--kp-font-head);
  font-weight: 700;
  line-height: 1.18;
  color: var(--kp-ink);
  letter-spacing: -.01em;
  margin: 0 0 .5em;
}
h1 { font-size: clamp(2rem, 4.5vw, 3.1rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); }
h3 { font-size: 1.35rem; }
p { margin: 0 0 1.2em; }

.kp-wrap { width: min(100% - 2.5rem, var(--kp-wrap)); margin-inline: auto; }
.kp-narrow { width: min(100% - 2.5rem, var(--kp-wrap-narrow)); margin-inline: auto; }
.screen-reader-text {
  position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px);
  white-space: nowrap; border: 0; padding: 0; margin: -1px;
}
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 999; background: var(--kp-ink);
  color: #fff; padding: .6rem 1rem; border-radius: 0 0 var(--kp-radius-sm) 0;
}
.skip-link:focus { left: 0; }

/* ==========================================================================
   3. Buttons & utilities
   ========================================================================== */
.kp-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--kp-font-head); font-weight: 600; font-size: .95rem;
  padding: .72rem 1.35rem; border-radius: 999px; border: 1.5px solid transparent;
  background: var(--kp-accent); color: #fff; cursor: pointer;
  transition: transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.kp-btn:hover { background: var(--kp-accent-dark); text-decoration: none; transform: translateY(-1px); color: #fff; }
.kp-btn--ghost { background: transparent; color: var(--kp-ink); border-color: var(--kp-line-strong); }
.kp-btn--ghost:hover { background: var(--kp-ink); color: #fff; border-color: var(--kp-ink); }
.kp-btn svg { width: 18px; height: 18px; }

.kp-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--kp-font-head); font-weight: 600; font-size: .72rem;
  letter-spacing: .12em; text-transform: uppercase; color: var(--kp-accent-dark);
}
.kp-eyebrow::before { content: ""; width: 1.6rem; height: 2px; background: var(--kp-accent); border-radius: 2px; }

.kp-tag {
  display: inline-block; font-family: var(--kp-font-head); font-weight: 600;
  font-size: .7rem; letter-spacing: .06em; text-transform: uppercase;
  color: var(--kp-slate); background: var(--kp-slate-soft);
  padding: .28rem .6rem; border-radius: 6px;
}

/* ==========================================================================
   4. Header
   ========================================================================== */
.kp-topbar {
  background: var(--kp-ink); color: #cfcabf; font-size: .82rem;
  font-family: var(--kp-font-head); font-weight: 500;
}
.kp-topbar .kp-wrap { display: flex; justify-content: space-between; align-items: center; min-height: 38px; gap: 1rem; }
.kp-topbar a { color: #fff; }
.kp-topbar__socials { display: flex; gap: .9rem; align-items: center; }
.kp-topbar__socials a { display: inline-flex; }
.kp-topbar__socials svg { width: 16px; height: 16px; }

.kp-header {
  position: sticky; top: 0; z-index: 50; background: var(--kp-surface);
  border-bottom: 1px solid var(--kp-line);
}
.kp-header__inner { display: flex; align-items: center; gap: 1.5rem; min-height: 76px; }
.kp-brand { display: flex; align-items: center; gap: .7rem; margin-right: auto; }
.kp-brand__logo { display: flex; align-items: center; }
.kp-brand__mark {
  width: 40px; height: 40px; border-radius: 11px; background: var(--kp-accent);
  display: grid; place-items: center; color: #fff; flex: none;
}
.kp-brand__mark svg { width: 22px; height: 22px; }
.kp-brand__name { font-family: var(--kp-font-head); font-weight: 800; font-size: 1.3rem; letter-spacing: -.02em; color: var(--kp-ink); }
.kp-brand__name b { color: var(--kp-accent); }
.kp-brand__tag { display: block; font-size: .72rem; font-weight: 500; color: var(--kp-muted); letter-spacing: .02em; }

.kp-nav { display: flex; }
.kp-nav ul { list-style: none; display: flex; gap: .3rem; margin: 0; padding: 0; }
.kp-nav a {
  display: block; font-family: var(--kp-font-head); font-weight: 600; font-size: .95rem;
  color: var(--kp-ink-soft); padding: .55rem .85rem; border-radius: 8px;
}
.kp-nav a:hover, .kp-nav .current-menu-item > a { color: var(--kp-ink); background: var(--kp-surface-2); text-decoration: none; }
.kp-nav .current-menu-item > a { color: var(--kp-accent-dark); }

.kp-header__actions { display: flex; align-items: center; gap: .5rem; }
.kp-iconbtn {
  display: grid; place-items: center; width: 42px; height: 42px; border-radius: 10px;
  border: 1px solid var(--kp-line); background: var(--kp-surface); color: var(--kp-ink);
  cursor: pointer;
}
.kp-iconbtn:hover { background: var(--kp-surface-2); }
.kp-iconbtn svg { width: 20px; height: 20px; }
.kp-menu-toggle { display: none; }

/* search drawer */
.kp-search-drawer {
  display: none; border-bottom: 1px solid var(--kp-line); background: var(--kp-surface);
  padding: 1rem 0;
}
.kp-search-drawer.is-open { display: block; }
.kp-search-form { display: flex; gap: .5rem; }
.kp-search-form input[type="search"] {
  flex: 1; padding: .8rem 1rem; border: 1.5px solid var(--kp-line-strong); border-radius: 10px;
  font-family: var(--kp-font-body); font-size: 1rem; background: var(--kp-paper);
}
.kp-search-form input[type="search"]:focus { outline: none; border-color: var(--kp-accent); }

/* ==========================================================================
   5. Hero slider
   ========================================================================== */
.kp-hero { padding: 2.5rem 0 1rem; }
.kp-slider { position: relative; }
.kp-slider__track { position: relative; }
.kp-slide {
  display: none; grid-template-columns: 1.15fr .85fr; gap: 0;
  background: var(--kp-surface); border: 1px solid var(--kp-line); border-radius: 22px; overflow: hidden;
  box-shadow: var(--kp-shadow);
}
.kp-slide.is-active { display: grid; animation: kp-fade .5s ease; }
@keyframes kp-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.kp-slide__media { position: relative; min-height: 340px; background: var(--kp-surface-2); }
.kp-slide__media img { width: 100%; height: 100%; object-fit: cover; }
.kp-slide__body { padding: clamp(1.5rem, 3vw, 2.75rem); display: flex; flex-direction: column; justify-content: center; }
.kp-slide__cat { margin-bottom: .9rem; }
.kp-slide__title { font-size: clamp(1.5rem, 2.6vw, 2.3rem); margin-bottom: .6rem; }
.kp-slide__title a { color: var(--kp-ink); }
.kp-slide__title a:hover { color: var(--kp-accent-dark); text-decoration: none; }
.kp-slide__excerpt { color: var(--kp-ink-soft); margin-bottom: 1.3rem; }
.kp-slide__meta { display: flex; align-items: center; gap: .6rem; font-size: .85rem; color: var(--kp-muted); margin-bottom: 1.4rem; }

.kp-slider__nav { display: flex; align-items: center; justify-content: space-between; margin-top: 1.1rem; }
.kp-slider__dots { display: flex; gap: .5rem; }
.kp-dot { width: 9px; height: 9px; border-radius: 999px; border: 0; background: var(--kp-line-strong); cursor: pointer; padding: 0; transition: width .2s, background .2s; }
.kp-dot.is-active { width: 26px; background: var(--kp-accent); }
.kp-slider__arrows { display: flex; gap: .5rem; }

/* ==========================================================================
   6. Sections
   ========================================================================== */
.kp-section { padding: 3.2rem 0; }
.kp-section__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 1.8rem; flex-wrap: wrap; }
.kp-section__head h2 { margin: .35rem 0 0; }
.kp-section--alt { background: var(--kp-surface-2); border-block: 1px solid var(--kp-line); }

/* category cards */
.kp-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.kp-cat {
  display: flex; flex-direction: column; gap: .6rem; padding: 1.3rem;
  background: var(--kp-surface); border: 1px solid var(--kp-line); border-radius: var(--kp-radius);
  transition: transform .15s, box-shadow .2s, border-color .2s; color: var(--kp-ink);
}
.kp-cat:hover { transform: translateY(-3px); box-shadow: var(--kp-shadow); border-color: var(--kp-line-strong); text-decoration: none; }
.kp-cat__icon { width: 46px; height: 46px; border-radius: 12px; background: var(--kp-accent-soft); color: var(--kp-accent-dark); display: grid; place-items: center; }
.kp-cat__icon svg { width: 24px; height: 24px; }
.kp-cat h3 { font-size: 1.1rem; margin: 0; }
.kp-cat span { font-size: .85rem; color: var(--kp-muted); }

/* feature rows */
.kp-rows { display: flex; flex-direction: column; gap: 2.6rem; }
.kp-row { display: grid; grid-template-columns: 1fr 1fr; gap: 2.6rem; align-items: center; }
.kp-row--flip .kp-row__media { order: 2; }
.kp-row__media img { border-radius: 18px; box-shadow: var(--kp-shadow); width: 100%; aspect-ratio: 16/11; object-fit: cover; }
.kp-row__media .kp-ph { aspect-ratio: 16/11; border-radius: 18px; background: linear-gradient(135deg, var(--kp-surface-2), var(--kp-slate-soft)); display: grid; place-items: center; color: var(--kp-line-strong); }
.kp-row__media .kp-ph svg { width: 60px; height: 60px; }
.kp-row h2 { margin-top: .5rem; }
.kp-row p { color: var(--kp-ink-soft); font-size: 1.08rem; }

/* ==========================================================================
   7. Post cards / grid
   ========================================================================== */
.kp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.kp-card {
  display: flex; flex-direction: column; background: var(--kp-surface);
  border: 1px solid var(--kp-line); border-radius: var(--kp-radius); overflow: hidden;
  transition: transform .15s, box-shadow .2s; height: 100%;
}
.kp-card:hover { transform: translateY(-3px); box-shadow: var(--kp-shadow-lg); }
.kp-card__media { position: relative; aspect-ratio: 16/10; background: var(--kp-surface-2); overflow: hidden; }
.kp-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.kp-card:hover .kp-card__media img { transform: scale(1.04); }
.kp-card__cat { position: absolute; top: .8rem; left: .8rem; background: rgba(255,255,255,.94); color: var(--kp-slate); }
.kp-card__body { padding: 1.2rem 1.25rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.kp-card__title { font-size: 1.2rem; margin: 0 0 .5rem; line-height: 1.3; }
.kp-card__title a { color: var(--kp-ink); }
.kp-card__title a:hover { color: var(--kp-accent-dark); text-decoration: none; }
.kp-card__excerpt { color: var(--kp-ink-soft); font-size: .95rem; margin: 0 0 1rem; }
.kp-card__meta { margin-top: auto; display: flex; align-items: center; gap: .5rem; font-size: .82rem; color: var(--kp-muted); }
.kp-card__meta .kp-reading { margin-left: auto; }

/* ==========================================================================
   8. Layout with sidebar
   ========================================================================== */
.kp-layout { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 2.6rem; padding: 2.6rem 0 3.5rem; align-items: start; }
.kp-layout--full { grid-template-columns: minmax(0,1fr); }

/* breadcrumbs */
.kp-crumbs { font-size: .82rem; color: var(--kp-muted); padding: 1.1rem 0 0; display: flex; flex-wrap: wrap; gap: .35rem; align-items: center; }
.kp-crumbs a { color: var(--kp-ink-soft); }
.kp-crumbs .sep { color: var(--kp-line-strong); }

/* ==========================================================================
   9. Single post
   ========================================================================== */
.kp-article__header { margin-bottom: 1.6rem; }
.kp-article__title { margin: .6rem 0 .8rem; }
.kp-article__meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: .65rem 1rem;
  padding-bottom: 1.3rem; border-bottom: 1px solid var(--kp-line); font-size: .9rem; color: var(--kp-muted);
}
.kp-author-chip { display: inline-flex; align-items: center; gap: .55rem; }
.kp-author-chip img { width: 34px; height: 34px; border-radius: 999px; }
.kp-author-chip b { color: var(--kp-ink); font-weight: 600; }
.kp-meta-item { display: inline-flex; align-items: center; gap: .35rem; }
.kp-meta-item svg { width: 15px; height: 15px; color: var(--kp-line-strong); }
.kp-updated { color: var(--kp-success); font-weight: 600; }

.kp-featured { margin: 1.6rem 0; }
.kp-featured img { border-radius: 18px; width: 100%; }
.kp-featured figcaption { font-size: .8rem; color: var(--kp-muted); margin-top: .5rem; text-align: center; }

/* table of contents */
.kp-toc {
  background: var(--kp-surface); border: 1px solid var(--kp-line); border-left: 3px solid var(--kp-accent);
  border-radius: var(--kp-radius); padding: 1.2rem 1.4rem; margin: 1.8rem 0;
}
.kp-toc__title { font-family: var(--kp-font-head); font-weight: 700; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--kp-slate); margin-bottom: .7rem; }
.kp-toc ol { margin: 0; padding-left: 1.1rem; }
.kp-toc li { margin: .25rem 0; }
.kp-toc a { color: var(--kp-ink-soft); }
.kp-toc a:hover { color: var(--kp-accent-dark); }
.kp-toc .lvl-3 { margin-left: .9rem; font-size: .92rem; }

/* content typography */
.kp-content { font-size: 1.12rem; line-height: 1.78; }
.kp-content > * { scroll-margin-top: 96px; }
.kp-content h2 { margin-top: 2.2rem; padding-top: .2rem; }
.kp-content h3 { margin-top: 1.7rem; }
.kp-content img, .kp-content figure { border-radius: 12px; }
.kp-content figure { margin: 1.8rem 0; }
.kp-content figcaption { font-size: .85rem; color: var(--kp-muted); text-align: center; margin-top: .5rem; }
.kp-content blockquote {
  margin: 1.8rem 0; padding: 1.1rem 1.5rem; border-left: 4px solid var(--kp-accent);
  background: var(--kp-accent-soft); border-radius: 0 var(--kp-radius-sm) var(--kp-radius-sm) 0;
  font-size: 1.18rem; font-family: var(--kp-font-head); color: var(--kp-ink);
}
.kp-content blockquote p:last-child { margin-bottom: 0; }
.kp-content ul, .kp-content ol { padding-left: 1.4rem; }
.kp-content li { margin: .4rem 0; }
.kp-content a { text-decoration: underline; text-underline-offset: 2px; }
.kp-content code { background: var(--kp-surface-2); padding: .15em .4em; border-radius: 5px; font-size: .9em; }
.kp-content table { width: 100%; border-collapse: collapse; margin: 1.6rem 0; font-size: .96rem; }
.kp-content th, .kp-content td { border: 1px solid var(--kp-line); padding: .65rem .8rem; text-align: left; }
.kp-content th { background: var(--kp-surface-2); font-family: var(--kp-font-head); }

/* callout helper (klus tip) */
.kp-callout {
  display: flex; gap: .9rem; background: var(--kp-slate-soft); border-radius: var(--kp-radius);
  padding: 1.1rem 1.3rem; margin: 1.8rem 0; border: 1px solid var(--kp-line);
}
.kp-callout svg { width: 22px; height: 22px; color: var(--kp-slate); flex: none; margin-top: .2rem; }

/* tags + share */
.kp-article__footer { margin-top: 2.2rem; padding-top: 1.5rem; border-top: 1px solid var(--kp-line); display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: center; }
.kp-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.kp-share { display: flex; gap: .5rem; }

/* author box (EEAT) */
.kp-authorbox {
  display: flex; gap: 1.3rem; background: var(--kp-surface); border: 1px solid var(--kp-line);
  border-radius: 18px; padding: 1.6rem; margin: 2.4rem 0;
}
.kp-authorbox img { width: 76px; height: 76px; border-radius: 18px; flex: none; }
.kp-authorbox__role { font-family: var(--kp-font-head); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--kp-accent-dark); font-weight: 700; }
.kp-authorbox h3 { font-size: 1.25rem; margin: .25rem 0 .4rem; }
.kp-authorbox p { color: var(--kp-ink-soft); font-size: .96rem; margin: 0 0 .7rem; }
.kp-authorbox__links { display: flex; gap: .8rem; font-size: .85rem; }

/* related */
.kp-related { margin: 2.6rem 0 0; }

/* ==========================================================================
   10. Sidebar widgets
   ========================================================================== */
.kp-sidebar { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 1.5rem; }
.kp-widget { background: var(--kp-surface); border: 1px solid var(--kp-line); border-radius: var(--kp-radius); padding: 1.4rem; }
.kp-widget__title { font-family: var(--kp-font-head); font-weight: 700; font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--kp-slate); margin: 0 0 1rem; padding-bottom: .7rem; border-bottom: 1px solid var(--kp-line); }
.kp-widget ul { list-style: none; margin: 0; padding: 0; }
.kp-widget li { padding: .45rem 0; border-bottom: 1px dashed var(--kp-line); }
.kp-widget li:last-child { border-bottom: 0; }
.kp-widget a { color: var(--kp-ink-soft); }
.kp-widget a:hover { color: var(--kp-accent-dark); }

.kp-about-widget { background: var(--kp-slate); color: #e8eef1; border-color: var(--kp-slate); }
.kp-about-widget .kp-widget__title { color: #fff; border-color: rgba(255,255,255,.15); }
.kp-about-widget p { color: #c9d4da; font-size: .92rem; }
.kp-about-widget img { width: 64px; height: 64px; border-radius: 14px; margin-bottom: .8rem; }

.kp-pop-item { display: flex; gap: .8rem; align-items: center; }
.kp-pop-item img { width: 58px; height: 58px; border-radius: 10px; object-fit: cover; flex: none; }
.kp-pop-item b { display: block; font-family: var(--kp-font-head); font-size: .92rem; line-height: 1.3; }
.kp-pop-item span { font-size: .78rem; color: var(--kp-muted); }

.kp-newsletter { background: var(--kp-accent-soft); border-color: #f3d9c8; }
.kp-newsletter input[type="email"] { width: 100%; padding: .7rem .9rem; border: 1.5px solid #eac4ac; border-radius: 9px; margin-bottom: .6rem; font-family: var(--kp-font-body); }
.kp-newsletter .kp-btn { width: 100%; justify-content: center; }

/* ==========================================================================
   11. Archive header
   ========================================================================== */
.kp-archive-head { padding: 2.4rem 0 .5rem; }
.kp-archive-head h1 { margin: .4rem 0 .3rem; }
.kp-archive-head .kp-count { color: var(--kp-muted); font-size: .95rem; }

/* pagination */
.kp-pagination { display: flex; gap: .4rem; justify-content: center; margin-top: 2.8rem; flex-wrap: wrap; }
.kp-pagination a, .kp-pagination span {
  min-width: 42px; height: 42px; display: grid; place-items: center; padding: 0 .6rem;
  border: 1px solid var(--kp-line); border-radius: 10px; font-family: var(--kp-font-head); font-weight: 600; color: var(--kp-ink);
}
.kp-pagination .current { background: var(--kp-accent); color: #fff; border-color: var(--kp-accent); }
.kp-pagination a:hover { background: var(--kp-surface-2); text-decoration: none; }

/* ==========================================================================
   12. Author archive (EEAT page)
   ========================================================================== */
.kp-author-hero { background: var(--kp-surface-2); border-bottom: 1px solid var(--kp-line); padding: 2.8rem 0; }
.kp-author-hero__inner { display: flex; gap: 1.6rem; align-items: center; }
.kp-author-hero img { width: 110px; height: 110px; border-radius: 24px; flex: none; box-shadow: var(--kp-shadow); }
.kp-author-hero h1 { margin: 0 0 .3rem; }
.kp-author-hero .kp-author-role { color: var(--kp-accent-dark); font-family: var(--kp-font-head); font-weight: 700; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; }
.kp-author-hero p { color: var(--kp-ink-soft); max-width: 60ch; margin: .6rem 0 0; }
.kp-author-stats { display: flex; gap: 1.8rem; margin-top: 1rem; font-size: .9rem; }
.kp-author-stats b { font-family: var(--kp-font-head); display: block; font-size: 1.3rem; color: var(--kp-ink); }

/* ==========================================================================
   13. Comments
   ========================================================================== */
.kp-comments { margin-top: 2.6rem; padding-top: 1.6rem; border-top: 1px solid var(--kp-line); }
.kp-comments ol { list-style: none; padding: 0; }
.kp-comments .children { list-style: none; padding-left: 1.6rem; }
.comment-body { background: var(--kp-surface); border: 1px solid var(--kp-line); border-radius: var(--kp-radius); padding: 1.1rem 1.3rem; margin-bottom: 1rem; }
.comment-author { font-family: var(--kp-font-head); font-weight: 700; }
.comment-author img { border-radius: 999px; vertical-align: middle; margin-right: .5rem; }
.comment-meta { font-size: .8rem; color: var(--kp-muted); margin-bottom: .6rem; }
.comment-form input[type=text], .comment-form input[type=email], .comment-form input[type=url], .comment-form textarea {
  width: 100%; padding: .7rem .9rem; border: 1.5px solid var(--kp-line-strong); border-radius: 9px; font-family: var(--kp-font-body); margin-bottom: .8rem;
}

/* ==========================================================================
   14. Footer
   ========================================================================== */
.kp-footer { background: var(--kp-ink); color: #b8b3a8; margin-top: 3rem; }
.kp-footer a { color: #e6e1d6; }
.kp-footer a:hover { color: #fff; }
.kp-footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; padding: 3rem 0 2.4rem; }
.kp-footer__brand .kp-brand__name { color: #fff; }
.kp-footer__brand p { color: #959086; font-size: .92rem; max-width: 34ch; }
.kp-footer h4 { color: #fff; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; margin: 0 0 1rem; }
.kp-footer ul { list-style: none; margin: 0; padding: 0; }
.kp-footer li { margin: .4rem 0; }
.kp-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 1.2rem 0; display: flex; justify-content: space-between; gap: 1rem; font-size: .82rem; flex-wrap: wrap; }
.kp-footer__socials { display: flex; gap: .8rem; }
.kp-footer__socials a { display: inline-flex; }
.kp-footer__socials svg { width: 18px; height: 18px; }

/* ==========================================================================
   15. Responsive
   ========================================================================== */
@media (max-width: 1024px) {
  .kp-cats { grid-template-columns: repeat(2, 1fr); }
  .kp-grid { grid-template-columns: repeat(2, 1fr); }
  .kp-layout { grid-template-columns: 1fr; }
  .kp-sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
  .kp-sidebar .kp-widget { flex: 1 1 280px; }
  .kp-footer__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .kp-menu-toggle { display: grid; }
  .kp-nav { position: fixed; inset: 76px 0 auto 0; background: var(--kp-surface); border-bottom: 1px solid var(--kp-line); padding: 1rem 1.25rem; display: none; box-shadow: var(--kp-shadow-lg); }
  .kp-nav.is-open { display: block; }
  .kp-nav ul { flex-direction: column; gap: 0; }
  .kp-nav a { padding: .8rem .5rem; border-bottom: 1px solid var(--kp-line); border-radius: 0; }
  .kp-slide { grid-template-columns: 1fr; }
  .kp-slide__media { min-height: 220px; order: -1; }
  .kp-row, .kp-row--flip .kp-row__media { grid-template-columns: 1fr; order: 0; }
  .kp-row__media { order: -1; }
  .kp-author-hero__inner { flex-direction: column; text-align: center; }
}
@media (max-width: 560px) {
  .kp-cats { grid-template-columns: 1fr; }
  .kp-grid { grid-template-columns: 1fr; }
  .kp-footer__top { grid-template-columns: 1fr; }
  .kp-topbar { display: none; }
  .kp-authorbox { flex-direction: column; }
}
