*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#1a1a2e;--card:#16213e;--accent:#4fbdba;--accent2:#7ec8e3;--line:#2a3a5e;--err:#842029;--ok:#2d6a4f;--dim:#8aa}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;background:var(--bg);color:#eee;min-height:100vh}
.dim{color:var(--dim)}.small{font-size:.85em}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{font-size:1.25em;font-weight:bold;color:var(--accent)}
a.brand,a.brand:hover{text-decoration:none}
.ico.on{background:#1a4a7a;border-color:var(--accent)}
.icons{display:flex;align-items:center;gap:8px}
.ico{background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:8px;padding:7px 10px;font-size:1.05em;cursor:pointer;line-height:1;display:inline-flex;align-items:center}
.ico:hover{background:#1a4a7a}.ico.txt{font-size:.95em}
.btn-top{background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:8px;padding:8px 14px;cursor:pointer;font-size:.9em;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:.2s}
.btn-top:hover{background:#842029;border-color:#a52834;text-decoration:none}
.who{color:var(--dim);font-size:.9em;margin:0 4px}.who b{color:#e74c3c}
.langsel{background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:7px;padding:6px 8px;font-size:.9em;cursor:pointer}

.wrap{max-width:680px;margin:26px auto;padding:0 16px}
.wrapwide{max-width:1600px;width:96%;margin:26px auto;padding:0 16px}
.card{background:var(--card);border-radius:12px;padding:28px;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.drop{background:#0f3460;border:3px dashed var(--accent);border-radius:10px;padding:46px 20px;text-align:center;position:relative}
.drop .big{font-size:42px;margin-bottom:10px}
.btnrow{margin-top:14px}
.btn{background:var(--accent);color:#13233a;border:none;border-radius:8px;padding:14px 18px;font-weight:bold;font-size:1em;cursor:pointer;width:100%;transition:.2s}
.btn:hover{background:var(--accent2)}
.btnrow+.btnrow{margin-top:8px}
.note{margin-top:14px}

.result{margin-top:22px}
.preview{max-width:100%;border-radius:8px;margin-bottom:14px;box-shadow:0 5px 20px rgba(0,0,0,.3)}
.urlrow{display:flex;gap:8px;background:#0f3460;padding:12px;border-radius:8px}
.url{flex:1;background:transparent;border:none;color:var(--accent);font-family:monospace;outline:none}
.urlrow .btn{width:auto;padding:8px 14px}

.msg{padding:11px;border-radius:7px;margin-bottom:14px;text-align:center}
.msg.err{background:var(--err);color:#ea868f}.msg.ok{background:var(--ok);color:#95d5b2}
.spinner{width:38px;height:38px;border:3px solid #333;border-top:3px solid var(--accent);border-radius:50%;animation:sp 1s linear infinite;margin:16px auto 0}
@keyframes sp{to{transform:rotate(360deg)}}

/* Panels */
.panel{display:none;background:var(--card);border-radius:12px;margin-top:18px;overflow:hidden}
.panel.open{display:block}
.page{background:var(--card);border-radius:12px;overflow:hidden}
.page.narrow{max-width:560px;margin-left:auto;margin-right:auto}
.phead{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.phead h2{font-size:1.05em;color:var(--accent)}
.x{background:none;border:none;color:#aaa;font-size:1.5em;cursor:pointer;line-height:1}
.ptools{padding:12px 18px;display:flex;gap:8px}
.ptools input[type=search]{flex:1;background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:7px;padding:8px 10px}
.ptools .btn{width:auto;padding:9px 14px}
.tablewrap{overflow:auto;max-height:62vh}
.tbl{width:100%;border-collapse:collapse;font-size:.86em}
.tbl th,.tbl td{padding:9px 12px;text-align:center;vertical-align:middle;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl th{position:sticky;top:0;background:#0f3460;color:var(--accent2)}
.tbl td.wrap{white-space:normal;word-break:break-all}
.tbl td.thcell{padding:5px 8px}
.thumb{width:78px;height:48px;object-fit:cover;border-radius:4px;border:1px solid var(--line);background:#0f1830;display:block;margin:0 auto}
.thumb:hover{border-color:var(--accent)}
.tbl th.sortable{cursor:pointer;user-select:none}
.tbl th.sortable:hover{color:#fff}
.tbl tr.filterrow th{top:36px;background:#0e2547;padding:4px 6px;z-index:9}
.colfilter{width:100%;min-width:64px;background:#0f1830;border:1px solid var(--line);color:#eee;border-radius:5px;padding:4px 6px;font-size:.88em}
.tbl tr.disabledrow td{opacity:.45}
.rowsel,#selAll{cursor:pointer;width:16px;height:16px}
.warn{background:#7a531b;color:#ffd9a0;border:1px solid #a06a1f;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:.92em}
.warn:hover{background:#a06a1f;color:#fff}
.ovtools{flex-wrap:wrap}
.bulkdel{margin:0 18px 12px}
.bulkdel summary{cursor:pointer;color:var(--accent2);padding:6px 0;user-select:none}
.bulkrow{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:12px;background:#0f1830;border-radius:8px;margin-top:6px}
.bulkrow label{display:flex;align-items:center;gap:5px;color:var(--dim);font-size:.9em}
.bulkrow input{background:#16213e;border:1px solid var(--line);color:#eee;border-radius:6px;padding:7px 9px}
.le-only{display:none}
.tag.le{background:#5a3a7a;color:#e6d5ff}
.lebanner{margin:0 18px 12px;padding:12px 14px;background:#3a2a1a;border:1px solid #7a531b;border-radius:8px;color:#ffd9a0;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ac-wrap{position:relative;display:block}
.ac-wrap input{width:100%}
.ac-list{position:absolute;left:0;right:0;top:100%;z-index:60;background:#16213e;border:1px solid var(--accent);border-top:0;border-radius:0 0 7px 7px;max-height:210px;overflow:auto;display:none;box-shadow:0 8px 20px rgba(0,0,0,.4)}
.ac-list.open{display:block}
.ac-item{padding:9px 11px;cursor:pointer;border-bottom:1px solid var(--line)}
.ac-item:last-child{border-bottom:0}
.ac-item:hover{background:#1a4a7a;color:#fff}
.tbl tr:nth-child(even) td{background:rgba(255,255,255,.035)}
.tbl tr:hover td{background:rgba(79,189,186,.12)}
/* Ablauf-Schattierung: <24h rot, <7T orange, <14T gelb */
.tbl tr.exp-red td{background:rgba(220,45,45,.30)}
.tbl tr.exp-red:hover td{background:rgba(220,45,45,.42)}
.tbl tr.exp-orange td{background:rgba(230,130,30,.28)}
.tbl tr.exp-orange:hover td{background:rgba(230,130,30,.40)}
.tbl tr.exp-yellow td{background:rgba(225,200,40,.22)}
.tbl tr.exp-yellow:hover td{background:rgba(225,200,40,.34)}
.tag{display:inline-block;padding:1px 7px;border-radius:10px;font-size:.85em}
.tag.live{background:#1b7a3e;color:#cfe}.tag.off{background:#262b35;color:#7a8190}
.tag.adm{background:#e74c3c;color:#fff}.tag.usr{background:#345;color:#cde}
.livemeta{margin-left:12px;color:#cdd6e3}
.lnk{background:#0f3460;border:1px solid var(--line);color:var(--accent);cursor:pointer;padding:6px 12px;border-radius:6px;font:inherit;font-size:.92em}
.lnk:hover{background:#1a4a7a}
.del{background:#842029;color:#ea868f;border:1px solid #a52834;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:.92em}
.del:hover{background:#a52834;color:#fff}

/* Forms */
.form{padding:18px;display:flex;flex-direction:column;gap:12px}
.form label{display:flex;flex-direction:column;gap:5px;font-size:.9em;color:var(--dim)}
.form input,.form select{background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:7px;padding:10px}
.form .chk{flex-direction:row;align-items:center;gap:8px}
.form hr{border:none;border-top:1px solid var(--line)}
.form .btn{width:auto;align-self:flex-start;padding:11px 20px}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:flex-start;justify-content:center;padding:30px 14px;z-index:50;overflow:auto}
.modal-card{background:var(--card);border-radius:12px;width:100%;max-width:640px}
#detailModal .modal-card{max-width:960px}
#detBody{padding:18px}
#detailModal .kv a{white-space:nowrap}            /* URL nicht umbrechen */
#detailModal .gpsline{white-space:nowrap;overflow-x:auto}  /* GPS-Adresse in einer Zeile */
#map{height:360px;border-radius:8px;margin:10px 0}
.kv{width:100%;border-collapse:collapse;font-size:.86em}
.kv td{padding:5px 8px;border-bottom:1px solid var(--line);vertical-align:top}
.kv td:first-child{color:var(--dim);white-space:nowrap;width:34%}
.exifbox{max-height:260px;overflow:auto;background:#0f1830;border-radius:7px;padding:10px;margin-top:8px;font-family:monospace;font-size:.8em;white-space:pre-wrap;word-break:break-all}
.exifdetails{margin-top:14px}
.exifdetails summary{cursor:pointer;color:#7ec8e3;font-size:.95em;font-weight:bold;padding:5px 0;user-select:none;list-style:revert}
.exifdetails summary:hover{color:var(--accent2)}

/* Auth */
body.auth{display:flex;align-items:center;justify-content:center;padding:20px}
.login{max-width:360px;width:100%;display:flex;flex-direction:column;gap:14px}
.login h1{color:var(--accent);text-align:center}
.login label{display:flex;flex-direction:column;gap:6px;color:var(--dim);font-size:.9em}
.login input{background:#0f3460;border:1px solid var(--line);color:#eee;border-radius:7px;padding:11px}
.login .btn{width:100%}

/* Views-Zahl klickbar (Overview) */
.vlink{background:none;border:none;color:var(--accent2);font:inherit;font-weight:bold;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}
.vlink:hover{color:#fff}

/* Footer (Startseite) */
.sitefooter{text-align:center;margin:28px auto 34px;padding:0 16px;color:var(--dim)}
.sitefooter .ftcount{font-size:.92em;letter-spacing:.2px}
.sitefooter .ftmade{font-size:.85em;margin-top:6px;opacity:.85}

/* Netzwerk-Flags (Detail) */
.nf{display:inline-block;padding:1px 7px;border-radius:8px;font-size:.85em;margin-right:4px}
.nf.vpn{background:#842029;color:#ffb3b3}
.nf.dc{background:#7a531b;color:#ffd9a0}
.nf.mo{background:#1b5e7a;color:#bfe9ff}
.nf.ok{background:#2d6a4f;color:#b7e4c7}

/* Heatmap */
.hmtools{flex-wrap:wrap;align-items:flex-end;gap:10px}
.hmtools label{display:flex;flex-direction:column;gap:4px;color:var(--dim);font-size:.82em}
.hmtools input{background:#0f1830;border:1px solid var(--line);color:#eee;border-radius:6px;padding:7px 9px}
.hmtools .btn,.hmtools .lnk{align-self:flex-end}
.hmlayers{display:flex;flex-wrap:wrap;gap:14px;align-items:center;padding:0 18px 6px}
.hmtog{display:flex;align-items:center;gap:6px;color:#cdd6e3;font-size:.9em;cursor:pointer}
.hmsep{width:1px;height:18px;background:var(--line)}
.hmdot{display:inline-block;width:12px;height:12px;border-radius:50%}
.hmdot.up{background:#ff4d4d}.hmdot.view{background:#39d98a}
#hmMap{height:540px;margin:8px 18px;border-radius:10px;border:1px solid var(--line);background:#0a0f1e}
.hmgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;padding:14px 18px 22px}
.hmcard{background:#0f1830;border:1px solid var(--line);border-radius:10px;padding:14px}
.hmcard h3{color:var(--accent2);font-size:.95em;margin-bottom:10px}
.hmbig{font-size:1em;margin-top:4px}
.hmbig span{font-size:1.7em;font-weight:bold;margin-right:6px}
.hmcard .up{color:#ff6b6b}.hmcard .view{color:#39d98a}
.hmsub{margin:2px 0 10px}
.hmrisk{margin-right:12px;color:#cdd6e3;font-size:.9em}
.hmrow{display:flex;align-items:center;gap:8px;margin:6px 0;font-size:.85em}
.hmlabel{flex:1 1 52%;min-width:0;white-space:normal;overflow-wrap:anywhere;color:#cdd6e3}
.hmbars{flex:1 1 30%;display:flex;flex-direction:column;gap:2px}
.hmbar{height:6px;border-radius:3px;min-width:2px}
.hmbar.up{background:#ff4d4d}.hmbar.view{background:#39d98a}
.hmnums{flex:0 0 auto;color:var(--dim)}
.hmleg{background:rgba(15,24,48,.88);padding:8px 11px;border:1px solid var(--line);border-radius:8px;color:#cdd6e3;font-size:.82em;line-height:1.6}
.hmleg .hmdot{margin-right:6px;vertical-align:middle}
.hmp-up,.hmp-view{animation:hmpulse 2.4s ease-in-out infinite}
@keyframes hmpulse{0%,100%{fill-opacity:.22}50%{fill-opacity:.6}}

/* ===== Mobile / iPhone ===== */
html,body{overflow-x:clip;max-width:100%}          /* kein horizontaler Versatz der ganzen Seite */
.url{min-width:0}                                  /* URL-Feld sprengt den Flex nicht mehr auf */
@media (max-width:640px){
  .topbar{flex-wrap:wrap;gap:8px 6px;padding:10px 12px}      /* Menüzeile umbrechen statt abschneiden */
  .icons{flex-wrap:wrap;justify-content:flex-end;gap:6px}
  .brand{font-size:1.1em}
  .who{display:none}                                          /* Username ausblenden – spart Platz */
  .ico{padding:6px 9px}
  .btn-top{padding:7px 11px;font-size:.85em}
  .langsel{padding:5px 6px;font-size:.85em}
  .wrap{margin:16px auto;padding:0 12px}
  .wrapwide{margin:16px auto;padding:0 12px;width:100%}
  .card{padding:20px 16px}
  .urlrow{flex-wrap:wrap}
  .urlrow .btn{width:100%}
  .ptools,.ovtools,.hmtools,.hmlayers,.bulkrow{flex-wrap:wrap}
  #map{height:300px}
  #hmMap{height:380px;margin:8px 12px}
  .modal{padding:14px 8px}
  #detailModal .modal-card{max-width:100%}
}
