/* ============================================================
   Krümelkiste — main.css
   Konsolidierter <style>-Block aus den Design-Dateien (Home ist
   am vollstaendigsten) + zusaetzliche Klassen aus Artikel,
   Kategorie, Vergleich, Kontakt, Suche, Checkliste und den
   Rechtstext-Seiten. Plus re-angehaengte Latest-Fix-CSS
   (Karten-Klassen, Mobile-Umbruch, Mobile-Ueberlauf, a11y).
   ============================================================ */

*{box-sizing:border-box}
:root{
  --kk-bg:#F8F4ED;--kk-paper:#FFFFFF;--kk-ink:#2A2D2A;--kk-muted:#6B6E6B;
  --kk-accent:#9CAF88;--kk-accent-d:#73895F;--kk-accent-soft:#D4DCC5;--kk-pop:#E0B33B;--kk-pop-d:#B98F22;
  --kk-border:#E6E2D8;--kk-shadow:0 4px 20px rgba(42,45,42,.07)
}
html{scroll-behavior:smooth}
/* Home-Sektions-Anker (siehe Home .dc.html scroll-margin-top) */
#kategorien,#tests,#checkliste,#newsletter{scroll-margin-top:92px}
html,body{margin:0;padding:0;background:var(--kk-bg);color:var(--kk-ink);font-family:'Inter',system-ui,sans-serif;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip}
::selection{background:rgba(156,175,136,.24)}
a{color:inherit;text-decoration:none}
input,button,textarea,select{font-family:inherit}
img{max-width:100%;height:auto}
.kk-d{font-family:'Playfair Display',Georgia,serif}
.kk-mono{font-family:'JetBrains Mono',monospace}
.kk-kicker{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--kk-accent-d)}

/* ---------- Scroll-Reveal ---------- */
[data-rv]{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1)}
[data-rv].in{opacity:1;transform:none}

/* ---------- Animierter Unterstrich-Link ---------- */
.kk-link,.kk-ul{position:relative}
.kk-link::after,.kk-ul::after{content:'';position:absolute;left:0;right:100%;bottom:-3px;height:2px;border-radius:2px;background:var(--kk-accent);transition:right .35s}
.kk-link:hover::after,.kk-ul:hover::after{right:0}

/* ---------- Buttons / Karten / Kacheln (Hover) ---------- */
.kk-btn{transition:transform .3s,box-shadow .3s}
.kk-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(156,175,136,.28)}
.kk-card{transition:transform .4s cubic-bezier(.22,.61,.36,1),box-shadow .4s}
.kk-card:hover{transform:translateY(-6px);box-shadow:0 22px 46px rgba(42,45,42,.13)}
.kk-card:hover .kk-img,.kk-card:hover .kk-cimg{transform:scale(1.05)}
.kk-tile{transition:transform .4s cubic-bezier(.22,.61,.36,1),box-shadow .4s}
.kk-tile:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(42,45,42,.14)}
.kk-tile:hover .kk-img,.kk-tile:hover .kk-cimg{transform:scale(1.06)}
.kk-tile:hover .kk-arr{transform:translateX(4px)}
.kk-pin{opacity:0;transform:translateY(-6px);transition:opacity .3s,transform .3s,filter .25s}
.kk-tile:hover .kk-pin,.kk-card:hover .kk-pin,.kk-pin:focus-visible{opacity:1;transform:none}
.kk-pin:hover{filter:brightness(1.08)}
@media(hover:none){.kk-pin{opacity:1;transform:none}}

/* ---------- Karussell (Tests) ---------- */
.kk-rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 16px;-ms-overflow-style:none;scrollbar-width:none}
.kk-rail::-webkit-scrollbar{display:none}
.kk-slide{scroll-snap-align:start;flex:0 0 clamp(260px,30vw,330px)}

/* ---------- Bento-Raster (Kategorien Home) ---------- */
.kk-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;grid-template-areas:"big big a b" "big big c d" "e e f f"}
@media(max-width:940px){.kk-hero{grid-template-columns:1fr!important}.kk-2col{grid-template-columns:1fr!important}.kk-bento{grid-template-columns:1fr 1fr;grid-auto-rows:180px;grid-template-areas:"big big" "a b" "c d" "e e" "f f"}}
@media(max-width:620px){.kk-nav-d{display:none!important}.kk-hide-sm{display:none!important}.kk-bento{grid-template-columns:1fr;grid-auto-rows:168px;grid-template-areas:"big" "a" "b" "c" "d" "e" "f"}}

/* ---------- Bild-Platzhalter (ersetzt <image-slot>) ---------- */
.kk-ph-img{display:block;width:100%;height:100%;background:linear-gradient(150deg,#eef1e6 0%,var(--kk-accent-soft) 55%,#c8d3b6 100%);position:relative}
.kk-ph-img::after{content:"Krümelkiste";position:absolute;inset:0;display:grid;place-items:center;font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(16px,3vw,26px);color:rgba(115,137,95,.5);letter-spacing:.01em}

/* ---------- Beitragskarte — KLASSENBASIERT (robust, unabhaengig von Inline-Styles) ----------
   Layout/Optik kommen komplett aus diesen Klassen, damit Karten auch dann
   korrekt aussehen, wenn Inline-Styles fehlen (Optimizer/AMP/alte Datei).
   Container = <article>, ganzer Klickbereich ueber stretched link auf dem Titel;
   Pinterest-"Merken"-Button ist ein SEPARATES <a> (keine verschachtelten Anchors). */
.kk-postgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;align-items:stretch}
.kk-postgrid--wide{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px}
@media(max-width:540px){.kk-postgrid{grid-template-columns:1fr;gap:18px}}
.kk-card{position:relative;display:flex;flex-direction:column;height:100%;border-radius:20px;overflow:hidden;background:var(--kk-paper);border:1px solid var(--kk-border);box-shadow:var(--kk-shadow);color:inherit;text-decoration:none}
.kk-card__link{color:inherit;text-decoration:none}
.kk-card__link::after{content:"";position:absolute;inset:0;z-index:1}
.kk-card__media{position:relative;display:block;aspect-ratio:4/3;min-height:150px;overflow:hidden;background:linear-gradient(150deg,#eef1e6,var(--kk-accent-soft) 55%,#c8d3b6)}
.kk-card__media>img,.kk-card__media .kk-cimg,.kk-card__media .kk-ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.kk-card__cat{position:absolute;left:11px;top:11px;z-index:3;padding:5px 11px;border-radius:999px;background:rgba(255,255,255,.94);color:var(--kk-ink);font-size:10.5px;font-weight:800;letter-spacing:.03em}
.kk-card__body{display:flex;flex-direction:column;flex:1;padding:16px 18px 18px}
.kk-card__title{margin:0;font-family:'Playfair Display',Georgia,serif;font-size:18.5px;font-weight:600;line-height:1.22;color:var(--kk-ink)}
.kk-card__meta{display:flex;align-items:center;gap:9px;margin-top:auto;padding-top:12px;font-size:12px;font-weight:600;color:var(--kk-muted)}
.kk-card__meta .kk-dot{opacity:.5}
.kk-card__more{font-weight:700;color:var(--kk-accent-d);margin-left:auto}
/* Pinterest-"Merken"-Button als Overlay (klassenbasiert) */
.kk-pin--mini,.kk-pin--card{position:absolute;top:13px;right:13px;z-index:4;background:#e60023;color:#fff;box-shadow:0 8px 20px rgba(230,0,35,.4);cursor:pointer}
.kk-pin--mini{display:grid;place-items:center;width:32px;height:32px;border-radius:50%}
.kk-pin--card{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;font-size:11.5px;font-weight:800}

/* ---------- Artikel-Body (single / .kk-prose) ---------- */
.kk-prose>p{margin:0 0 22px;font-size:17.5px;line-height:1.85;color:rgba(42,45,42,.85)}
.kk-prose h2{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:clamp(24px,3vw,32px);letter-spacing:-.01em;margin:40px 0 14px;color:var(--kk-ink)}
.kk-prose h3{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:clamp(20px,2.4vw,25px);margin:30px 0 10px;color:var(--kk-ink)}
.kk-prose ul,.kk-prose ol{margin:0 0 22px;padding-left:22px}
.kk-prose li{font-size:17px;line-height:1.8;color:rgba(42,45,42,.85);margin:0 0 9px}
.kk-prose strong{font-weight:700;color:var(--kk-ink)}
.kk-prose a{color:var(--kk-accent-d);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(115,137,95,.5)}
.kk-prose img{border-radius:14px;margin:30px 0;box-shadow:0 18px 44px rgba(42,45,42,.12)}
.kk-prose blockquote{margin:28px 0;padding:18px 26px;border-left:3px solid var(--kk-accent);font-family:'Playfair Display',Georgia,serif;font-size:clamp(20px,2.4vw,22px);font-style:italic;line-height:1.45;color:var(--kk-ink)}
.kk-prose blockquote p{margin:0;font-size:inherit;line-height:inherit;color:inherit}

/* ---------- Mobile-Ueberlauf verhindern (Latest-Fix) ----------
   Grid-/Flex-Spalten duerfen nicht durch breite Inhalte (Tabellen, Code,
   lange URLs) gesprengt werden; breite Tabellen scrollen innerhalb des Textes. */
.kk-art,.kk-art>*,.kk-2col,.kk-2col>*,.kk-prose{min-width:0}
.kk-prose{overflow-wrap:break-word;word-wrap:break-word}
.kk-prose table{display:block;width:100%;max-width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.kk-prose figure,.kk-prose .wp-block-table{max-width:100%;overflow-x:auto;margin-left:0;margin-right:0}
.kk-prose pre{max-width:100%;overflow-x:auto}

/* ---------- Vergleichs-/Bestenlisten-Karten ---------- */
.kk-vrow{transition:transform .4s,box-shadow .4s}
.kk-vrow:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(42,45,42,.12)}
.kk-tablewrap{overflow-x:auto}
.kk-ctable{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
.kk-ctable td,.kk-ctable th{padding:14px 18px;border-bottom:1px solid var(--kk-border)}
.kk-ctable th{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--kk-muted)}

/* ---------- Rechtstext / Lese-Seiten ---------- */
.kk-legal h2{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:clamp(21px,3vw,24px);margin:32px 0 9px;color:var(--kk-ink)}
.kk-legal h3{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:18px;margin:24px 0 8px;color:var(--kk-ink)}
.kk-legal p{font-size:15.5px;line-height:1.75;color:var(--kk-muted);margin:0 0 12px}
.kk-legal ul,.kk-legal ol{margin:0 0 14px;padding-left:22px;font-size:15.5px;line-height:1.75;color:var(--kk-muted)}
.kk-legal strong{color:var(--kk-ink);font-weight:700}
.kk-legal a{color:var(--kk-accent-d);text-decoration:underline;text-underline-offset:3px}

/* ---------- Formularfelder (Kontakt) ---------- */
.kk-in{padding:14px 16px;border-radius:13px;border:1px solid var(--kk-border);background:var(--kk-bg);font-size:15px;color:var(--kk-ink);outline:none;width:100%;transition:border-color .3s}
.kk-in:focus{border-color:var(--kk-accent);box-shadow:0 0 0 4px rgba(156,175,136,.18)}

/* ---------- WP-Pagination ---------- */
.kk-pagination{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:50px;flex-wrap:wrap}
.kk-pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 14px;border-radius:12px;border:1px solid var(--kk-border);background:var(--kk-paper);font-family:'Playfair Display',serif;font-size:15px;color:var(--kk-ink);transition:border-color .3s,color .3s}
.kk-pagination .page-numbers:hover{border-color:var(--kk-accent);color:var(--kk-accent-d)}
.kk-pagination .page-numbers.current{border-color:transparent;background:var(--kk-accent);color:#fff}
.kk-pagination .page-numbers.dots{border:none;background:transparent;color:var(--kk-muted)}

/* ---------- Kommentare ---------- */
.kk-comments{max-width:760px;margin:48px auto 0;padding:0 clamp(20px,5vw,40px)}
.kk-comments .comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.kk-comments .comment-list ul.children{list-style:none;margin:14px 0 0 24px;padding-left:18px;border-left:2px solid var(--kk-border);display:flex;flex-direction:column;gap:16px}
.kk-comment-body{padding:22px 24px;border-radius:16px;background:var(--kk-paper);border:1px solid var(--kk-border);box-shadow:var(--kk-shadow)}
.kk-comments .comment-author{font-weight:700;color:var(--kk-ink)}
.kk-comments .comment-meta{font-size:12px;color:var(--kk-muted);margin-bottom:8px}
.kk-comments p{font-size:14.5px;line-height:1.65;color:rgba(42,45,42,.78)}
.kk-comment-form input[type=text],.kk-comment-form input[type=email],.kk-comment-form input[type=url],.kk-comment-form textarea{width:100%;padding:14px 16px;border-radius:12px;border:1px solid var(--kk-border);background:var(--kk-paper);color:var(--kk-ink);font-size:14.5px;outline:none;margin-bottom:14px;transition:border-color .3s,box-shadow .3s}
.kk-comment-form input:focus,.kk-comment-form textarea:focus{border-color:var(--kk-accent);box-shadow:0 0 0 4px rgba(156,175,136,.18)}
.kk-comment-form .submit{padding:14px 30px;border:none;border-radius:12px;font-size:14.5px;font-weight:700;color:#fff;background:var(--kk-accent);box-shadow:0 12px 28px rgba(156,175,136,.32);cursor:pointer;transition:transform .35s}
.kk-comment-form .submit:hover{transform:translateY(-2px)}

/* ---------- Affiliate-Box-Shortcode ---------- */
.kk-affbox{margin:32px 0;background:var(--kk-paper);border:1px solid var(--kk-border);border-left:4px solid var(--kk-pop);border-radius:0 16px 16px 0;padding:22px 24px;box-shadow:var(--kk-shadow)}

/* ---------- Checkliste (Page-Template) ---------- */
.kk-clitem{display:flex;align-items:flex-start;gap:13px;padding:11px 0;border-bottom:1px solid var(--kk-border);cursor:pointer}
.kk-clitem:last-child{border-bottom:none}
.kk-clbox{flex:none;width:22px;height:22px;border-radius:7px;border:2px solid var(--kk-accent);display:grid;place-items:center;margin-top:1px;transition:background .2s,border-color .2s;color:#fff}
.kk-clbox svg{opacity:0;transition:opacity .2s}
.kk-clitem.done .kk-clbox{background:var(--kk-accent);border-color:var(--kk-accent)}
.kk-clitem.done .kk-clbox svg{opacity:1}
.kk-clitem.done .kk-cllabel{text-decoration:line-through;color:var(--kk-muted)}
.kk-print-only{display:none}
@media print{
  @page{margin:14mm}
  html,body{background:#fff!important}
  .kk-no-print{display:none!important}
  .kk-print-only{display:block!important}
  #kk-print-area{box-shadow:none!important;border:none!important;padding:0!important;margin:0!important;max-width:none!important}
  .kk-clgroup{break-inside:avoid;border:1px solid #ccc!important;box-shadow:none!important}
  .kk-clbox{border-color:#333!important}
  *{color:#000!important}
}

/* ---------- Sitemap ---------- */
.kk-slink{display:inline-block;padding:5px 0;font-size:15px;color:var(--kk-muted);transition:color .25s,padding-left .25s}
.kk-slink:hover{color:var(--kk-accent-d);padding-left:6px}

/* ---------- Skip-Link (a11y) ---------- */
.kk-skip{position:absolute;left:-9999px;top:0;z-index:300;padding:12px 20px;background:#fff;color:var(--kk-ink);border-radius:0 0 12px 0}
.kk-skip:focus{left:0}

/* ---------- Nav / Responsive Latest-Fixes ---------- */
@media(max-width:620px){.kk-nav-d{display:none!important}.kk-hide-sm{display:none!important}}
@media(max-width:960px){.kk-2col{grid-template-columns:1fr!important}}
/* Artikel-Seitenleiste, Vergleichskarte & feste Raster mobil voll umbrechen */
@media(max-width:900px){.kk-art{grid-template-columns:1fr!important}.kk-aside{position:static!important}.kk-vrow,.kk-vcard,.kk-rank-row{grid-template-columns:1fr!important}}
@media(max-width:760px){.kk-smap{grid-template-columns:1fr!important}.kk-clgroups{grid-template-columns:1fr!important}}
@media(max-width:860px){.kk-2col{grid-template-columns:1fr!important}}
@media(max-width:940px){.kk-foot-grid{grid-template-columns:1fr 1fr!important}}
@media(max-width:560px){.kk-foot-grid{grid-template-columns:1fr!important}}

/* ---------- prefers-reduced-motion ---------- */
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}[data-rv]{opacity:1;transform:none}}
@keyframes kkfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
