/* ---- CATEGORY OVERVIEW PAGE ---- */
/* layered on index.css + index_product.css */

/* HERO */
.cat-hero{background:#f5f5f3;padding:56px 0 100px;position:relative;overflow:hidden}
.cat-hero-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;position:relative;z-index:1}
.cat-h1{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;
  font-size:clamp(56px,7.84vw,112px);line-height:.94;letter-spacing:-.02em;
  margin:0 0 24px;color:#0b0b0c;
}
.cat-h1 .thin{font-weight:200;font-style:normal;color:var(--rok-text-muted-accessible)}
.cat-lede{font-size:18px;line-height:1.55;color:#444;max-width:520px;margin:0 0 36px}
.cat-lede b{color:#0b0b0c;font-weight:700}
.cat-meta{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:#e2e2de;
  border:1px solid #e2e2de;max-width:520px;
}
.cat-meta > div{background:#fff;padding:14px 16px}
.cat-meta .k{font-size:11px;color:var(--rok-text-muted-accessible);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
.cat-meta .v{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:22px;color:#0b0b0c;
}

.cat-hero-visual{position:relative;aspect-ratio:16/9;background:#0b0b0c;overflow:hidden}
/* spacer reserves the line + bottom-margin of the eyebrow in the left column
   so the visual's top aligns with the h1 (not the eyebrow) */
.cat-hero-spacer{
  display:block;font-size:11px;line-height:1;letter-spacing:.18em;
  visibility:hidden;margin-bottom:24px;
}
.cat-hero-visual img{width:100%;height:100%;object-fit:cover;display:block}
.cas-pill{
  position:absolute;left:24px;bottom:24px;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  padding:14px 18px;display:flex;align-items:center;gap:14px;
  border:1px solid rgba(0,0,0,.08);
}
.cas-pill img{width:48px;height:48px;object-fit:contain;background:transparent;flex-shrink:0}
.cas-pill strong{display:block;font-size:13px;color:#0b0b0c;font-weight:700}
/* CAS pill — moved out of hero image, now bottom-left of hero text column */
.cat-cas-pill{
  position:static;display:inline-flex;align-items:center;gap:14px;
  background:#fff;border:1px solid #e2e2de;padding:14px 18px;margin-top:32px;
  box-shadow:none;backdrop-filter:none;
}

/* Filter chips: "Neu 2026" pulled left, separator after it */
.cat-filter-chips{justify-content:flex-start}
.cat-filter-chips .chip-new{
  background:var(--rok-orange);border-color:var(--rok-orange);color:var(--rok-text-on-orange);
  font-weight:700;
}
.cat-filter-chips .chip-new:hover{background:#fff;color:var(--rok-orange)}
.cat-filter-chips .chip-new.active{background:#fff;color:var(--rok-orange);border-color:#fff}
.cat-filter-chips .sep{display:inline-block;width:1px;height:18px;background:rgba(255,255,255,.18);margin:0 6px;align-self:center}

/* FILTER BAR */
.cat-filter{
  background:#0b0b0c;color:#fff;border-top:1px solid rgba(255,255,255,.06);
  position:sticky;top:var(--nav-h, 99px);z-index:30;
}
.cat-filter-inner{
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center;
  /* Keep the v2-container horizontal padding (40px / 20px responsive) so the
     left edge of "<count> Produkte" aligns with the h1 above. Setting only
     top/bottom padding here lets v2-container's `padding:0 40px` take effect. */
  padding-top:18px;padding-bottom:18px;
}
.cat-filter-left{font-size:13px;color:rgba(255,255,255,.7);display:flex;gap:10px;align-items:center}
.cat-filter-left strong{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:18px;color:#fff;
}
.cat-filter-left .dot{color:rgba(255,255,255,.3)}
.cat-filter-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.cat-filter-chips button{
  background:transparent;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);
  padding:7px 14px;font:inherit;font-size:12px;font-weight:600;cursor:pointer;
  letter-spacing:.04em;transition:all .15s ease;
}
.cat-filter-chips button:hover{border-color:#fff;color:#fff}
.cat-filter-chips button.active{background:var(--rok-orange);border-color:var(--rok-orange);color:var(--rok-text-on-orange)}
.cat-filter-right{display:flex;gap:10px;align-items:center;font-size:12px;color:rgba(255,255,255,.7)}
.cat-filter-right select{
  background:#1a1a1c;border:1px solid rgba(255,255,255,.15);color:#fff;
  padding:6px 10px;font:inherit;font-size:12px;margin-left:8px;cursor:pointer;
}
.cat-view-btn{
  width:34px;height:34px;background:transparent;border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.6);font-size:14px;cursor:pointer;
}
.cat-view-btn.active{background:#fff;color:#0b0b0c;border-color:#fff}

/* PRODUCT GRID */
.cat-grid-sec{padding:80px 0;background:#fff}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#e2e2de;border:1px solid #e2e2de}
.cat-grid.list-view{grid-template-columns:1fr}
.cat-card{
  background:#fff;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;
}
.cat-card:hover{background:#fafaf7}
.cat-card .img{aspect-ratio:16/9;overflow:hidden;background:#f0f0ec;position:relative}
.cat-card .img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;filter:grayscale(.2)}
.cat-card:hover .img img{transform:scale(1.05);filter:none}
.cat-card .num-tag{
  position:absolute;top:12px;left:12px;background:#0b0b0c;color:#fff;padding:4px 10px;
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:12px;letter-spacing:.05em;
}
.cat-card .new-tag{
  position:absolute;top:12px;right:12px;background:var(--rok-orange);color:var(--rok-text-on-orange);padding:4px 8px;
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
}
.cat-card .body{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.cat-card .body .kicker{
  font-size:11px;color:var(--rok-orange-text);letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:8px;
}
.cat-card .body h3{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;
  font-size:32px;letter-spacing:-.01em;margin:0 0 6px;color:#0b0b0c;line-height:1;
}
.cat-card .body h3 .thin{font-weight:200;font-style:normal;color:var(--rok-text-muted-accessible)}
.cat-card .body p{font-size:14px;line-height:1.55;color:var(--rok-text-muted-accessible);margin:8px 0 18px;flex:1}
.cat-card .specs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#e2e2de;
  border:1px solid #e2e2de;margin-bottom:18px;
}
.cat-card .specs > div{background:#fff;padding:8px 10px}
.cat-card .specs .k{font-size:9.5px;color:var(--rok-text-muted-accessible);letter-spacing:.06em;text-transform:uppercase;margin-bottom:1px}
.cat-card .specs .v{font-family:'Roboto',sans-serif;font-weight:700;font-size:13px;color:#0b0b0c}
.cat-card .foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid #f0f0ec;
}
.cat-card .foot .link{font-size:12px;font-weight:700;letter-spacing:.06em;color:#0b0b0c}
.cat-card:hover .foot .link{color:var(--rok-orange)}
.cat-card .foot .arr{font-size:18px;color:var(--rok-text-muted-accessible);transition:all .15s}
.cat-card:hover .foot .arr{color:var(--rok-orange);transform:translateX(4px)}

/* LIST view — image stays strictly 16:9 (non-negotiable design rule). To
 * eliminate vertical whitespace around the image, the image column is wide
 * enough that the image's computed height (width × 9/16) typically matches
 * or exceeds the body content height; the body then stretches via the
 * existing `.body p { flex: 1 }` to fill the row. Image stays flush with
 * the row's top and bottom edges. */
.cat-grid.list-view .cat-card{display:grid;grid-template-columns:clamp(320px,28vw,380px) 1fr;gap:0;align-items:stretch}
.cat-grid.list-view .img{aspect-ratio:16/9;height:auto;align-self:start;width:100%}
.cat-grid.list-view .body{padding:24px 32px}
.cat-grid.list-view .specs{grid-template-columns:repeat(6,1fr)}
@media (max-width: 760px) {
  .cat-grid.list-view .cat-card{grid-template-columns:1fr}
  .cat-grid.list-view .img{aspect-ratio:16/9}
}

/* WHY CAS */
.cat-why{background:#f5f5f3;padding:120px 0}
.cat-why-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:64px}
.cat-why-head h2{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;
  font-size:clamp(48px,6vw,84px);line-height:.92;letter-spacing:-.02em;margin:14px 0 0;color:#0b0b0c;
}
.cat-why-head h2 .thin{font-weight:200;font-style:normal;color:var(--rok-text-muted-accessible)}
.cat-why-head .side{font-size:16px;line-height:1.6;color:var(--rok-text-muted-accessible);margin:0 0 18px}

.cat-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#e2e2de;border:1px solid #e2e2de}
.why-card{background:#fff;padding:36px 32px;position:relative}
.why-card .num{
  position:absolute;top:24px;right:28px;
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;
  color:#8f8f8f;font-size:48px;line-height:1;
}
.why-card h3{
  font-family:'Roboto',sans-serif;font-weight:700;font-size:20px;margin:0 0 10px;color:#0b0b0c;line-height:1.25;
}
.why-card p{font-size:14px;line-height:1.6;color:var(--rok-text-muted-accessible);margin:0 0 20px}
.why-card .logos{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.why-card .logos span{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:11px;
  border:1px solid #e2e2de;padding:5px 9px;color:var(--rok-text-muted-accessible);letter-spacing:.04em;
}
.why-card .check{list-style:none;padding:0;margin:0;font-size:13px;color:#444}
.why-card .check li{padding:8px 0 8px 22px;border-bottom:1px solid #f0f0ec;position:relative}
.why-card .check li::before{
  content:"✓";position:absolute;left:0;color:var(--rok-orange);font-weight:900;
}
.why-card .check li:last-child{border-bottom:0}

/* COMPARE */
.cat-compare{padding:120px 0;background:#fff}
.cat-compare-wrap{
  overflow-x:auto;border:1px solid #e2e2de;
  scrollbar-width:thin;scrollbar-color:var(--rok-text-muted-accessible) #fff;
}
.cat-cmp{
  width:100%;min-width:1100px;border-collapse:collapse;font-size:13.5px;background:#fff;
}
.cat-cmp thead th{background:#fafaf7;border-bottom:2px solid #0b0b0c;padding:24px 18px;vertical-align:top}
.cat-cmp thead th:first-child{width:160px;background:#0b0b0c}
.cat-cmp .cmp-h{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.cat-cmp .cmp-h img{width:100%;aspect-ratio:16/9;object-fit:cover;background:#f0f0ec;margin-bottom:8px}
.cat-cmp .cmp-h .num{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:11px;color:var(--rok-orange-text);letter-spacing:.05em;
}
.cat-cmp .cmp-h .name{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:18px;color:#0b0b0c;text-transform:uppercase;line-height:1;
}
.cat-cmp .cmp-h em{font-size:11px;color:var(--rok-text-muted-accessible);letter-spacing:.06em;font-style:normal;text-transform:uppercase}
.cat-cmp tbody th{
  text-align:left;background:#0b0b0c;color:#fff;padding:14px 18px;font-weight:600;
  font-size:12px;letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.08);
}
.cat-cmp tbody td{
  padding:14px 18px;border-bottom:1px solid #f0f0ec;color:#0b0b0c;font-weight:500;text-align:center;
}
.cat-cmp tbody tr:hover td{background:#fafaf7}
.cat-cmp .cta-row td a{
  display:inline-block;font-size:12px;letter-spacing:.06em;font-weight:700;color:var(--rok-orange-text);text-decoration:none;
  padding:8px 14px;border:1px solid var(--rok-orange);transition:all .15s ease;
  text-transform:uppercase;
}
.cat-cmp .cta-row td a:hover{background:var(--rok-orange);color:#fff}

/* IN ACTION */
.cat-action{background:#0b0b0c;padding:0;color:#fff}
.cat-action-inner{display:grid;grid-template-columns:1fr;align-items:center;position:relative;min-height:520px}
.cat-action-img{position:relative;width:100%;height:100%;min-height:520px}
.cat-action-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.cat-action-card{
  position:relative;z-index:2;background:#fff;color:#0b0b0c;padding:40px;
  margin:60px auto;max-width:680px;
}
.cat-action-card h3{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;
  font-size:clamp(32px,3.5vw,48px);line-height:1;letter-spacing:-.01em;margin:14px 0 18px;
}
.cat-action-card h3 .thin{font-weight:300;font-style:normal;color:var(--rok-text-muted-accessible)}
.cat-action-card p{font-size:14px;color:var(--rok-text-muted-accessible);margin:0 0 24px;letter-spacing:.04em}
.cat-action-card .kpi{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid #e2e2de;padding-top:20px}
.cat-action-card .kpi strong{
  font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;font-size:32px;color:var(--rok-orange);display:block;line-height:1;
}
.cat-action-card .kpi span{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--rok-text-muted-accessible);margin-top:4px;display:block}

/* OTHER CATEGORIES */
.cat-other{padding:120px 0;background:#f5f5f3}

/* When the chip group is suppressed (single-bucket category), collapse the
   middle 1fr track so the sort/view section sits flush against the right
   edge of the container — same horizontal anchor it has when chips are
   present in column 3. The left "<count> Produkte" group remains in
   column 1 → its left edge stays aligned with the h1 above. */
@media (min-width:1101px){
  .cat-filter-inner[data-chip-count="0"]{
    grid-template-columns:auto auto;
    justify-content:space-between;
  }
}

/* RESPONSIVE */
@media (max-width:1100px){
  .cat-hero-inner{grid-template-columns:1fr;gap:48px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid.list-view .cat-card{grid-template-columns:1fr}
  .cat-grid.list-view .img{aspect-ratio:16/9}
  .cat-why-head{grid-template-columns:1fr;gap:24px}
  .cat-why-grid{grid-template-columns:1fr}
  .cat-filter-inner{grid-template-columns:1fr;gap:14px}
  .cat-filter-left,.cat-filter-right{justify-content:center}
}
@media (max-width:700px){
  .cat-grid{grid-template-columns:1fr}
  .cat-meta{grid-template-columns:repeat(2,1fr)}
  .cat-action-card{margin:24px;padding:28px}
  .cat-action-card .kpi{grid-template-columns:1fr;gap:14px}
}

/* ── "Alle Inhalte" tile grid (CategoryItemsGrid) ───────────────────────── */
.cat-items{padding:96px 0;background:#fff}
.cat-items .v2-section-head{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;margin-bottom:32px}
.cat-items .v2-section-head .side{color:var(--rok-text-muted-accessible);font-size:14px;text-align:right}
.cat-items .v2-section-head .side strong{color:#111;font-size:18px;margin-right:6px}
.cat-items .v2-section-head .side .dot{color:#cfcfcf}
.cat-items-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-top:1px solid #ececec;border-bottom:1px solid #ececec;margin-bottom:32px}
.cat-items-chips{display:flex;flex-wrap:wrap;gap:8px}
.cat-items-chips button{appearance:none;border:1px solid #d0d0d0;background:#fff;color:#333;font-size:13px;letter-spacing:.02em;padding:8px 14px;border-radius:999px;cursor:pointer;transition:all .2s var(--rok-ease)}
.cat-items-chips button:hover{border-color:#111;color:#111}
.cat-items-chips button.active{background:#111;color:#fff;border-color:#111}
.cat-items-sort{font-size:13px;color:var(--rok-text-muted-accessible);display:inline-flex;align-items:center;gap:8px}
.cat-items-sort select{appearance:none;border:1px solid #d0d0d0;background:#fff;color:#111;font-size:13px;padding:7px 28px 7px 12px;border-radius:8px;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,#666 50%),linear-gradient(135deg,#666 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
@media (max-width:900px){
  .cat-items .v2-section-head{grid-template-columns:1fr;gap:18px}
  .cat-items .v2-section-head .side{text-align:left}
  .cat-items-bar{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   NEWSLETTER-FILL-CARD
   Füllt leere .cat-grid-Zellen mit einer Newsletter-Anmeldebox im
   Mega-Menü-Look (.v2-mega-feat): schwarz + radialer Orange-Gradient,
   eckig (border-radius:0), AA-Kontrast. Genau eine Karte je Raster,
   als letztes Grid-Item. Span/Sichtbarkeit folgen der Spaltenzahl pro
   Breakpoint (data-nlfill-mod = count % 6). Komponente:
   src/components/site/NewsletterFillCard.tsx
   ============================================================ */
.nl-fill-card{
  background:#0b0b0c;color:#fff;padding:32px;position:relative;overflow:hidden;border-radius:0;
  display:flex;flex-direction:column;gap:14px;justify-content:center;min-height:100%;
}
.nl-fill-card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 100% 0%,rgba(234,91,10,.35),transparent 60%);
}
.nl-fill-card > *{position:relative;z-index:1}
.nl-fill-card .eyb{font-family:'Roboto',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--rok-orange)}
.nl-fill-card h3{font-family:'Roboto',sans-serif;font-weight:900;font-style:italic;text-transform:uppercase;font-size:22px;line-height:1;margin:0;letter-spacing:-.01em;color:#fff}
.nl-fill-card .body{font-size:13px;line-height:1.55;color:rgba(255,255,255,.72);margin:0;max-width:46ch}
.nl-fill-card form{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.nl-fill-card .nl-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.nl-fill-card .row{display:flex;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);padding:5px}
.nl-fill-card .row:focus-within{border-color:#fff}
.nl-fill-card input[type=email]{flex:1;min-width:0;border:0;background:transparent;padding:12px 14px;color:#fff;font:inherit;font-size:15px;outline:none}
.nl-fill-card input[type=email]::placeholder{color:rgba(255,255,255,.5)}
.nl-fill-card button[type=submit]{flex:0 0 auto;border:0;background:var(--rok-orange);color:var(--rok-text-on-orange);font-family:'Roboto',sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:12px;padding:0 18px;cursor:pointer;transition:background .2s}
.nl-fill-card button[type=submit]:hover{background:var(--rok-orange-hover)}
.nl-fill-card button[type=submit]:disabled{opacity:.6;cursor:default}
.nl-fill-card .consent{font-size:11px;line-height:1.5;color:rgba(255,255,255,.55);margin:0}
.nl-fill-card .consent a{color:#fff;text-decoration:underline}
.nl-fill-card .nl-ok,.nl-fill-card .nl-err{font-size:12px;line-height:1.5;margin:6px 0 0}
.nl-fill-card .nl-ok{color:#fff}
.nl-fill-card .nl-ok strong{color:var(--rok-orange)}
.nl-fill-card .nl-err{color:#ffd2c2}
.nl-fill-card .nl-err strong{color:#fff}
.nl-fill-card .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* Default (Mobile, 1 Spalte ≤700px UND Empty-State): volle Zeile, sichtbar. */
.nl-fill-card{grid-column:1 / -1}

/* Desktop 3 Spalten (>1100px). Lücke = 3 − (n % 3). */
@media (min-width:1101px){
  .cat-grid > .nl-fill-card[data-nlfill-mod="1"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="4"]{grid-column:span 2}              /* n%3==1 → 2 Zellen frei */
  .cat-grid > .nl-fill-card[data-nlfill-mod="2"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="5"]{grid-column:span 1}              /* n%3==2 → 1 Zelle frei */
  .cat-grid > .nl-fill-card[data-nlfill-mod="0"]:not([data-nlfill-empty]),
  .cat-grid > .nl-fill-card[data-nlfill-mod="3"]{display:none}                    /* n%3==0 & n>0 → keine Lücke */
  /* Schmale Einzelzelle: langer Body würde überlaufen → ausblenden. */
  .cat-grid > .nl-fill-card[data-nlfill-mod="2"] .body,
  .cat-grid > .nl-fill-card[data-nlfill-mod="5"] .body{display:none}
}

/* Tablet 2 Spalten (701–1100px). Lücke = 2 − (n % 2). */
@media (min-width:701px) and (max-width:1100px){
  .cat-grid > .nl-fill-card[data-nlfill-mod="1"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="3"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="5"]{grid-column:span 1}              /* n ungerade → 1 Zelle frei */
  .cat-grid > .nl-fill-card[data-nlfill-mod="2"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="4"],
  .cat-grid > .nl-fill-card[data-nlfill-mod="0"]:not([data-nlfill-empty]){display:none} /* n gerade & >0 → keine Lücke */
  .cat-grid > .nl-fill-card[data-nlfill-mod="1"] .body,
  .cat-grid > .nl-fill-card[data-nlfill-mod="3"] .body,
  .cat-grid > .nl-fill-card[data-nlfill-mod="5"] .body{display:none}
}

/* Band-Variante (primäres Raster, Prop bandWhenFull → data-nlfill-band):
   bei VOLLER Reihe NICHT ausblenden, sondern als volle Abschluss-Band
   (grid-column:1/-1) zeigen, damit die Newsletter-Einladung auf jeder Seite
   präsent bleibt (Lock-in). Extra [data-nlfill-band] erhöht die Spezifität →
   schlägt die display:none-Regeln oben. Body bleibt sichtbar (volle Breite). */
@media (min-width:1101px){
  .cat-grid > .nl-fill-card[data-nlfill-band][data-nlfill-mod="0"]:not([data-nlfill-empty]),
  .cat-grid > .nl-fill-card[data-nlfill-band][data-nlfill-mod="3"]{display:flex;grid-column:1 / -1}
}
@media (min-width:701px) and (max-width:1100px){
  .cat-grid > .nl-fill-card[data-nlfill-band][data-nlfill-mod="2"],
  .cat-grid > .nl-fill-card[data-nlfill-band][data-nlfill-mod="4"],
  .cat-grid > .nl-fill-card[data-nlfill-band][data-nlfill-mod="0"]:not([data-nlfill-empty]){display:flex;grid-column:1 / -1}
}

/* List-View (immer 1 Spalte): Karte bewusst als volle Abschluss-Band-CTA
   zeigen — überschreibt die display:none-Regeln der Mod-Logik. */
.cat-grid.list-view > .nl-fill-card{display:flex !important;grid-column:1 / -1}
.cat-grid.list-view > .nl-fill-card .body{display:block}
