/* Webkatalog · NODE · modernes Theme
   Nutzt CSS-Variablen aus layout.php: --primary --primary-ink --bg --ink
   --muted --font --img-card-h --img-list-w --img-list-h.
   Abgeleitete Tokens (Flächen, Rahmen, Schatten) via color-mix. */
:root{
  --surface: color-mix(in srgb, var(--ink) 4%, var(--bg));
  --surface-2: color-mix(in srgb, var(--ink) 7%, var(--bg));
  --border: color-mix(in srgb, var(--ink) 13%, transparent);
  --border-strong: color-mix(in srgb, var(--ink) 22%, transparent);
  --shadow: 0 1px 2px rgba(0,0,0,.04), 0 8px 24px -12px color-mix(in srgb, var(--ink) 40%, transparent);
  --shadow-lg: 0 2px 4px rgba(0,0,0,.05), 0 18px 40px -16px color-mix(in srgb, var(--ink) 50%, transparent);
  --radius: 16px; --radius-sm: 10px;
  --maxw: 1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--font); color:var(--ink); font-size:17px; line-height:1.65;
  background:
    radial-gradient(1100px 600px at 88% -8%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 60%),
    radial-gradient(900px 500px at -10% 0%, color-mix(in srgb, var(--primary) 7%, transparent), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.muted{color:var(--muted)}

/* Kopfzeile: sticky + Blur */
header.site{position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:saturate(140%) blur(12px); -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--border)}
header.site .bar{display:flex;align-items:center;gap:1.2rem;min-height:68px;flex-wrap:wrap}
.logo{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink)}
.logo img{height:40px;width:auto}
header nav{display:flex;align-items:center;gap:.35rem;margin-left:auto;flex-wrap:wrap}
header nav a{position:relative;padding:.5rem .8rem;border-radius:99px;font-size:.95rem;font-weight:500;color:var(--muted);transition:color .18s,background .18s}
header nav a:hover{color:var(--ink);background:var(--surface-2)}
header nav .pkglink{background:var(--primary);color:var(--primary-ink) !important;font-weight:700;padding:.5rem 1rem;box-shadow:var(--shadow)}
header nav .pkglink:hover{filter:brightness(1.05)}
header nav .lang{display:inline-flex;gap:.25rem;margin-left:.25rem;font-size:.82rem}
header nav .lang a{padding:.25rem .5rem;color:var(--muted)}

.adbanner{margin:1rem auto}
.adbanner:empty{display:none}
main.wrap{padding-top:2rem;padding-bottom:3rem;min-height:50vh}

/* Layout */
.layout{display:grid;grid-template-columns:240px 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}

/* Kategorien-Seitenleiste */
.cats{position:sticky;top:90px}
.cats h2{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:0 0 .8rem;font-weight:700}
.cats ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.15rem}
.cats li a{display:block;padding:.5rem .75rem;border-radius:var(--radius-sm);color:var(--muted);font-weight:500;transition:background .15s,color .15s}
.cats li a:hover{background:var(--surface-2);color:var(--ink)}
.cats li a.on{background:color-mix(in srgb, var(--primary) 14%, transparent);color:var(--primary);font-weight:700}

/* Inhalt */
.listing h1{font-size:clamp(1.7rem,4vw,2.4rem);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin:.2rem 0 1.6rem}
.newshead{margin:2.6rem 0 1.2rem;font-size:1.4rem;font-weight:800;letter-spacing:-.02em;
  padding-top:1.6rem;border-top:1px solid var(--border)}
.intro{font-size:1.05rem;color:color-mix(in srgb,var(--ink) 80%, var(--bg));
  background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);
  padding:1rem 1.2rem;border-radius:var(--radius-sm);margin-bottom:1.8rem}

/* Link-Karten (Standard: 3 Spalten) */
.links{display:grid;gap:1.4rem}
.links.style-cards{grid-template-columns:repeat(3,1fr)}
body .links.style-cards{grid-template-columns:repeat(3,1fr)}
.links.style-cards.cols-2{grid-template-columns:repeat(2,1fr)}
.links.style-cards.cols-3{grid-template-columns:repeat(3,1fr)}
.link{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .22s,border-color .22s;
  display:flex;flex-direction:column}
.link:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}
.links.style-cards .link .thumbwrap{display:block;overflow:hidden;background:var(--surface-2)}
.links.style-cards .link .thumb{width:100%;height:var(--img-card-h,180px);object-fit:cover;
  transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.link:hover .thumb{transform:scale(1.05)}
.linkbody{padding:1rem 1.1rem 1.15rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.link h3{margin:0;font-size:1.12rem;font-weight:700;letter-spacing:-.01em;line-height:1.3}
.link h3 a:hover{color:var(--primary)}
.link p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.55}
.visit{margin-top:auto;align-self:flex-start;font-size:.82rem;font-weight:600;color:var(--primary);
  display:inline-flex;align-items:center;gap:.3rem;word-break:break-all}
.visit::after{content:"→";transition:transform .18s}
.link:hover .visit::after{transform:translateX(3px)}

/* Listen-Stil (Bild links) */
.links.style-list{grid-template-columns:1fr}
.links.style-list .link{flex-direction:row;align-items:stretch}
.links.style-list .link .thumbwrap{flex:0 0 auto;overflow:hidden}
.links.style-list .link .thumb{width:var(--img-list-w,180px);height:var(--img-list-h,130px);object-fit:cover;
  transition:transform .4s}
.links.style-list .link .linkbody{justify-content:center}
@media(max-width:560px){.links.style-list .link{flex-direction:column}
  .links.style-list .link .thumb{width:100%;height:var(--img-card-h,180px)}}

/* News */
.newslist{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.newsitem{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .22s,box-shadow .22s,border-color .22s}
.newsitem:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}
.newsitem .thumbwrap{display:block;overflow:hidden;background:var(--surface-2)}
.newsitem .thumb{width:100%;height:var(--img-card-h,180px);object-fit:cover;transition:transform .4s}
.newsitem:hover .thumb{transform:scale(1.05)}
.newsitem > div,.newsitem h2,.newsitem h3{padding-left:1.1rem;padding-right:1.1rem}
.newsitem > div{padding:1rem 0 1.15rem}
.newsitem h2,.newsitem h3{margin:.9rem 0 .2rem;font-size:1.12rem;font-weight:700;letter-spacing:-.01em}
.newsitem h2 a:hover,.newsitem h3 a:hover{color:var(--primary)}
.newsitem p{margin:.3rem 1.1rem;color:var(--muted);font-size:.95rem}
.newsitem > div p{margin:.3rem 0}

/* News-Einzelansicht / CMS-Seite */
.newsfull,.cmspage{max-width:740px;margin:0 auto}
.newsfull h1,.cmspage h1{font-size:clamp(1.9rem,4vw,2.6rem);font-weight:800;letter-spacing:-.025em;line-height:1.12;margin:.3rem 0 .6rem}
.newsimg{width:100%;border-radius:var(--radius);margin:1rem 0 1.6rem;box-shadow:var(--shadow)}
.newsfull .body,.cmspage .body{font-size:1.08rem;line-height:1.8}
.newsfull .body h2,.cmspage .body h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:1.8rem 0 .6rem}
.newsfull .body h3,.cmspage .body h3{font-size:1.2rem;font-weight:700;margin:1.4rem 0 .5rem}
.newsfull .body p,.cmspage .body p{margin:0 0 1.1rem}
.newsfull .body a,.cmspage .body a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
.newsfull .body img,.cmspage .body img{border-radius:var(--radius-sm);margin:1rem 0}
.newsfull .body blockquote,.cmspage .body blockquote{margin:1.2rem 0;padding:.4rem 0 .4rem 1.2rem;
  border-left:3px solid var(--primary);color:var(--muted);font-style:italic}
.newsfull .body ul,.newsfull .body ol{margin:0 0 1.1rem 1.2rem}

/* Formular (Kontakt) */
.contact{max-width:560px;display:flex;flex-direction:column;gap:1rem}
.contact label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;font-weight:600;color:var(--muted)}
.contact input,.contact textarea{font:inherit;color:var(--ink);background:var(--surface);
  border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:.7rem .85rem;transition:border-color .15s,box-shadow .15s}
.contact input:focus,.contact textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent)}
.contact textarea{resize:vertical}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.btn{display:inline-flex;align-items:center;gap:.4rem;align-self:flex-start;cursor:pointer;
  font:inherit;font-weight:700;border:0;border-radius:99px;padding:.7rem 1.4rem;
  background:var(--primary);color:var(--primary-ink);box-shadow:var(--shadow);transition:transform .15s,filter .15s}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.notice{padding:.8rem 1.1rem;border-radius:var(--radius-sm);margin:1rem 0;border:1px solid var(--border)}
.notice.ok{background:color-mix(in srgb,#22c55e 15%,var(--bg));border-color:color-mix(in srgb,#22c55e 45%,transparent)}
.notice.err{background:color-mix(in srgb,#ef4444 13%,var(--bg));border-color:color-mix(in srgb,#ef4444 45%,transparent)}

/* Fußzeile */
footer.site{border-top:1px solid var(--border);margin-top:3rem;padding:2rem 0;color:var(--muted);font-size:.9rem}
footer.site p{margin:.2rem 0}
footer.site a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}

/* ---- Layout-Varianten ---- */
body.layout-sidebar-right .layout{grid-template-columns:1fr 240px}
body.layout-sidebar-right .cats{order:2}
body.layout-sidebar-right .listing{order:1}

body.layout-top-nav .layout,body.layout-magazine .layout{display:block}
body.layout-top-nav .cats,body.layout-magazine .cats{position:static;margin-bottom:1.8rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
body.layout-top-nav .cats h2,body.layout-magazine .cats h2{display:none}
body.layout-top-nav .cats ul,body.layout-magazine .cats ul{flex-direction:row;flex-wrap:wrap;gap:.4rem}
body.layout-top-nav .cats li a,body.layout-magazine .cats li a{border:1px solid var(--border);border-radius:99px;padding:.4rem .9rem}

/* ---- responsiv ---- */
@media(max-width:900px){
  .links.style-cards,body .links.style-cards,.links.style-cards.cols-2,.links.style-cards.cols-3,.newslist{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  body{font-size:16px}
  .layout{grid-template-columns:1fr}
  .cats{position:static}
  .cats ul{flex-direction:row;flex-wrap:wrap;gap:.4rem}
  .cats li a{border:1px solid var(--border);border-radius:99px;padding:.35rem .8rem}
  header nav{gap:.15rem}
}
@media(max-width:560px){
  .links.style-cards,body .links.style-cards,.links.style-cards.cols-2,.links.style-cards.cols-3,.newslist{grid-template-columns:1fr}
}

/* Hervorgehobene Links ("Featured") */
.link{position:relative}
.link.featured{border-color:var(--primary);
  box-shadow:0 0 0 2px color-mix(in srgb, var(--primary) 35%, transparent), var(--shadow)}
.link.featured:hover{box-shadow:0 0 0 2px color-mix(in srgb, var(--primary) 45%, transparent), var(--shadow-lg)}
.featured-badge{position:absolute;top:.6rem;left:.6rem;z-index:3;
  background:var(--primary);color:var(--primary-ink);font-size:.72rem;font-weight:700;
  letter-spacing:.02em;padding:.22rem .55rem;border-radius:999px;box-shadow:var(--shadow);text-transform:uppercase}

/* Seitenblättern (öffentliche Listen) */
.pager{display:flex;gap:.6rem;align-items:center;justify-content:center;margin:1.8rem 0 .4rem}
.pager a{padding:.45rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--ink);text-decoration:none;background:var(--surface);transition:border-color .15s,color .15s}
.pager a:hover{border-color:var(--primary);color:var(--primary)}
.pager span{color:var(--muted);font-size:.92rem}

/* ===== Band-Stil: farbiger Kopf & Fuß + Icons (Vorlagen 91–120) ===== */
.chrome-band header.site{
  background:var(--head-bg);color:var(--head-ink);
  backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:none;
  box-shadow:0 2px 14px rgba(0,0,0,.16)}
.chrome-band header.site .logo{color:var(--head-ink)}
.chrome-band header nav a{color:var(--head-ink)}
.chrome-band header nav a:hover{color:var(--head-ink);background:rgba(255,255,255,.18)}
.chrome-band header .lang a{color:var(--head-ink)}
.chrome-band footer.site{
  background:var(--foot-bg);color:var(--foot-ink);
  border-top:none;margin-top:3rem}
.chrome-band footer.site a{color:var(--foot-ink)}
/* Icons als Elemente an den Texten */
.nic{margin-right:.4rem;font-size:.95em;line-height:1}
.brandic{font-size:1.15em;line-height:1;vertical-align:-2px}

/* ===== Zentral verwaltete Netzwerk-Blöcke (Plugins) ===== */
.net-blocks{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:2.5rem auto 0}
.net-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem}
.net-block h3{margin:.1rem 0 .6rem;font-size:1.02rem}
.net-block .net-body{font-size:.92rem;color:var(--ink)}
.net-block img{max-width:100%;height:auto;border-radius:8px}
.net-node-grid{display:grid;gap:.65rem;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));margin:0;padding:0;list-style:none}
.net-node{display:flex;align-items:center;gap:.65rem;padding:.6rem .7rem;border:1px solid var(--border);
  border-radius:14px;background:var(--surface);text-decoration:none;color:var(--ink);
  transition:transform .16s,border-color .16s,box-shadow .16s}
.net-node:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:var(--shadow-lg)}
.net-node-ava{flex:0 0 auto;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;
  background:var(--c,var(--primary));color:#fff;font-weight:700;font-size:1rem}
.net-node-tx{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.net-node-tx strong{font-size:.94rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.net-node-tx small{color:var(--muted);font-size:.77rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Netzwerk-Block über die volle Breite der Block-Reihe */
.net-block.net-nodes{grid-column:1/-1}
.net-img{max-width:100%;height:auto;border-radius:8px;margin-bottom:.6rem;display:block}
.net-blocks.net-top{margin:1.4rem auto 2rem}
/* Cookie-Hinweis */
.cookie-notice{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:var(--surface,#fff);
  border-top:1px solid var(--border,#ddd);box-shadow:0 -4px 18px rgba(0,0,0,.12)}
.cookie-inner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.85rem 1rem}
.cookie-txt{flex:1 1 280px;font-size:.9rem;line-height:1.5;color:var(--ink)}
.cookie-txt p{margin:0}
.cookie-title{display:block;margin:0 0 .15rem;font-size:.98rem}
.cookie-txt a{color:var(--primary);text-decoration:underline}
.cookie-ok{flex:0 0 auto;border:0;border-radius:99px;cursor:pointer;font-weight:700;
  padding:.55rem 1.3rem;background:var(--primary);color:var(--primary-ink,#fff)}
.cookie-ok:hover{filter:brightness(.95)}
/* „Neu"-Badge */
.new-badge{position:absolute;top:.55rem;left:.55rem;z-index:2;background:#16a34a;color:#fff;
  font-size:.72rem;font-weight:700;padding:.18rem .5rem;border-radius:99px;letter-spacing:.02em}
.link{position:relative}
.submitpage .submit-price{font-size:1.05rem;margin:.4rem 0 1rem}

/* Unteres Menü (Footer) */
.footmenu{display:flex;flex-wrap:wrap;gap:.3rem .9rem;justify-content:center;margin:0 0 .6rem}
.footmenu a{color:inherit;opacity:.85;text-decoration:none;font-size:.9rem}
.footmenu a:hover{opacity:1;text-decoration:underline}

/* Link-Eintragen-Formular (submit.php) */
.submitpage form.contact{max-width:640px}
.submitpage form.contact label{display:block;margin:.7rem 0;font-weight:600}
.submitpage form.contact input,
.submitpage form.contact select,
.submitpage form.contact textarea{width:100%;margin-top:.3rem;padding:.6rem .7rem;border:1px solid rgba(0,0,0,.18);border-radius:8px;font:inherit;font-weight:400;background:#fff;box-sizing:border-box}
.submitpage form.contact select{appearance:none;-webkit-appearance:none;padding-right:2rem;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23667' stroke-width='2'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .75rem center}
.submitpage .agree{display:flex;gap:.55rem;align-items:flex-start;font-weight:400;margin:1rem 0}
.submitpage .agree input{width:auto;margin:.2rem 0 0;flex:0 0 auto}
.submitpage button[disabled]{opacity:.5;cursor:not-allowed}

/* Plugin-Seitenleisten (links/rechts) */
.cols{display:grid;gap:1.3rem;align-items:start;margin-top:1rem}
.cols.has-left.has-right{grid-template-columns:220px minmax(0,1fr) 220px}
.cols.has-left:not(.has-right){grid-template-columns:220px minmax(0,1fr)}
.cols.has-right:not(.has-left){grid-template-columns:minmax(0,1fr) 220px}
.cols .colmain{min-width:0}
.cols .side{min-width:0}
.cols .side .net-blocks{display:block;padding:0;margin:0}
.cols .side .net-block{margin:0 0 1rem}
.cols .side .net-img{max-width:100%;height:auto}
@media(max-width:860px){
  .cols{grid-template-columns:1fr}
  .cols .colmain{order:1}
  .cols .side-left{order:2}
  .cols .side-right{order:3}
}
