:root{
  --bg:#f5f6f8; --card:#fff; --ink:#1c2230; --muted:#6a7280;
  --accent:#2b5cad; --accent2:#e8eef9; --line:#e2e5ea; --shadow:0 1px 3px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.45;font-size:16px;padding-bottom:2.6rem}
.foot{position:fixed;left:0;right:0;bottom:0;text-align:center;
  background:#fff;color:var(--muted);font-size:.85rem;padding:.5rem .8rem;z-index:20;
  border-top:1px solid var(--line);transform:translateZ(0);will-change:transform}

/* Kopf */
.top{position:sticky;top:0;z-index:10;background:var(--accent);color:#fff;box-shadow:var(--shadow)}
.bar{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;
  max-width:860px;margin:0 auto;padding:.6rem .8rem}
.brand{color:#fff;text-decoration:none;font-weight:700;font-size:1.1rem;align-self:flex-end}
.bar nav{display:flex;flex-wrap:wrap;gap:.4rem;width:100%}
.bar nav a{color:#eaf0fb;text-decoration:none;font-size:.92rem;padding:.3rem .7rem;
  border-radius:14px;background:rgba(255,255,255,.12);white-space:nowrap}
.bar nav a.active{color:var(--accent);font-weight:600;background:#fff}
.searchwrap{max-width:860px;margin:0 auto;padding:0 .8rem .7rem}
.searchwrap.hide{display:none}
#q{width:100%;padding:.7rem .9rem;border:0;border-radius:10px;font-size:1rem;
  box-shadow:var(--shadow);outline:none}

/* Inhalt */
main{max-width:860px;margin:0 auto;padding:.8rem}
#app{position:relative}
#app.sliding{overflow:hidden}
#app.sliding .view{position:absolute;top:0;left:.8rem;right:.8rem;width:auto}
.view{transition:transform .35s ease}
.hint{color:var(--muted);padding:1.2rem .2rem}
.error{color:#b00020;padding:1rem;background:#fff0f1;border-radius:8px}

/* Trefferliste */
.list{display:flex;flex-direction:column;gap:.5rem}
.item{display:block;background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:.7rem .85rem;text-decoration:none;color:inherit;box-shadow:var(--shadow)}
.item:active{background:var(--accent2)}
.item .name{font-weight:600}
.item .meta{color:var(--muted);font-size:.85rem;margin-top:.15rem}
.serietitle{font-size:1.2rem;font-weight:700;color:var(--accent);margin:.1rem 0 .4rem;line-height:1.25}
.count{color:var(--muted);font-size:.85rem;margin:.2rem .2rem .6rem}
.navrow{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem .7rem;color:#eaf0fb;font-size:.85rem;padding:0 0 .4rem}
.navrow .sortlbl{display:inline-flex;align-items:center;gap:.5rem}
.navrow .sortradio{display:inline-flex;align-items:center;gap:.25rem}
.navrow select{font-size:.85rem;padding:.25rem .45rem;border:0;border-radius:6px;background:#fff;color:var(--ink)}
.dbnav{display:inline-flex;gap:.25rem;margin-left:auto}
.dbnav button{background:#fff;color:var(--accent);border:0;border-radius:6px;padding:.2rem .55rem;font-size:.95rem;line-height:1;cursor:pointer;font-weight:700}
.dbnav button:active{background:var(--accent2)}
.navmore{background:#fff;color:var(--accent);border:0;border-radius:6px;font-weight:700;font-size:.9rem;
  padding:.25rem .5rem;min-width:3.4rem;white-space:nowrap;cursor:pointer;line-height:1}
.optrow .navmore{margin-left:auto}
.navmore:active{background:var(--accent2)}
.navmore:disabled{opacity:.4;cursor:default;background:#fff}
.searchline{display:flex;align-items:center;gap:.6rem}
.searchline #q{flex:1 1 auto;min-width:0;width:auto}
.trefferinfo{flex:0 0 auto;color:#eaf0fb;font-size:.9rem;white-space:nowrap;font-weight:600}
.optrow{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem 1rem;color:#eaf0fb;font-size:.82rem;padding:0 0 .5rem}
.optrow .sortchk{display:inline-flex;align-items:center;gap:.3rem}
.item.current{outline:2px solid #fff;outline-offset:-2px;box-shadow:0 0 0 2px var(--accent),var(--shadow);background:var(--accent2)}

/* Detail */
.back{display:inline-block;margin:.2rem 0 .6rem;color:var(--accent);text-decoration:none;font-size:.95rem}
.serie{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:.85rem;box-shadow:var(--shadow);margin-bottom:.8rem;
  position:sticky;top:var(--topH,64px);z-index:6;will-change:transform}
.serie h1{font-size:1.25rem;margin:.1rem 0 .4rem;color:var(--accent)}
.kv{display:flex;flex-wrap:wrap;gap:.3rem .9rem;color:var(--muted);font-size:.9rem}
.kv b{color:var(--ink);font-weight:600}

.tablewrap{overflow-x:auto;background:var(--card);border:1px solid var(--line);
  border-radius:10px;box-shadow:var(--shadow)}
table{border-collapse:collapse;width:100%;font-size:.9rem;min-width:560px}
th,td{padding:.5rem .6rem;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{background:#fafbfc;position:sticky;top:0;font-size:.82rem;color:var(--muted);letter-spacing:.02em}
td.num,th.num{text-align:right}
tr:last-child td{border-bottom:0}
.sub{color:var(--muted);font-size:.85rem;white-space:normal}
/* Detail-Tabelle: kein eigener Scroll-Container, damit der Kopf am Seitenscroll klebt */
.detailwrap{overflow:visible}
.detailwrap table{min-width:0;width:100%}
.detailwrap th,.detailwrap td{white-space:normal;word-break:break-word}
.detailwrap td.num,.detailwrap th.num{white-space:nowrap;word-break:normal}
.detailwrap thead th{top:var(--theadTop,0);z-index:5;background:#e4eefb;color:#2b5cad}
.detailwrap tbody tr:nth-child(odd){background:#fff}
.detailwrap tbody tr:nth-child(even){background:#f7f9fc}
td.wrap,th.wrap{white-space:normal}
/* Cover fuellt die (durch Umbruch evtl. hoehere) Zeilenhoehe aus */
.detailwrap td{vertical-align:top}
.detailwrap td.coverc{height:1px}
.detailwrap td.coverc img{height:100%;min-height:46px;max-height:240px;width:auto;object-fit:contain;border-radius:3px;display:block}
/* Heft-Karten (Mobil statt Tabelle) */
.hcards{display:flex;flex-direction:column;gap:.6rem}
.hcard{padding:.7rem .8rem}
.hcard .serietitle{font-size:1.05rem;margin:.05rem 0 .5rem}
.hcard .serieCover{width:92px}
.hcard .kv{flex-direction:column;gap:.25rem;font-size:.92rem}
.hcard .kv span{color:var(--ink)}
.hcard .kv b{color:var(--accent);font-weight:600;margin-right:.3rem}
.hcardbest{margin-top:.6rem}
.serieHead{display:flex;gap:.9rem;align-items:flex-start}
.serieCover{width:110px;max-width:32vw;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.25);flex:0 0 auto}
/* fehlendes Cover: Platzhalter darf die Kartenhoehe nicht hochtreiben */
.serieCover.nocover{height:84px;object-fit:contain;box-shadow:none;background:transparent;align-self:flex-start}
.serieInfo{flex:1 1 auto}
img.thumb{height:46px;width:auto;border-radius:3px;display:block;background:#eee}
td.coverc{width:54px;padding:.25rem .4rem}

/* Bestand */
.cards{display:flex;flex-wrap:wrap;gap:.5rem;margin:.2rem 0 .9rem}
.card{flex:1 1 130px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;box-shadow:var(--shadow)}
.card .lbl{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.03em}
.card .val{font-size:1.25rem;font-weight:700;margin-top:.15rem}
.pos{color:#1a7f37}.neg{color:#b00020}
.bhead{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:space-between;align-items:center;margin:.2rem 0 .5rem;font-weight:700;font-size:1.1rem}
.bhbtns{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.9rem;font-weight:400}
.reptab td{white-space:normal;word-break:break-word;vertical-align:top}
.reptab .repnr{line-height:1.5}
@media print{
  .top,.foot,.bhbtns{display:none !important}
  main{max-width:none;padding:0}
  .tablewrap{overflow:visible;border:0;box-shadow:none}
  body{background:#fff;padding:0}
}
td.bestc{white-space:nowrap}
.owned{color:#1a7f37;font-weight:700}
.bbtn{border:1px solid var(--line);background:#fff;border-radius:6px;padding:.15rem .55rem;font-size:.95rem;cursor:pointer;line-height:1.2}
.bbtn.add{color:var(--accent);font-weight:700}
.bbtn.del{color:#b00020}
/* Titel-Badges (Hinweise / Wechsel) + Info-Popup */
.badges{display:inline-flex;gap:.6rem;vertical-align:middle;position:relative;top:-.4em}
.tbadge{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;
  border-radius:50%;border:1px solid #9db6dd;color:var(--accent);
  background:linear-gradient(#ffffff,#dbe6f6);
  font-size:.9rem;line-height:1;padding:0;font-weight:700;cursor:pointer;flex:0 0 auto;
  box-shadow:0 2px 0 #9db6dd,0 3px 5px rgba(0,0,0,.28),inset 0 1px 0 #fff;
  transition:transform .05s ease,box-shadow .05s ease}
.tbadge.ibadge{font-style:italic;font-family:Georgia,"Times New Roman",serif}
.tbadge:active{transform:translateY(2px);
  background:linear-gradient(#e6edf8,#cfdcef);
  box-shadow:0 0 0 #9db6dd,0 1px 2px rgba(0,0,0,.3),inset 0 2px 4px rgba(0,0,0,.22)}
/* flache Variante (Popup-Titel) - kein 3D, nicht klickbar */
.tbadge.flat{background:#fff;border-color:var(--accent);box-shadow:none;cursor:default;
  vertical-align:middle;margin-right:.45rem;transform:none}
.tbadge.flat:active{transform:none;box-shadow:none;background:#fff}
.infodlg{max-width:430px}
.infodlg h3{color:var(--accent)}
.infolist{margin:.2rem 0 .4rem;padding-left:1.1rem}
.infolist li{margin:.3rem 0;line-height:1.35}
.wtab{width:100%;max-width:100%;min-width:0;border-collapse:collapse;font-size:.9rem;table-layout:fixed}
.wtab td,.wtab th{border:1px solid var(--line);padding:.4rem .55rem;text-align:left;white-space:normal;word-break:break-word;overflow-wrap:anywhere;line-height:1.3}
.wtab .wsubrow th{background:#e4eefb;color:var(--accent);font-size:.82rem}
button.sec{background:#eef1f5;border:1px solid var(--line);border-radius:8px;padding:.35rem .9rem;cursor:pointer;font-size:.9rem}
.login{max-width:340px;margin:2rem auto;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:1.2rem;box-shadow:var(--shadow);text-align:center}
.login h2{margin:.2rem 0 .3rem}
.login input{width:100%;padding:.6rem .8rem;border:1px solid var(--line);border-radius:8px;font-size:1rem;margin:.5rem 0}
.login button{width:100%;padding:.6rem;background:var(--accent);color:#fff;border:0;border-radius:8px;font-size:1rem;cursor:pointer}
#modal{display:none}#modal.show{display:block}
#modal .ov{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}
#modal .dlg{background:#fff;border-radius:12px;padding:1rem 1.2rem;max-width:380px;width:100%;min-width:0;box-shadow:0 8px 30px rgba(0,0,0,.3)}
#modal .dlg h3{overflow-wrap:anywhere}
#modal .dlg h3{margin:.1rem 0 .6rem;font-size:1.05rem}
#modal label{display:block;font-size:.82rem;color:var(--muted);margin:.5rem 0}
#modal input{display:block;width:100%;margin-top:.2rem;padding:.5rem .6rem;border:1px solid var(--line);border-radius:8px;font-size:1rem;color:var(--ink)}
#modal .dlgbtn{display:flex;gap:.6rem;margin-top:1rem}
#modal #f_save{flex:1;padding:.55rem;background:var(--accent);color:#fff;border:0;border-radius:8px;cursor:pointer;font-size:1rem}

/* Filter */
.filterbox{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.8rem;box-shadow:var(--shadow);margin-bottom:.8rem}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .7rem}
.fgrid label{display:flex;flex-direction:column;font-size:.78rem;color:var(--accent);font-weight:600;gap:.2rem;min-width:0}
.fgrid input,.fgrid select{width:100%;min-width:0;box-sizing:border-box;padding:.45rem .55rem;border:1px solid var(--line);border-radius:7px;font-size:.95rem;color:var(--ink);background:#fff}
.fsec{margin:1rem 0 .35rem;font-size:.78rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.03em;border-top:1px solid var(--line);padding-top:.6rem}
.fsec:first-child{margin-top:0;border-top:0;padding-top:0}
.ffield .finput{display:flex;gap:.3rem;align-items:center}
.ffield .finput input{flex:1 1 auto;min-width:0}
.opsel{flex:0 0 auto;max-width:8.5rem;padding:.45rem .3rem;border:1px solid var(--line);border-radius:7px;font-size:.8rem;background:#fff;color:var(--ink)}
.fchecks{display:flex;flex-direction:column;gap:.2rem;margin-top:.3rem}
.fchecks label{font-size:.9rem;color:var(--ink)}
#fl_free{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.5rem}
.ffrow{display:flex;gap:.3rem;align-items:center}
.ffrow select,.ffrow input{padding:.4rem .4rem;border:1px solid var(--line);border-radius:7px;font-size:.85rem;background:#fff;color:var(--ink);min-width:0}
.ffrow .ff_join{flex:0 0 4rem}
.ffrow .ff_field{flex:0 0 7rem}
.ffrow .ff_op{flex:0 0 7rem}
.ffrow .ff_val{flex:1 1 auto}
.ffrow .ff_del{flex:0 0 auto;border:1px solid var(--line);background:#fff;color:#b00020;border-radius:6px;padding:.3rem .55rem;cursor:pointer}
@media (max-width:560px){
  .ffield .finput{flex-wrap:wrap}
  .opsel{max-width:none;width:100%}
  .ffrow{flex-wrap:wrap}
  .ffrow .ff_field,.ffrow .ff_op{flex:1 1 45%}
  .ffrow .ff_val{flex:1 1 100%}
}
.chk{display:flex;align-items:center;gap:.45rem;margin-top:.7rem;font-size:.9rem;color:var(--ink)}
.chk input{width:auto}
.fbtns{display:flex;gap:.6rem;margin-top:.8rem}
#fl_go{padding:.5rem 1.1rem;border:0;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;font-size:.95rem}
.hitem{display:flex;gap:.6rem;align-items:center}
.hitem .thumb{height:46px;flex:0 0 auto}
.hinfo{min-width:0}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:.7rem}
.gcell{margin:0;text-align:center}
.gcell .gcover{width:100%;height:auto;border-radius:6px;box-shadow:var(--shadow);background:#eee}
.gcell figcaption{font-size:.8rem;margin-top:.25rem;line-height:1.25}
.gcell figcaption a{color:var(--ink);text-decoration:none;font-weight:600}
#fl_more{margin:.7rem 0;text-align:center}
.moreh{margin:.8rem 0;text-align:center}
@media (min-width:560px){ .fgrid{grid-template-columns:1fr 1fr 1fr} }

/* Lightbox */
.zoom{cursor:zoom-in}
#modal .imgov{cursor:zoom-out}
#modal .imgov img{max-width:96vw;max-height:96vh;width:auto;height:auto;border-radius:6px;background:#fff;box-shadow:0 6px 40px rgba(0,0,0,.6)}
#modal .imgclose{position:fixed;top:10px;right:14px;width:42px;height:42px;border:0;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:1.4rem;cursor:pointer}

@media (max-width:520px){
  body{font-size:15px}
  .fgrid{grid-template-columns:1fr 1fr;gap:.45rem .5rem}
}

/* PWA: Update-/Installieren-Banner */
#updbar,#instbar{position:fixed;left:50%;transform:translateX(-50%);
  z-index:9000;display:flex;align-items:center;gap:.7rem;max-width:92vw;
  background:#1c2230;color:#fff;border:1px solid #2a3142;border-radius:12px;
  padding:.6rem .7rem .6rem 1rem;box-shadow:0 6px 24px rgba(0,0,0,.35);font-size:.92rem}
#updbar{bottom:calc(2.6rem + .6rem)}
#instbar{bottom:calc(2.6rem + 3.4rem)}   /* etwas hoeher, damit beide nicht ueberlappen */
#updbar #upd_go,#instbar #inst_go{background:#2b5cad;color:#fff;border:0;border-radius:8px;
  padding:.45rem .9rem;font-weight:600;cursor:pointer;white-space:nowrap}
#updbar #upd_go:disabled{opacity:.6;cursor:default}
#updbar #upd_x,#instbar #inst_x{background:transparent;color:#cbd3e0;border:0;font-size:1.2rem;
  line-height:1;cursor:pointer;padding:.1rem .3rem}

/* Startanimation (Kugel-Bild) */
/* App vor dem ersten Paint verdecken, bis die Animation startet/ausgeblendet ist */
html.intro-pending,html.intro-pending body{background:#0c0e14}
html.intro-pending body>*:not(#introOverlay){visibility:hidden}
body.intro-active{overflow:hidden}
#introOverlay{position:fixed;inset:0;z-index:9999;background:#0c0e14;opacity:1;transition:opacity .6s ease}
#introOverlay.hide{opacity:0;pointer-events:none}
#introStage{position:absolute;inset:0;width:100%;height:100%}
#introSkip{position:absolute;top:14px;right:14px;z-index:2;font:600 14px/1 system-ui,Segoe UI,Roboto,Arial,sans-serif;color:#e7ecf3;background:rgba(34,38,52,.7);border:1px solid #313748;border-radius:8px;padding:9px 14px;cursor:pointer}
#introSkip:hover{background:rgba(46,52,72,.92)}
