*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --sidebar-width: 280px;
  --header-height: 48px;
  --bg: #1a1a2e;
  --bg2: #16213e;
  --bg3: #0f3460;
  --accent: #3388ff;
  --accent2: #e94560;
  --text: #e0e0e0;
  --text-dim: #8888aa;
  --border: #2a2a4a;
  --radius: 6px;
  --shadow: 0 2px 8px rgba(0,0,0,0.4);
}

body { font-family: 'Segoe UI', system-ui, sans-serif; background: var(--bg); color: var(--text); height: 100vh; overflow: hidden; display: flex; flex-direction: column; }

/* Top nav */
#topnav {
  height: var(--header-height);
  background: var(--bg3);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 16px;
  flex-shrink: 0;
  z-index: 20;
}
.topnav-brand {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
  letter-spacing: 0.03em;
  margin-right: 8px;
}
.topnav-center {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.topnav-center label {
  font-size: 0.78rem;
  color: var(--text-dim);
  white-space: nowrap;
}
.topnav-center select {
  width: 180px;
  margin-bottom: 0;
  padding: 5px 8px;
  font-size: 0.85rem;
}
.topnav-sep {
  color: var(--text-dim);
  font-size: 1rem;
  opacity: 0.5;
  user-select: none;
}
#btn-new-country,
#btn-new-municipality {
  width: auto;
  margin-top: 0;
  white-space: nowrap;
  background: var(--bg2);
  color: var(--text);
  border: 1px solid var(--border);
  padding: 5px 10px;
  font-size: 0.8rem;
}
#btn-new-country:hover,
#btn-new-municipality:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.topnav-right {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}
.topnav-admin-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 0.78rem;
  border-radius: var(--radius);
  cursor: pointer;
}
.topnav-admin-btn:hover { border-color: var(--accent); color: var(--accent); }
#topnav-user {
  font-size: 0.8rem;
  color: var(--text-dim);
}
#btn-logout {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 0.78rem;
  border-radius: var(--radius);
}
#btn-logout:hover { border-color: var(--accent2); color: var(--accent2); }

#app { display: flex; flex: 1; overflow: hidden; }

/* Sidebar */
#sidebar {
  width: var(--sidebar-width);
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  flex-shrink: 0;
  z-index: 10;
  height: 100%;
}


section { padding: 12px 14px; border-bottom: 1px solid var(--border); }
section h2 { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-dim); margin-bottom: 8px; }

/* Inputs */
select, input[type="text"], input[type="color"] {
  width: 100%;
  padding: 6px 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: 0.85rem;
  margin-bottom: 6px;
}
select:focus, input:focus { outline: none; border-color: var(--accent); }

/* Buttons */
button {
  cursor: pointer;
  border: none;
  border-radius: var(--radius);
  font-size: 0.82rem;
  padding: 6px 10px;
  transition: background 0.15s;
}
button.primary { background: var(--accent); color: #fff; }
button.primary:hover { background: #2277ee; }
button.danger { background: var(--accent2); color: #fff; }
button.danger:hover { background: #c73348; }
#btn-new-layer {
  width: 100%;
  margin-top: 6px;
  background: var(--bg3);
  color: var(--text);
  border: 1px solid var(--border);
}
#btn-new-layer:hover { background: var(--accent); color: #fff; }

/* Draw tools */
#draw-tools { display: flex; flex-direction: column; gap: 4px; }
.tool-btn {
  text-align: left;
  padding: 7px 10px;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
}
.tool-btn:hover { background: var(--bg3); border-color: var(--accent); }
.tool-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
#draw-status { margin-top: 6px; font-size: 0.78rem; color: var(--text-dim); min-height: 18px; }

/* Layers list */
#layers-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }

.layer-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  transition: border-color 0.15s;
}
.layer-item:hover { border-color: var(--accent); }
.layer-item.active { border-color: var(--accent); background: var(--bg3); }

.layer-color-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.layer-name { flex: 1; font-size: 0.83rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.layer-type { font-size: 0.7rem; color: var(--text-dim); flex-shrink: 0; }
.layer-vis-btn {
  background: none;
  border: none;
  color: var(--text-dim);
  padding: 2px 4px;
  font-size: 0.8rem;
  flex-shrink: 0;
}
.layer-vis-btn:hover { color: var(--text); }
.layer-del-btn {
  background: none;
  border: none;
  color: var(--accent2);
  padding: 2px 4px;
  font-size: 0.78rem;
  flex-shrink: 0;
  opacity: 0;
}
.layer-item:hover .layer-del-btn { opacity: 1; }

#active-layer-info { font-size: 0.82rem; color: var(--text-dim); }
#active-layer-info strong { color: var(--text); }

/* Map */
#map { flex: 1; height: 100%; }

/* Modal */
#modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
}
#modal-overlay.hidden { display: none; }
#modal {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  min-width: 320px;
  box-shadow: var(--shadow);
}
#modal-content { margin-bottom: 16px; font-size: 0.9rem; }
#modal-content label { display: block; margin-bottom: 4px; color: var(--text-dim); font-size: 0.8rem; }
#modal-actions { display: flex; justify-content: flex-end; gap: 8px; }
#modal-cancel { background: var(--bg); color: var(--text); border: 1px solid var(--border); }
#modal-cancel:hover { border-color: var(--accent); }

/* Toast */
#toast {
  position: fixed;
  bottom: 20px; left: 50%;
  transform: translateX(-50%);
  background: var(--bg3);
  color: var(--text);
  padding: 8px 18px;
  border-radius: 20px;
  font-size: 0.85rem;
  box-shadow: var(--shadow);
  z-index: 200;
  transition: opacity 0.3s;
}
#toast.hidden { display: none; }
#toast.error { background: var(--accent2); }

/* Documents */
#doc-feature-label { font-size: 0.75rem; color: var(--text-dim); margin-bottom: 6px; }
#doc-feature-id { color: var(--accent); font-family: monospace; }
#doc-list { display: flex; flex-direction: column; gap: 3px; max-height: 200px; overflow-y: auto; margin-bottom: 8px; }
.doc-loading, .doc-empty { font-size: 0.78rem; color: var(--text-dim); padding: 4px 0; }
.doc-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.doc-icon { font-size: 1rem; flex-shrink: 0; }
.doc-info { flex: 1; min-width: 0; }
.doc-name { display: block; font-size: 0.8rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-meta { font-size: 0.7rem; color: var(--text-dim); }
.doc-dl-btn, .doc-del-btn {
  background: none; border: none; padding: 2px 5px; font-size: 0.8rem; flex-shrink: 0;
}
.doc-dl-btn { color: var(--accent); }
.doc-dl-btn:hover { color: #fff; }
.doc-del-btn { color: var(--accent2); opacity: 0; }
.doc-item:hover .doc-del-btn { opacity: 1; }
#btn-doc-upload {
  width: 100%; background: var(--bg3); color: var(--text);
  border: 1px solid var(--border); padding: 6px;
}
#btn-doc-upload:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

/* Address / postal codes */
#addr-tools { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }
#addr-mode-status { font-size: 0.75rem; color: var(--accent); min-height: 16px; margin-bottom: 6px; }

#postal-code-list { display: flex; flex-direction: column; gap: 3px; max-height: 200px; overflow-y: auto; }
.pc-empty { font-size: 0.78rem; color: var(--text-dim); padding: 4px 0; }
.pc-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.82rem;
}
.pc-code { font-weight: 600; color: var(--accent); min-width: 48px; }
.pc-label { flex: 1; color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.78rem; }
.pc-del-btn {
  background: none; border: none; color: var(--accent2);
  padding: 1px 4px; font-size: 0.75rem; opacity: 0;
}
.pc-item:hover .pc-del-btn { opacity: 1; }

.lookup-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.lookup-table th { text-align: left; padding: 4px 8px; color: var(--text-dim); font-size: 0.75rem; border-bottom: 1px solid var(--border); }
.lookup-table td { padding: 6px 8px; border-bottom: 1px solid var(--border); }

/* Topnav user button */
.topnav-user-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 0.8rem;
  border-radius: var(--radius);
  cursor: pointer;
}
.topnav-user-btn:hover { border-color: var(--accent); color: var(--accent); }

/* Profile overlay */
#profile-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.65);
  display: flex; align-items: center; justify-content: center;
  z-index: 90;
}
#profile-overlay.hidden { display: none !important; }
#profile-panel {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: min(900px, 95vw);
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow);
  overflow: hidden;
}
#profile-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  background: var(--bg3);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
#profile-title { display: flex; align-items: center; gap: 12px; }
#profile-avatar { font-size: 2rem; }
#profile-title h2 { font-size: 1rem; font-weight: 600; margin: 0; }
.profile-role { font-size: 0.75rem; color: var(--text-dim); }
#btn-profile-close {
  background: none; border: 1px solid var(--border);
  color: var(--text-dim); padding: 4px 9px; border-radius: var(--radius);
}
#btn-profile-close:hover { border-color: var(--accent2); color: var(--accent2); }

/* Log section */
#profile-log-section { display: flex; flex-direction: column; flex: 1; overflow: hidden; padding: 16px 20px; gap: 12px; }
#log-toolbar { display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
#log-toolbar h3 { font-size: 0.85rem; font-weight: 600; color: var(--text); }
#log-filters { display: flex; gap: 8px; }
#log-filters select { width: auto; margin-bottom: 0; font-size: 0.8rem; padding: 4px 8px; }

#log-table-wrapper { flex: 1; overflow-y: auto; border: 1px solid var(--border); border-radius: var(--radius); }
#log-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
#log-table th {
  position: sticky; top: 0;
  background: var(--bg3); padding: 8px 10px;
  text-align: left; font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-dim);
  border-bottom: 1px solid var(--border);
}
#log-table td { padding: 7px 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
#log-table tr:last-child td { border-bottom: none; }
#log-table tr:hover td { background: var(--bg3); }

.log-cell-time { white-space: nowrap; color: var(--text-dim); font-size: 0.76rem; }
.log-cell-type { white-space: nowrap; }
.log-cell-name { max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.log-cell-detail { color: var(--text-dim); font-size: 0.76rem; }

.log-action {
  display: inline-block; padding: 2px 7px;
  border-radius: 10px; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em;
}
.log-action-create { background: rgba(51,200,100,0.15); color: #33c864; }
.log-action-update { background: rgba(51,136,255,0.15); color: var(--accent); }
.log-action-delete { background: rgba(233,69,96,0.15); color: var(--accent2); }
.log-action-upload { background: rgba(180,120,255,0.15); color: #b478ff; }

.log-loading, .log-error, .log-empty { padding: 20px; text-align: center; color: var(--text-dim); font-size: 0.85rem; }
.log-error { color: var(--accent2); }
.dim { color: var(--text-dim); }

#log-pagination {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  flex-shrink: 0; padding-top: 4px;
}
#log-pagination button {
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text); padding: 4px 12px; font-size: 0.8rem;
}
#log-pagination button:disabled { opacity: 0.35; cursor: default; }
#log-pagination button:not(:disabled):hover { border-color: var(--accent); }
#log-page-info { font-size: 0.78rem; color: var(--text-dim); }

/* Login screen */
#login-screen {
  position: fixed; inset: 0;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
}
#login-screen.hidden { display: none !important; }

#login-box {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 36px 32px;
  width: 320px;
  box-shadow: var(--shadow);
  display: flex; flex-direction: column; gap: 8px;
}
#login-box h1 { font-size: 1.1rem; color: var(--accent); margin-bottom: 2px; }
#login-box p { font-size: 0.82rem; color: var(--text-dim); margin-bottom: 12px; }
#login-form { display: flex; flex-direction: column; gap: 6px; }
#login-form label { font-size: 0.78rem; color: var(--text-dim); margin-top: 4px; }
#login-form input { margin-bottom: 0; }
#login-form button { margin-top: 10px; padding: 9px; font-size: 0.9rem; }
#login-error {
  color: var(--accent2);
  font-size: 0.8rem;
  padding: 6px 8px;
  background: rgba(233,69,96,0.12);
  border-radius: var(--radius);
  border: 1px solid rgba(233,69,96,0.3);
}

/* ── User management overlay ──────────────────────────────────────────────── */
.overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center;
}
.overlay-panel {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  width: min(900px, 95vw);
  max-height: 85vh;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.overlay-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
}
.overlay-header h2 { font-size: 0.95rem; font-weight: 600; }
.btn-close {
  background: none; border: none; color: var(--text-dim);
  font-size: 1.3rem; cursor: pointer; padding: 0 4px; line-height: 1;
}
.btn-close:hover { color: var(--accent2); }

.users-layout {
  display: grid; grid-template-columns: 260px 1fr;
  flex: 1; overflow: hidden;
}
.users-list-col {
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.users-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.users-toolbar h3 { font-size: 0.8rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.06em; }
#users-list { flex: 1; overflow-y: auto; padding: 8px 0; }

.user-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px; gap: 8px;
  border-bottom: 1px solid var(--border);
  font-size: 0.85rem;
}
.user-row-info { display: flex; align-items: center; gap: 6px; flex: 1; min-width: 0; }
.user-name { font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.badge-super {
  display: inline-block; padding: 1px 6px; border-radius: 8px;
  background: rgba(100,180,255,0.15); color: #64b4ff;
  font-size: 0.7rem; white-space: nowrap;
}
.user-row-actions { display: flex; gap: 5px; flex-shrink: 0; }
.btn-sm {
  padding: 3px 9px; font-size: 0.75rem;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--bg2); color: var(--text); cursor: pointer;
}
.btn-sm:hover { border-color: var(--accent); color: var(--accent); }
.btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-primary:hover { background: var(--accent2); border-color: var(--accent2); color: #fff; }
.btn-danger { border-color: var(--accent2); color: var(--accent2); }
.btn-danger:hover { background: var(--accent2); color: #fff; }
.btn-access { border-color: var(--accent); color: var(--accent); }
.btn-invite { border-color: #16a34a; color: #16a34a; }
.btn-invite:hover { background: #16a34a; color: #fff; }

.users-access-col {
  padding: 16px 20px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 10px;
}
.users-access-col h3 { font-size: 0.9rem; font-weight: 600; }
.access-hint { font-size: 0.8rem; color: var(--text-dim); }
.access-section-label {
  display: block; font-size: 0.75rem; font-weight: 600;
  color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.05em;
  margin-top: 4px;
}
.access-check-list {
  display: flex; flex-direction: column; gap: 5px;
  max-height: 160px; overflow-y: auto;
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 8px 10px; background: var(--bg);
}
.access-check-item {
  display: flex; align-items: center; gap: 7px;
  font-size: 0.83rem; cursor: pointer;
}
.access-check-item input[type="checkbox"] { width: auto; margin-bottom: 0; }
.muni-country-hint { font-size: 0.75rem; color: var(--text-dim); }
.access-actions { display: flex; gap: 8px; margin-top: 8px; }

.loading-row, .empty-row, .error-row {
  padding: 12px 14px; font-size: 0.82rem; color: var(--text-dim); text-align: center;
}
.error-row { color: var(--accent2); }

.checkbox-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.85rem; color: var(--text); cursor: pointer;
}
.checkbox-label input[type="checkbox"] { width: auto; margin-bottom: 0; }

/* Utility */
.hidden { display: none !important; }
