*{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)}
.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}
#detBody{padding:18px}
#map{height:240px;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%}
