:root{
  --bg:#0d1117;--surf:#161b22;--surf2:#1c2128;--surf3:#21262d;
  --border:#30363d;--accent:#58a6ff;--accent2:#00d4ff;
  --green:#3fb950;--red:#f85149;--orange:#d29922;--purple:#bc8cff;
  --text:#e6edf3;--muted:#8b949e;--muted2:#6e7681;--hl:#388bfd1a;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{background:var(--bg);color:var(--text);font-family:'Segoe UI',system-ui,sans-serif;font-size:13px;display:flex;flex-direction:column}

/* ── TOPBAR ── */
.topbar{
  background:var(--surf);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;padding:6px 12px;
  min-height:44px;flex-shrink:0;z-index:100;flex-wrap:wrap;row-gap:6px;
}
.logo{font-size:14px;font-weight:700;color:var(--accent2);white-space:nowrap}
.logo small{color:var(--muted);font-weight:400;font-size:11px}
.sep{width:1px;height:22px;background:var(--border);flex-shrink:0}
.stat-chip{
  display:flex;align-items:center;gap:4px;padding:3px 8px;
  border-radius:5px;border:1px solid var(--border);background:var(--surf2);
  cursor:pointer;transition:border-color .15s;white-space:nowrap;font-size:11px;
}
.stat-chip:hover{border-color:var(--accent)}
.stat-chip.active{border-color:var(--accent);background:var(--hl)}
.btn.active{border-color:var(--accent);background:var(--hl);color:var(--accent)}
.stat-chip b{font-size:13px;font-weight:700}
.spacer{flex:1}
.btn{padding:5px 12px;border-radius:6px;border:1px solid var(--border);cursor:pointer;
  font-size:12px;font-weight:600;transition:all .15s;background:var(--surf2);
  color:var(--text);white-space:nowrap;line-height:1.4}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn:disabled{opacity:.4;cursor:default}
.btn-green{background:#3fb95020;border-color:var(--green);color:var(--green)}
.btn-green:hover{background:var(--green);color:#0d1117}
.btn-red{background:#f8514920;border-color:var(--red);color:var(--red)}
.btn-red:hover{background:var(--red);color:#fff}

/* ── FILTER BAR ── */
.filterbar{
  background:var(--surf2);border-bottom:1px solid var(--border);
  padding:5px 12px;display:flex;align-items:center;gap:6px;
  flex-shrink:0;flex-wrap:wrap;
}
.fb-group{display:flex;align-items:center;gap:4px}
.fb-label{font-size:10px;color:var(--muted);white-space:nowrap}
input.fb{
  background:var(--surf);border:1px solid var(--border);color:var(--text);
  padding:3px 7px;border-radius:5px;font-size:12px;height:26px;
}
input.fb:focus{outline:none;border-color:var(--accent)}
.btn-rst2{padding:3px 8px;height:26px;border-radius:5px;border:1px solid var(--border);
  background:transparent;color:var(--muted);cursor:pointer;font-size:11px;transition:all .15s}
.btn-rst2:hover{border-color:var(--red);color:var(--red)}

/* ── LAYOUT ── */
.layout{display:flex;flex:1;overflow:hidden;min-height:0}

/* ── FOOTER ── */
.site-footer{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;
  padding:10px 14px;border-top:1px solid var(--border);background:var(--surf);
  font-size:11px;color:var(--muted);
}
.site-footer-desc{flex:1;min-width:200px}
.site-footer-contacts{white-space:nowrap}
.site-footer-link{color:var(--accent);text-decoration:none}
.site-footer-link:hover{text-decoration:underline}

/* ── SIDEBAR ── */
.sidebar{
  width:0;background:var(--surf);border-right:1px solid var(--border);
  overflow:hidden;transition:width .2s;flex-shrink:0;display:flex;flex-direction:column;
}
.sidebar.open{width:260px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.sidebar.open::-webkit-scrollbar{width:6px}
.sidebar.open::-webkit-scrollbar-track{background:transparent}
.sidebar.open::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.sb-inner{padding:10px;display:flex;flex-direction:column;gap:10px;width:100%;box-sizing:border-box}
.svc-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.svc-list::-webkit-scrollbar{width:6px}
.svc-list::-webkit-scrollbar-track{background:transparent}
.svc-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.svc-item{display:flex;align-items:center;gap:6px;padding:2px 4px;border-radius:3px;
  font-size:11px;cursor:pointer;user-select:none;line-height:13px}
.svc-item:hover{background:var(--surf2)}
.svc-item input{margin:0;flex-shrink:0;width:13px;height:13px;accent-color:var(--accent)}
.svc-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-sec h3{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);margin-bottom:5px}
.fr{margin-bottom:5px}
.fr label{display:block;font-size:10px;color:var(--muted);margin-bottom:2px}
.fr input:not([type=checkbox]),.fr select{width:100%;background:var(--surf2);border:1px solid var(--border);
  color:var(--text);padding:4px 6px;border-radius:4px;font-size:11px}
.fr input:not([type=checkbox]):focus,.fr select:focus{outline:none;border-color:var(--accent)}
.fr textarea{width:100%;background:var(--surf2);border:1px solid var(--border);
  color:var(--text);padding:4px 6px;border-radius:4px;font-size:11px;resize:vertical;
  font-family:inherit;box-sizing:border-box}
.fr textarea:focus{outline:none;border-color:var(--accent)}
.ef-photo-thumb{position:relative;width:64px;height:64px;border-radius:4px;overflow:hidden;border:1px solid var(--border)}
.ef-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ef-photo-del{position:absolute;top:2px;right:2px;background:#0008;color:#fff;border-radius:50%;
  width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:11px;
  cursor:pointer;line-height:1}
.ef-photo-del:hover{background:var(--red)}
.tog-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;cursor:pointer;user-select:none}
.tog-row span{font-size:11px}
.tog{width:28px;height:15px;background:var(--surf3);border:1px solid var(--border);
  border-radius:8px;position:relative;flex-shrink:0;transition:all .15s}
.tog::after{content:'';width:9px;height:9px;background:var(--muted);border-radius:50%;
  position:absolute;top:2px;left:2px;transition:all .15s}
.tog.on{background:var(--accent);border-color:var(--accent)}
.tog.on::after{left:15px;background:#fff}
.div{height:1px;background:var(--border);margin:2px 0}
.btn-rst{width:100%;padding:4px;background:transparent;border:1px solid var(--border);
  color:var(--muted);border-radius:4px;cursor:pointer;font-size:10px;transition:all .15s}
.btn-rst:hover{border-color:var(--red);color:var(--red)}
.sb-close{display:block;width:100%;padding:6px;background:var(--surf);border:1px solid var(--border);
  color:var(--muted);border-radius:4px;cursor:pointer;font-size:11px;margin-bottom:4px;transition:all .15s;
  position:sticky;top:0;z-index:1}
.sb-close:hover{border-color:var(--red);color:var(--red)}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}

/* ── PROGRESS ── */
#progressPanel{
  background:var(--surf2);border-bottom:1px solid var(--border);
  padding:8px 14px;display:none;flex-direction:column;gap:5px;
  max-height:160px;flex-shrink:0;
}
#progressPanel.show{display:flex}
.prog-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.prog-title{font-weight:700;font-size:12px}
.prog-mode{font-size:10px;color:var(--muted);background:var(--surf3);padding:1px 6px;border-radius:3px}
.prog-bar-wrap{background:var(--surf3);border-radius:3px;height:6px;overflow:hidden}
.prog-bar{height:100%;background:var(--accent2);border-radius:3px;transition:width .4s;width:0%}
.prog-counters{display:flex;gap:12px;font-size:10px;color:var(--muted)}
.prog-counters b{color:var(--text)}
.prog-log{background:var(--surf);border:1px solid var(--border);border-radius:4px;
  padding:5px 8px;font-family:monospace;font-size:10px;color:var(--muted);
  height:72px;overflow-y:auto;flex-shrink:0;line-height:1.4}
.prog-log .ok{color:var(--green)}
.prog-log .err{color:var(--red)}

/* ── DUPLICATES PANEL ── */
.dup-panel{
  background:var(--surf2);border-bottom:1px solid var(--border);
  padding:6px 14px;display:none;max-height:130px;overflow-y:auto;flex-shrink:0;
}
.dup-panel.show{display:block}
.dup-head{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.dup-head h3{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.dup-tabs{display:flex;gap:4px}
.dup-tab{padding:1px 7px;border-radius:3px;border:1px solid var(--border);
  cursor:pointer;font-size:10px;transition:all .15s;background:var(--surf)}
.dup-tab.on{background:var(--accent);border-color:var(--accent);color:#0d1117;font-weight:700}
.dup-groups{display:flex;flex-direction:column;gap:3px}
.dup-grp{background:var(--surf);border:1px solid var(--border);border-radius:4px;
  padding:4px 8px;font-size:11px;display:flex;gap:6px;align-items:baseline;flex-wrap:wrap}
.dk{font-weight:700;white-space:nowrap}
.dk.ph{color:var(--orange)}
.dk.tg{color:var(--purple)}
.dn a{color:var(--accent);text-decoration:none}
.dn a:hover{text-decoration:underline}

/* ── TABLE ── */
.table-area{flex:1;overflow:auto;min-height:0}
.res-bar{padding:4px 14px;background:var(--surf);border-bottom:1px solid var(--border);
  font-size:10px;color:var(--muted);flex-shrink:0}
table{width:100%;border-collapse:collapse}
thead th{background:var(--surf);color:var(--muted);font-size:10px;text-transform:uppercase;
  letter-spacing:.05em;padding:6px 8px;text-align:left;position:sticky;top:0;
  border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap;z-index:5}
thead th:hover{color:var(--text)}
th.asc::after{content:' ↑';color:var(--accent2)}
th.desc::after{content:' ↓';color:var(--accent2)}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
tbody tr:hover{background:var(--hl)}
tbody tr.rph{box-shadow:inset 3px 0 0 var(--orange)}
tbody tr.rtg{box-shadow:inset 3px 0 0 var(--purple)}
tbody tr.rbt{box-shadow:inset 3px 0 0 var(--red)}
tbody tr.is-removed{opacity:.4}
tbody tr.is-removed:hover{opacity:.7}
.removed-badge{display:inline-flex;align-items:center;font-size:9px;font-weight:700;
  padding:1px 4px;border-radius:2px;margin-left:3px;vertical-align:middle;
  background:#8b949e18;color:var(--muted);border:1px solid #8b949e40}
td{padding:4px 8px;vertical-align:middle}
.phcol{width:46px}
.phw{width:38px;height:50px;overflow:hidden;border-radius:3px}
.phw img{width:100%;height:100%;object-fit:cover;display:block}
.phw .no-img{width:100%;height:100%;background:var(--surf3)}
.nl{color:var(--accent);font-weight:600;text-decoration:none}
.nl:hover{text-decoration:underline}
.badge{display:inline-flex;align-items:center;font-size:9px;font-weight:700;
  padding:1px 4px;border-radius:2px;margin-left:3px;vertical-align:middle}
.bv{background:#3fb95018;color:var(--green);border:1px solid #3fb95040}
.bp{background:#d2992218;color:var(--orange);border:1px solid #d2992240}
.bt{background:#bc8cff18;color:var(--purple);border:1px solid #bc8cff40}
.bx{background:#58a6ff18;color:var(--accent);border:1px solid #58a6ff40}
.pv{font-family:monospace;font-size:11px}
.pv a{color:var(--text);text-decoration:none}
.pv a:hover{color:var(--accent)}
.tgv a{color:var(--purple);text-decoration:none;font-size:11px}
.tgv a:hover{text-decoration:underline}
.pm{font-weight:700;color:var(--green);font-size:12px}
.sv2{font-size:10px;color:var(--muted);max-width:160px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.mark-star{font-size:14px;cursor:pointer;opacity:.25;transition:opacity .15s;user-select:none;padding:0 2px}
.mark-star.on{opacity:1;color:var(--green)}
.mark-star.admin:hover{opacity:.7}
.fav-star{font-size:14px;cursor:pointer;opacity:.25;transition:opacity .15s;user-select:none;padding:0 2px;color:var(--red)}
.fav-star.on{opacity:1}
.fav-star:hover{opacity:.7}
.pcard-fav{position:absolute;top:8px;right:8px;font-size:16px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0d1117a0;opacity:.7}
.pcard-fav.on{opacity:1}
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state .icon{font-size:40px;margin-bottom:12px}
.empty-state h2{font-size:15px;color:var(--text);margin-bottom:6px}

/* ── CARD VIEW (mobile) ── */
.cards{display:none;flex-direction:column;gap:8px;padding:8px}
.pcard{display:flex;gap:10px;background:var(--surf2);border:1px solid var(--border);
  border-radius:8px;padding:8px;cursor:pointer;position:relative}
.pcard.is-removed{opacity:.4}
.pcard.rph{box-shadow:inset 3px 0 0 var(--orange)}
.pcard.rtg{box-shadow:inset 3px 0 0 var(--purple)}
.pcard.rbt{box-shadow:inset 3px 0 0 var(--red)}
.pcard-photo{width:60px;height:80px;flex-shrink:0;border-radius:5px;overflow:hidden;background:var(--surf3)}
.pcard-photo img{width:100%;height:100%;object-fit:cover;display:block}
.pcard-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;justify-content:center}
.pcard-name{font-weight:700;font-size:13px;display:flex;align-items:center;gap:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pcard-meta{font-size:11px;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap}
.pcard-prices{font-size:11px;display:flex;gap:8px}
.pcard-svc{font-size:10px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pcard-star{position:absolute;top:8px;right:8px;font-size:15px}
.order-cell{display:flex;align-items:center;justify-content:flex-end;gap:3px}
.order-num{min-width:14px;text-align:right}
.order-arrow{cursor:pointer;font-size:9px;color:var(--muted);user-select:none;padding:1px 2px;border-radius:2px;line-height:1}
.order-arrow:hover{color:var(--accent);background:var(--surf2)}
.order-arrow.disabled{opacity:.2;pointer-events:none}
.pcard-order{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:4px;
  background:#0d1117a0;border-radius:10px;padding:2px 6px;font-size:10px;color:var(--text)}
.pcard-order .order-arrow{font-size:11px;color:var(--muted)}
.pcard-order .order-arrow:hover{color:var(--accent);background:transparent}

/* ── DETAIL DRAWER ── */
#drawer{
  position:fixed;top:0;right:-500px;width:460px;height:100%;
  background:var(--surf);border-left:1px solid var(--border);
  z-index:200;transition:right .22s;display:flex;flex-direction:column;overflow:hidden;
}
#drawer.open{right:0}
.dr-head{padding:12px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;flex-shrink:0}
.dr-head h2{flex:1;font-size:14px;font-weight:700}
.dr-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}
.dr-close:hover{color:var(--text)}
.dr-body{overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px;flex:1}
.dr-photos{display:flex;gap:6px;flex-wrap:wrap}
.dr-photos img{height:100px;width:auto;border-radius:5px;object-fit:cover;cursor:pointer}
.dr-photos img:hover{opacity:.85}
.dr-section h4{font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted2);margin-bottom:6px}
.dr-fields{display:grid;grid-template-columns:auto 1fr;gap:3px 10px}
.df-label{color:var(--muted);font-size:11px;white-space:nowrap}
.df-value{font-size:11px;font-weight:600}
.dr-services{display:flex;gap:4px;flex-wrap:wrap}
.dr-svc{font-size:10px;padding:2px 6px;border-radius:3px;
  background:var(--surf3);border:1px solid var(--border);color:var(--muted)}
.dr-desc{background:var(--surf2);border:1px solid var(--border);border-radius:5px;
  padding:8px 10px;font-size:11px;color:var(--muted);line-height:1.5;
  white-space:pre-wrap;word-break:break-word}
.dr-links{display:flex;gap:6px;flex-wrap:wrap}
.dr-link{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;
  background:var(--surf2);border:1px solid var(--border);border-radius:5px;
  color:var(--accent);text-decoration:none;font-size:11px;font-weight:600;transition:all .15s}
.dr-link:hover{border-color:var(--accent);background:var(--hl)}

/* ── REVIEWS ── */
.dr-review{background:var(--surf2);border:1px solid var(--border);border-radius:5px;padding:8px 10px;font-size:12px}
.dr-review+.dr-review{margin-top:6px}
.dr-review-text{margin-top:4px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.rstar{font-size:18px;cursor:pointer;color:var(--muted)}
.rstar.on{color:var(--accent)}
.dr-review-form textarea{width:100%;background:var(--surf2);border:1px solid var(--border);
  color:var(--text);padding:6px 8px;border-radius:5px;font-size:12px;resize:vertical;
  font-family:inherit;box-sizing:border-box;margin-bottom:8px}
.dr-review-form textarea:focus{outline:none;border-color:var(--accent)}
.account-tabs{display:flex;gap:4px;margin-bottom:4px}
.account-tab{flex:1;background:var(--surf2);border:1px solid var(--border);color:var(--muted);
  border-radius:6px;padding:6px;font-size:12px;font-weight:600;cursor:pointer}
.account-tab.active{background:var(--accent);color:#0d1117;border-color:var(--accent)}
.auth-field{display:flex;flex-direction:column;gap:5px}
.auth-field label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.auth-field input{background:var(--surf2);border:1px solid var(--border);color:var(--text);
  padding:8px 10px;border-radius:6px;font-size:13px;outline:none}
.auth-field input:focus{border-color:var(--accent)}

/* ── TOAST ── */
.toast{position:fixed;bottom:16px;right:16px;background:var(--surf);
  border:1px solid var(--border);border-radius:6px;padding:8px 16px;
  font-size:12px;z-index:400;transform:translateY(50px);opacity:0;transition:all .2s}
.toast.show{transform:translateY(0);opacity:1}
.toast.ok{border-color:var(--green);color:var(--green)}
.toast.err{border-color:var(--red);color:var(--red)}

/* ── CHAT ── */
.chat-badge{background:var(--red);color:#fff;border-radius:8px;padding:0 5px;font-size:10px;margin-left:4px}
.chat-sidebar{
  width:0;background:var(--surf);border-right:1px solid var(--border);
  overflow:hidden;transition:width .2s;flex-shrink:0;display:flex;flex-direction:column;
}
.chat-sidebar.open{width:300px}
.chat-head{padding:10px 12px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;
  white-space:nowrap}
.chat-head-actions{display:flex;align-items:center;gap:8px}
.chat-lock-btn{width:24px;height:24px;border-radius:5px;border:1px solid var(--border);
  background:transparent;color:var(--muted);cursor:pointer;font-size:13px;line-height:1}
.chat-lock-btn:hover{border-color:var(--accent);color:var(--accent)}
.chat-lock-btn.locked{border-color:var(--red);color:var(--red);background:#f8514918}
.chat-close{cursor:pointer;color:var(--muted);font-size:16px;line-height:1}
.chat-close:hover{color:var(--text)}
.chat-messages{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px;min-width:280px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.chat-messages::-webkit-scrollbar{width:6px}
.chat-messages::-webkit-scrollbar-track{background:transparent}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.chat-msg{display:flex;flex-direction:column;gap:2px;max-width:90%}
.chat-msg.own{align-self:flex-end;align-items:flex-end}
.chat-author{font-size:11px;color:var(--accent2);font-weight:600;display:flex;align-items:center;gap:6px}
.chat-msg.own .chat-author{color:var(--green)}
.chat-del{cursor:pointer;color:var(--muted);font-size:11px;opacity:.6}
.chat-del:hover{color:var(--red);opacity:1}
.chat-bubble{background:var(--surf2);border-radius:6px;padding:6px 9px;font-size:12px;
  word-break:break-word;white-space:pre-wrap;line-height:1.4}
.chat-msg.own .chat-bubble{background:var(--hl)}
.chat-time{font-size:10px;color:var(--muted2)}
.chat-empty{color:var(--muted);font-size:12px;text-align:center;padding:20px 0}
.chat-input-row{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border);min-width:280px}
.chat-input-row input{flex:1;background:var(--surf2);border:1px solid var(--border);color:var(--text);
  padding:8px 10px;border-radius:6px;font-size:12px;outline:none}
.chat-input-row input:focus{border-color:var(--accent)}
.chat-input-row button{background:var(--accent);color:#0d1117;border:none;border-radius:6px;
  padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer}
.chat-login-prompt{padding:10px 12px;border-top:1px solid var(--border);color:var(--muted);
  font-size:12px;text-align:center;min-width:280px}
.chat-login-prompt a{color:var(--accent2);cursor:pointer;text-decoration:underline}

@media (max-width:768px){
  .chat-sidebar{width:0;position:fixed;top:0;left:0;height:100%;z-index:150;transition:width .2s}
  .chat-sidebar.open{width:100%;overflow-y:hidden}
}

/* ── SPINNER ── */
.spin{width:12px;height:12px;border:2px solid var(--border);
  border-top-color:var(--accent2);border-radius:50%;
  animation:spin .6s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── LIGHTBOX ── */
#lightbox{
  display:none;position:fixed;inset:0;background:#000000e0;z-index:500;
  align-items:center;justify-content:center;
}
#lightbox.open{display:flex}
#lbImg{max-width:92vw;max-height:92vh;object-fit:contain;border-radius:6px;user-select:none}
.lb-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:#ffffff18;border:none;color:#fff;font-size:28px;cursor:pointer;
  padding:10px 16px;border-radius:6px;transition:background .15s;user-select:none;
}
.lb-btn:hover{background:#ffffff30}
#lbPrev{left:12px}
#lbNext{right:12px}
#lbClose{position:absolute;top:12px;right:12px;background:#ffffff18;border:none;
  color:#fff;font-size:20px;cursor:pointer;padding:6px 12px;border-radius:6px}
#lbClose:hover{background:#ffffff30}
#lbCounter{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  color:#ffffffa0;font-size:12px;user-select:none}

/* ── PROFILE HISTORY ── */
.dr-hist-entry{background:var(--surf2);border:1px solid var(--border);border-radius:5px;
  padding:7px 10px;margin-bottom:5px;cursor:pointer;transition:border-color .15s}
.dr-hist-entry:hover{border-color:var(--accent)}
.dr-hist-meta{font-size:10px;color:var(--muted);margin-bottom:4px}
.dr-hist-tags{display:flex;flex-wrap:wrap;gap:3px}
.dr-hist-tag{font-size:9px;padding:1px 6px;border-radius:2px;
  background:#d2992218;border:1px solid #d2992240;color:var(--orange)}
.dr-hist-body{display:none;margin-top:8px;padding-top:8px;
  border-top:1px solid var(--border)}
.dr-hist-body.open{display:block}
.df-changed{color:var(--orange)!important;font-weight:700}
.dr-hist-section-changed{outline:1px solid #d2992240;border-radius:4px;padding:3px 5px;background:#d2992210}

/* ── ADMIN-ONLY COLUMNS ── */
.admin-col{display:none}
body.is-admin .admin-col{display:table-cell}

/* ── NO-HOVER DEVICES (touch screens) ── */
@media (hover:none){
  .btn:hover{border-color:var(--border);color:var(--text);background:var(--surf2)}
  .btn-green:hover{background:#3fb95020;color:var(--green)}
  .btn-red:hover{background:#f8514920;color:var(--red)}
  .stat-chip:hover{border-color:var(--border)}
  tbody tr:hover{background:transparent}
  .fav-star{opacity:.6;font-size:18px}
  .fav-star.on{opacity:1}
}

/* ── MOBILE ── */
@media (max-width:768px){
  html,body{height:auto;overflow:auto}
  body{flex-direction:column}

  /* Topbar */
  .topbar{height:auto;flex-wrap:wrap;padding:6px 10px;gap:6px;row-gap:5px}
  .logo{font-size:13px}
  .sep{display:none}
  #adminControls{order:-1;width:100%;overflow-x:auto;padding-bottom:2px}
  #adminControls>*{flex-shrink:0}
  #scDupPh,#scDupTg{display:none}
  #btnDups,button[onclick="loadData()"]{display:none!important}
  #btnSidebar{order:9}
  #adminDbBtn{order:10}
  .spacer{display:none}
  #userBadge{font-size:10px}

  /* Pagination — hide labels, keep icons only */
  .res-bar{flex-wrap:wrap;row-gap:4px}
  .pg-label{display:none}

  /* Layout */
  .layout{flex-direction:column;overflow:visible;min-height:0;flex:none}

  /* Sidebar */
  .sidebar{width:0;position:fixed;top:0;left:0;height:100%;z-index:150;transition:width .2s}
  .sidebar.open{width:100%;overflow-y:auto}

  /* Main */
  .main{overflow:visible;flex:none}

  /* Progress */
  #progressPanel{max-height:none}

  /* Table area */
  .table-area{overflow-x:visible;overflow-y:visible;flex:none}

  /* Card view replaces table on mobile */
  table{display:none}
  .cards{display:flex}

  /* Filter bar — just the search field, full width */
  .filterbar{padding:6px 10px}
  .filterbar .fb-label{display:none}

  /* Drawer — full screen */
  #drawer{width:100%;right:-100%}
  #drawer.open{right:0}
  .dr-head{flex-wrap:wrap;position:relative;padding-right:36px}
  .dr-close{position:absolute;top:10px;right:12px}
  #drAdminBtns{margin-left:0!important;width:100%;flex-wrap:wrap}



  /* Login modal */
  #loginOverlay>div{width:90%;padding:20px}
}
