/* ── Variables ─────────────────────────────────────────────── */
:root {
  --bg:      #0f1117;
  --sf:      #141824;
  --sf2:     #1a2030;
  --sf3:     #202840;
  --bd:      #1e2535;
  --bd2:     #2d3748;
  --tx:      #f1f5f9;
  --tx2:     #94a3b8;
  --tx3:     #64748b;
  --ac:      #6366f1;
  --acd:     #4f46e5;
  --acl:     rgba(99,102,241,.12);
  --grn:     #22c55e;
  --grnl:    rgba(34,197,94,.12);
  --red:     #ef4444;
  --redl:    rgba(239,68,68,.12);
  --amb:     #f59e0b;
  --ambl:    rgba(245,158,11,.12);
  --r:       8px;
  --r2:      12px;
  --sh:      0 1px 3px rgba(0,0,0,.4);
  --sh2:     0 4px 16px rgba(0,0,0,.5);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);color:var(--tx);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
a{color:var(--ac);text-decoration:none}
a:hover{text-decoration:underline}
hr{border:none;border-top:1px solid var(--bd);margin:16px 0}
img{max-width:100%;display:block}

/* ── App shell ──────────────────────────────────────────────── */
.app-shell{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ────────────────────────────────────────────────── */
.sidebar{
  width:220px;flex-shrink:0;
  display:flex;flex-direction:column;
  background:var(--sf);border-right:1px solid var(--bd);
  overflow-y:auto;
}
.sidebar-logo{
  display:flex;align-items:center;gap:10px;
  padding:18px 16px 14px;border-bottom:1px solid var(--bd);
}
.sidebar-logo .brand-logo{width:132px;height:auto;display:block}

.sidebar-nav{flex:1;padding:8px 8px}
.sidebar-nav a{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:var(--r);
  color:var(--tx2);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .15s;user-select:none;
}
.sidebar-nav a:hover{background:var(--sf2);color:var(--tx);text-decoration:none}
.sidebar-nav a.active{background:var(--acl);color:var(--ac)}
.sidebar-nav a .nav-icon{width:18px;text-align:center;opacity:.8}
.sidebar-nav .nav-sep{height:1px;background:var(--bd);margin:6px 0}

.sidebar-footer{
  padding:12px 16px;border-top:1px solid var(--bd);
  display:flex;flex-direction:column;gap:8px;
}
.user-chip{
  display:flex;align-items:center;gap:8px;
}
.user-avatar{
  width:28px;height:28px;border-radius:50%;
  background:var(--ac);display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;
}
.user-info{overflow:hidden}
.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:11px;color:var(--tx3);text-transform:capitalize}

/* ── Main content ───────────────────────────────────────────── */
.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.page-header{
  padding:20px 24px 16px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--sf);
}
.page-title{font-size:18px;font-weight:700;letter-spacing:-.02em}
.page-sub{font-size:12px;color:var(--tx3);margin-top:2px}
.page-body{padding:24px;flex:1}

/* ── Login overlay ──────────────────────────────────────────── */
.login-overlay{
  position:fixed;inset:0;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;
}
.login-card{
  width:380px;padding:32px;
  background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);
  box-shadow:var(--sh2);
}
.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.login-brand .brand-logo{width:156px;height:auto;display:block}
.login-title{font-size:20px;font-weight:700;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--tx3);margin-bottom:24px}
.login-error{
  background:var(--redl);border:1px solid var(--red);border-radius:var(--r);
  padding:10px 12px;font-size:13px;color:#fca5a5;margin-bottom:16px;
}

/* ── Cards ──────────────────────────────────────────────────── */
.card{
  background:var(--sf);border:1px solid var(--bd);
  border-radius:var(--r2);padding:20px;
}
.card+.card{margin-top:16px}
.card-title{font-size:15px;font-weight:600;margin-bottom:12px}
.card-subtitle{font-size:12px;color:var(--tx3);margin-bottom:16px;margin-top:-8px}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.stat-card{
  background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);
  padding:16px;
}
.stat-label{font-size:11px;color:var(--tx3);font-weight:500;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.stat-value{font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1}
.stat-hint{font-size:11px;color:var(--tx3);margin-top:4px}

/* ── Grid utils ─────────────────────────────────────────────── */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}}

/* ── Tables ─────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--bd)}
table{width:100%;border-collapse:collapse}
thead tr{background:var(--sf2)}
thead th{
  padding:10px 14px;text-align:left;
  font-size:11px;font-weight:600;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.06em;
  border-bottom:1px solid var(--bd);white-space:nowrap;
}
tbody tr{border-bottom:1px solid var(--bd);transition:background .1s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--sf2)}
tbody td{padding:10px 14px;font-size:13px;vertical-align:middle}
.td-mono{font-family:'SF Mono','Fira Code',monospace;font-size:12px}
.td-actions{display:flex;gap:6px;justify-content:flex-end}
.empty-row td{text-align:center;color:var(--tx3);padding:32px;font-size:13px}

/* ── Forms ──────────────────────────────────────────────────── */
.form-group{margin-bottom:14px}
.form-group:last-child{margin-bottom:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row.cols3{grid-template-columns:1fr 1fr 1fr}
label{display:block;font-size:12px;font-weight:600;color:var(--tx2);margin-bottom:5px}
label .req{color:var(--red);margin-left:2px}
input[type=text],input[type=email],input[type=password],input[type=number],
input[type=url],textarea,select{
  width:100%;padding:8px 10px;
  background:var(--sf2);border:1px solid var(--bd2);border-radius:var(--r);
  color:var(--tx);font-size:13px;font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
  outline:none;appearance:none;
}
input:focus,textarea:focus,select:focus{
  border-color:var(--ac);
  box-shadow:0 0 0 3px rgba(99,102,241,.15);
}
input::placeholder,textarea::placeholder{color:var(--tx3)}
textarea{resize:vertical;min-height:72px}
select option{background:var(--sf)}
.form-hint{font-size:11px;color:var(--tx3);margin-top:4px}
.input-group{display:flex;gap:8px}
.input-group input{flex:1}
.checkbox-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer}
.checkbox-row input[type=checkbox]{
  width:16px;height:16px;accent-color:var(--ac);
  border-radius:4px;cursor:pointer;flex-shrink:0;
}
.checkbox-label{font-size:13px;color:var(--tx2);cursor:pointer;user-select:none}

/* ── Buttons ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 14px;border-radius:var(--r);
  font-size:13px;font-weight:600;font-family:inherit;
  border:none;cursor:pointer;transition:all .15s;
  white-space:nowrap;text-decoration:none;user-select:none;
}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--ac);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--acd)}
.btn-secondary{background:var(--sf2);color:var(--tx2);border:1px solid var(--bd2)}
.btn-secondary:hover:not(:disabled){background:var(--sf3);color:var(--tx)}
.btn-danger{background:var(--redl);color:#fca5a5;border:1px solid var(--red)}
.btn-danger:hover:not(:disabled){background:var(--red);color:#fff}
.btn-ghost{background:transparent;color:var(--tx2);padding:6px 8px}
.btn-ghost:hover{background:var(--sf2);color:var(--tx)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-icon{padding:6px;width:30px;height:30px;border-radius:6px}
.btn-group{display:flex;gap:8px}

/* ── Badges ─────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;
  padding:2px 8px;border-radius:20px;
  font-size:11px;font-weight:600;letter-spacing:.02em;
}
.badge-default{background:var(--sf2);color:var(--tx2);border:1px solid var(--bd)}
.badge-accent{background:var(--acl);color:#a5b4fc}
.badge-green{background:var(--grnl);color:#86efac}
.badge-red{background:var(--redl);color:#fca5a5}
.badge-amber{background:var(--ambl);color:#fcd34d}

/* ── Tabs ───────────────────────────────────────────────────── */
.tabs{
  display:flex;gap:2px;border-bottom:1px solid var(--bd);
  margin-bottom:20px;padding-bottom:0;
}
.tab-item{
  padding:8px 14px;font-size:13px;font-weight:500;color:var(--tx2);
  cursor:pointer;border-bottom:2px solid transparent;
  margin-bottom:-1px;transition:all .15s;user-select:none;
}
.tab-item:hover{color:var(--tx)}
.tab-item.active{color:var(--ac);border-bottom-color:var(--ac)}

/* ── Modal ──────────────────────────────────────────────────── */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;
  z-index:800;padding:20px;backdrop-filter:blur(2px);
}
.modal-box{
  background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);
  box-shadow:var(--sh2);width:100%;max-width:520px;
  display:flex;flex-direction:column;max-height:90vh;
}
.modal-box.modal-lg{max-width:700px}
.modal-head{
  padding:18px 20px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-head h3{font-size:16px;font-weight:700}
.modal-close{
  background:none;border:none;color:var(--tx3);
  font-size:20px;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1;
}
.modal-close:hover{background:var(--sf2);color:var(--tx)}
.modal-body{padding:20px;overflow-y:auto}
.modal-foot{
  padding:14px 20px;border-top:1px solid var(--bd);
  display:flex;justify-content:flex-end;gap:8px;
}

/* ── Toast ──────────────────────────────────────────────────── */
.toast-rack{
  position:fixed;bottom:20px;right:20px;
  display:flex;flex-direction:column;gap:8px;
  z-index:9000;pointer-events:none;
}
.toast{
  padding:10px 14px;border-radius:var(--r);
  font-size:13px;font-weight:500;
  max-width:320px;box-shadow:var(--sh2);
  pointer-events:auto;
  animation:toastIn .2s ease;
}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.toast-info{background:#1e2535;color:var(--tx);border:1px solid var(--bd2)}
.toast-success{background:#14301e;color:#86efac;border:1px solid var(--grn)}
.toast-error{background:#2a1515;color:#fca5a5;border:1px solid var(--red)}
.toast-warn{background:#2a2000;color:#fcd34d;border:1px solid var(--amb)}

/* ── Locations layout ───────────────────────────────────────── */
.locations-shell{
  display:grid;grid-template-columns:1fr 340px;
  height:calc(100vh - 113px);overflow:hidden;
}
.map-wrap{position:relative;height:100%}
#map,#search-map{width:100%;height:100%}
.leaflet-bottom,.maplibregl-ctrl-bottom-left,.maplibregl-ctrl-bottom-right{z-index:1}
.map-fallback{
  position:absolute;inset:0;z-index:300;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:24px;text-align:center;
  background:linear-gradient(180deg,rgba(15,17,23,.82),rgba(15,17,23,.94));
  backdrop-filter:blur(4px);
}
.map-fallback-title{font-size:16px;font-weight:700;letter-spacing:-.02em}
.map-fallback-body{max-width:420px;font-size:13px;line-height:1.6;color:var(--tx2)}
/* map control panel */
.map-controls{
  position:absolute;top:10px;left:10px;z-index:400;
  display:flex;flex-direction:column;gap:4px;pointer-events:all;
}
.map-provider-select{
  background:rgba(20,24,36,.92);backdrop-filter:blur(4px);
  border:1px solid var(--bd2);color:var(--tx);
  border-radius:6px;padding:5px 6px;font-size:11px;cursor:pointer;outline:none;max-width:110px;
}
.map-ctrl-btn{
  width:32px;height:32px;border:1px solid var(--bd2);
  background:rgba(20,24,36,.92);backdrop-filter:blur(4px);
  color:var(--tx);border-radius:6px;cursor:pointer;
  font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.map-ctrl-btn:hover{background:var(--sf2)}
.map-layer-select{
  background:rgba(20,24,36,.92);backdrop-filter:blur(4px);
  border:1px solid var(--bd2);color:var(--tx);
  border-radius:6px;padding:5px 6px;font-size:11px;cursor:pointer;outline:none;max-width:110px;
}
.map-links{display:flex;flex-wrap:wrap;gap:8px}
/* click-to-add chip */
.map-click-chip{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:400;
  background:rgba(20,24,36,.95);backdrop-filter:blur(6px);
  border:1px solid var(--grn);color:var(--tx);
  border-radius:20px;padding:6px 14px;font-size:12px;
  display:flex;align-items:center;gap:8px;box-shadow:var(--sh2);white-space:nowrap;
}
.map-click-chip .chip-add{
  background:var(--grn);color:#fff;border:none;border-radius:12px;
  padding:3px 10px;font-size:12px;cursor:pointer;font-weight:500;
}
.map-click-chip .chip-close{
  background:transparent;border:none;color:var(--tx3);cursor:pointer;font-size:18px;line-height:1;padding:0;
}
/* search field value tags */
.search-fields{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.search-field-tag{
  font-size:11px;background:var(--sf2);border:1px solid var(--bd);
  border-radius:4px;padding:1px 6px;color:var(--tx2);
}
.search-field-tag b{color:var(--tx3);font-weight:500;margin-right:2px}
.poi-side-panel{
  background:var(--sf);border-left:1px solid var(--bd);
  display:flex;flex-direction:column;overflow:hidden;
}
.poi-panel-head{
  padding:12px 14px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
}
.poi-panel-head h4{font-size:14px;font-weight:600}
.poi-panel-list{flex:1;overflow-y:auto}
.poi-list-item{
  padding:10px 14px;border-bottom:1px solid var(--bd);
  cursor:pointer;transition:background .1s;
}
.poi-list-item:hover{background:var(--sf2)}
.poi-list-item.active{background:var(--acl)}
.poi-list-title{font-size:13px;font-weight:500}
.poi-list-meta{font-size:11px;color:var(--tx3);margin-top:2px}
.poi-panel-form{flex:1;overflow-y:auto;padding:14px}
.poi-panel-empty{
  flex:1;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;color:var(--tx3);font-size:13px;padding:20px;text-align:center;
}
.poi-panel-pagination{
  padding:10px 14px;border-top:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
}
.poi-panel-pagination span{font-size:12px;color:var(--tx3)}

/* ── Map markers ────────────────────────────────────────────── */
.map-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--ac);border:2px solid rgba(255,255,255,.5);
  box-shadow:0 2px 6px rgba(0,0,0,.4);
  cursor:pointer;transition:transform .15s,border-color .15s;
}
.map-dot:hover,.map-dot.active{transform:scale(1.6);border-color:#fff}

/* ── Inline search bar ──────────────────────────────────────── */
.search-bar{
  display:flex;gap:8px;align-items:center;
  background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);
  padding:6px 12px;
}
.search-bar input{
  flex:1;border:none;background:transparent;color:var(--tx);
  font-size:14px;outline:none;padding:4px 0;
}
.search-bar input::placeholder{color:var(--tx3)}

/* ── Filter row ─────────────────────────────────────────────── */
.filter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.filter-row select,.filter-row input{max-width:180px}

/* ── Pagination bar ─────────────────────────────────────────── */
.pagination{
  display:flex;align-items:center;gap:8px;
  padding:12px 0;font-size:12px;color:var(--tx3);
}

/* ── Dividers / section ─────────────────────────────────────── */
.section-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
}
.section-title{font-size:15px;font-weight:600}

/* ── Field list (dataset fields) ────────────────────────────── */
.field-pill{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;border-radius:var(--r);
  background:var(--sf2);border:1px solid var(--bd);margin-bottom:6px;
}
.field-pill-info{display:flex;align-items:center;gap:8px}
.field-pill-code{font-family:'SF Mono','Fira Code',monospace;font-size:12px;color:var(--tx2)}
.field-pill-name{font-size:13px;font-weight:500}
.field-pill-type{font-size:11px;color:var(--tx3)}

/* ── Dataset item ───────────────────────────────────────────── */
.ds-card{
  background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);
  margin-bottom:10px;overflow:hidden;
}
.ds-card-head{
  padding:12px 14px;display:flex;align-items:center;
  justify-content:space-between;cursor:pointer;
  transition:background .1s;
}
.ds-card-head:hover{background:var(--sf2)}
.ds-card-head.open{background:var(--sf2);border-bottom:1px solid var(--bd)}
.ds-card-title{font-size:14px;font-weight:600}
.ds-card-meta{font-size:11px;color:var(--tx3);margin-top:2px}
.ds-card-body{padding:12px 14px}

/* ── Loading spinner ────────────────────────────────────────── */
.spinner{
  width:24px;height:24px;border-radius:50%;
  border:2px solid var(--bd2);border-top-color:var(--ac);
  animation:spin .6s linear infinite;display:inline-block;
}
.spinner-sm{width:16px;height:16px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-block{
  display:flex;align-items:center;justify-content:center;
  padding:40px;flex-direction:column;gap:12px;color:var(--tx3);font-size:13px;
}
.empty-block{
  display:flex;align-items:center;justify-content:center;
  padding:40px;flex-direction:column;gap:8px;
  color:var(--tx3);font-size:13px;text-align:center;
}
.empty-block .empty-icon{font-size:32px;opacity:.4;margin-bottom:4px}

/* ── Org settings form ──────────────────────────────────────── */
.key-display{
  font-family:'SF Mono','Fira Code',monospace;font-size:12px;
  background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);
  padding:8px 10px;color:var(--tx2);word-break:break-all;
}

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}


.shot-img {
  width:100%;
  height:auto;
  
}