/* Webkatalog Zentrale · Oberfläche im Look der Node-Verwaltung
   Dunkles Theme, Top-Leiste mit Navigation, Karten, blaue Akzentfarbe. */
:root{
  --bg:#0f141b; --panel:#151c26; --panel-2:#1b2430; --surface:#1b2430;
  --line:#233040; --border:#233040; --in-border:#2c3a4c;
  --ink:#e7edf3; --muted:#93a2b3; --nav-ink:#c7d2dd;
  --accent:#2563eb; --primary:#2563eb; --accent-ink:#ffffff; --primary-ink:#ffffff;
  --danger:#ef4444; --warn:#fbbf24; --radius:12px;
  --font:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--primary)}

/* Login (bare) */
body.bare{display:grid;place-items:center;min-height:100vh;
  background:radial-gradient(900px 500px at 70% -10%,#16202c,transparent),var(--bg)}
main.center{width:100%;max-width:420px;padding:1rem}

/* App-Layout: Top-Leiste + zentrierter Inhalt (wie Node-Admin) */
body.app{min-height:100vh}
.adtop{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding:.7rem 1.1rem;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.adtop .brand{font-weight:700;letter-spacing:.2px}
.adtop nav{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}
.adtop nav a{color:var(--nav-ink);text-decoration:none;padding:.35rem .65rem;border-radius:8px;font-size:.9rem;font-weight:500}
.adtop nav a:hover{background:var(--panel-2);color:var(--ink)}
.adtop nav a.on{background:var(--accent);color:var(--accent-ink);font-weight:600}
.adtop .sep{width:1px;height:22px;background:var(--line);margin:0 .25rem}
.adtop .lang a{font-size:.8rem;border:1px solid var(--line);padding:.1rem .45rem;border-radius:6px;color:var(--muted)}
.adtop .me{font-size:.82rem;color:var(--muted)}
.adtop .logout{color:#fca5a5 !important}

.content{padding:1.6rem 2rem;max-width:1100px;margin:0 auto}
h1{font-size:1.5rem;margin:.2rem 0 1rem}
h2{font-size:1.1rem;margin:0 0 .8rem}
.muted{color:var(--muted)}
.hint{color:var(--warn);font-size:.85rem}
code{background:var(--panel-2);padding:.1rem .35rem;border-radius:5px;font-size:.85em}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;margin-bottom:1.2rem}
.card.auth h1{text-align:center}
.flash{background:#16321f;border:1px solid #2f6b41;color:#bbf7d0;padding:.7rem 1rem;border-radius:8px;margin-bottom:1.2rem}

/* Formulare */
label{display:block;margin-bottom:.8rem;font-size:.9rem;color:var(--muted)}
input,select,textarea{width:100%;background:var(--bg);border:1px solid var(--in-border);color:var(--ink);
  padding:.55rem .7rem;border-radius:8px;font:inherit;margin-top:.25rem}
input[type=color]{height:42px;padding:3px}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent}
textarea{margin-bottom:.8rem;resize:vertical;min-height:90px}
.row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:.4rem}
.row > input,.row > select{width:auto;flex:1;margin-top:0}
.chk{display:flex;align-items:center;gap:.4rem;color:var(--ink)}
.chk input{width:auto;margin:0}

.btn{display:inline-block;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  padding:.5rem .9rem;border-radius:8px;cursor:pointer;font:inherit;font-weight:600;text-decoration:none}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.btn.ghost{background:var(--panel-2)}
.btn.danger{background:#b91c1c;color:#fff;border-color:transparent}
.btn.danger:hover{background:#a11717}

/* Tabellen */
.tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.tbl th,.tbl td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.4px}
.tbl a{color:var(--accent)}
.act{display:flex;gap:.35rem;flex-wrap:wrap}
.act form{margin:0}
.key{font-size:.78rem}

.badge{display:inline-block;padding:.15rem .55rem;border-radius:99px;font-size:.78rem;background:var(--panel-2);border:1px solid var(--line)}
.badge.active,.badge.approved{background:#16321f;color:#bbf7d0;border-color:#2f6b41}
.badge.inactive,.badge.rejected{background:#2a1518;color:#fca5a5;border-color:#5b2626}
.badge.pending{background:#2e2710;color:#fcd34d;border-color:#5b4a14}

/* Kacheln & Pakete */
.grid{display:grid;gap:1rem}
.stats{grid-template-columns:repeat(4,1fr)}
.stat{display:flex;flex-direction:column;gap:.2rem}
.stat .num{font-size:2rem;font-weight:700;color:var(--accent)}
.cards3{grid-template-columns:repeat(3,1fr)}
.pkg .price{font-size:1.6rem;font-weight:700;margin:.3rem 0 .6rem}
.pkg ul{list-style:none;padding:0;margin:0 0 1rem;color:var(--muted);font-size:.9rem}
.pkg li{padding:.2rem 0;border-bottom:1px dashed var(--line)}

@media(max-width:820px){
  .adtop{flex-direction:column;align-items:flex-start}
  .content{padding:1.2rem}
  .stats,.cards3{grid-template-columns:1fr 1fr}
}

/* Node-Auswahl (Links/News) */
.nodepick{border:1px solid var(--border);border-radius:10px;padding:.8rem 1rem;margin:.8rem 0}
.nodepick legend{padding:0 .4rem;font-weight:600}
.nodegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;max-height:280px;overflow:auto}
.nodeopt{display:flex;gap:.5rem;align-items:flex-start;padding:.5rem .6rem;border:1px solid var(--border);
  border-radius:8px;cursor:pointer;background:var(--surface);transition:border-color .15s,background .15s}
.nodeopt:hover{border-color:var(--primary)}
.nodeopt input{margin-top:.2rem;width:auto}
.nodeopt span{font-size:.9rem;line-height:1.25}
.nodeopt small{font-size:.72rem;word-break:break-all}

/* Medien & Editor */
.filelabel{display:block;font-size:.85rem;color:var(--muted);margin:.6rem 0}
.filelabel input[type=file]{display:block;margin-top:.3rem;color:inherit}
.thumb{max-width:120px;max-height:90px;border-radius:6px;border:1px solid var(--border);object-fit:cover}
.imgedit{display:flex;align-items:center;gap:.8rem;margin:.5rem 0}
.wysiwyg{border:1px solid var(--in-border);border-radius:8px;overflow:hidden;margin:.5rem 0;background:var(--bg)}
.wy-bar{display:flex;flex-wrap:wrap;gap:4px;padding:6px;border-bottom:1px solid var(--line)}
.wy-btn{font:inherit;font-size:.8rem;padding:.25rem .5rem;border:1px solid var(--in-border);border-radius:6px;
  background:transparent;color:inherit;cursor:pointer}
.wy-btn:hover{border-color:var(--primary)}
.wy-area{min-height:160px;padding:.7rem .9rem;outline:none;line-height:1.5}
.wy-area:focus{box-shadow:inset 0 0 0 2px var(--primary)}
.wy-area h2{font-size:1.2rem;margin:.4rem 0}
.wy-area h3{font-size:1.05rem;margin:.4rem 0}

/* --- Bild-Editor vor Upload --------------------------------------- */
.imged{border:1px solid var(--in-border);border-radius:10px;padding:.8rem;margin:.5rem 0;background:var(--bg)}
.imged-stage{display:flex;justify-content:center;background:#000;border-radius:8px;overflow:hidden}
.imged-canvas{touch-action:none;cursor:grab;max-width:100%}
.imged-canvas:active{cursor:grabbing}
.imged-ctrls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-top:.6rem}
.imged-ctrls label{display:flex;align-items:center;gap:.35rem;margin:0;color:var(--ink);font-size:.85rem}
.imged-ctrls select{width:auto;margin:0}
.imged-ctrls input[type=range]{width:140px;margin:0}
.imged-ctrls .btn{padding:.35rem .7rem;font-size:.85rem}
.imged-note{font-size:.78rem}
.imged-done{margin:.4rem 0}

/* Infotext unter den Paketen */
.pkginfo{line-height:1.7}
.pkginfo h2{font-size:1.2rem;margin:.4rem 0}
.pkginfo h3{font-size:1.05rem;margin:.4rem 0}
.pkginfo ul,.pkginfo ol{margin:.4rem 0 .8rem 1.2rem}
.pkginfo a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* Theme-Umschalter */
.themetgl{background:var(--panel-2);border:1px solid var(--line);color:var(--ink);
  width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:.95rem;line-height:1;padding:0}
.themetgl:hover{border-color:var(--accent)}

/* === HELLES THEME === */
html[data-theme="light"]{
  --bg:#f4f6f9; --panel:#ffffff; --panel-2:#eef2f7; --surface:#ffffff;
  --line:#e2e8f0; --border:#e2e8f0; --in-border:#cbd5e1;
  --ink:#1f2937; --muted:#5b6675; --nav-ink:#475569;
  --accent:#2563eb; --primary:#2563eb; --accent-ink:#ffffff; --primary-ink:#ffffff;
}
html[data-theme="light"] body.bare{background:radial-gradient(900px 500px at 70% -10%,#e9eef5,transparent),var(--bg)}
html[data-theme="light"] .adtop{box-shadow:0 1px 0 rgba(0,0,0,.04)}
html[data-theme="light"] .card{box-shadow:0 1px 2px rgba(0,0,0,.04)}
html[data-theme="light"] .flash{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
html[data-theme="light"] code{background:#eef2f7}
