/* CloudVisual 360 — admin pages (login, dashboard, project, editor) */

/* ---- Login ---- */
.auth-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(1200px 600px at 50% -10%, var(--auth-glow) 0%, var(--bg) 60%);
}
.auth-card {
  width: min(380px, 92vw); background: var(--panel);
  border: 1px solid var(--border); border-radius: 14px;
  padding: 32px; box-shadow: var(--shadow);
}
.auth-card .logo { height: 36px; margin: 0 auto 10px; display: block; }
.auth-card h1 { text-align: center; margin-bottom: 2px; }
.auth-card .sub { text-align: center; margin-bottom: 22px; }
.auth-error {
  background: #fdecea; border: 1px solid var(--danger); color: #90261f;
  border-radius: 8px; padding: 8px 12px; font-size: 13px; margin-bottom: 14px;
}
html[data-theme="dark"] .auth-error { background: #3a1d1b; color: #ffd9d6; }
.auth-error.ok { background: #e7f6ec; border-color: var(--ok); color: #1d6b38; }
html[data-theme="dark"] .auth-error.ok { background: #16301e; color: #b8e8c5; }
.auth-links { display: flex; justify-content: space-between; margin-top: 14px; font-size: 13px; }

/* ---- Dashboard ---- */
.dash-wrap { max-width: 1280px; margin: 0 auto; padding: 22px 20px 60px; }
.dash-controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 20px; }
.dash-controls .search { flex: 1; min-width: 220px; }
.filter-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-chips .btn[aria-pressed="true"] { background: var(--accent-dark); border-color: var(--accent-dark); color: #fff; }

.project-grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
}
.project-card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  display: flex; flex-direction: column; transition: border-color .15s;
}
.project-card:hover { border-color: var(--btn-hover-border); }
.project-card .cover {
  aspect-ratio: 2 / 1; background: var(--panel-2) center/cover no-repeat;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 13px; cursor: pointer;
}
.project-card .body { padding: 12px 14px 14px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.project-card .name { font-weight: 600; font-size: 16px; }
.project-card .meta { font-size: 12.5px; color: var(--muted); display: flex; flex-wrap: wrap; gap: 4px 12px; }
.project-card .actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

.empty-state { text-align: center; color: var(--muted); padding: 70px 20px; }

/* ---- Project editor page ---- */
.proj-wrap { max-width: 1280px; margin: 0 auto; padding: 22px 20px 80px; }
.proj-cols { display: grid; grid-template-columns: minmax(320px, 5fr) minmax(380px, 7fr); gap: 20px; align-items: start; }
@media (max-width: 980px) { .proj-cols { grid-template-columns: 1fr; } }

.dropzone {
  border: 2px dashed var(--border); border-radius: var(--radius);
  padding: 26px; text-align: center; color: var(--muted);
  cursor: pointer; transition: border-color .15s, background .15s;
}
.dropzone.drag { border-color: var(--accent); background: rgba(56, 168, 232, .08); }

.pano-row {
  display: flex; gap: 12px; align-items: center;
  background: var(--panel-2); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px; margin-bottom: 8px;
}
.pano-row .thumb {
  width: 96px; height: 48px; border-radius: 6px; flex-shrink: 0;
  background: #000 center/cover no-repeat;
}
.pano-row .info { flex: 1; min-width: 0; }
.pano-row .info input { margin-bottom: 4px; }
.pano-row .meta { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pano-row .tags { display: flex; gap: 4px; }
.pano-row .tag {
  font-size: 10.5px; padding: 1px 7px; border-radius: 99px;
  border: 1px solid var(--border); color: var(--muted);
}
.pano-row .tag.on { color: #1d7c40; border-color: #a9d8b8; }
html[data-theme="dark"] .pano-row .tag.on { color: #7ee2a0; border-color: #2b5b3c; }
.pano-row .btns { display: flex; flex-direction: column; gap: 4px; }
.pano-row .btns .iconbtn {
  background: none; border: 1px solid var(--border); color: var(--muted);
  border-radius: 6px; width: 26px; height: 22px; cursor: pointer; font-size: 12px; line-height: 1;
}
.pano-row .btns .iconbtn:hover { color: var(--text); border-color: var(--accent); }

.upload-item { margin-bottom: 10px; }
.upload-item .name { font-size: 13px; margin-bottom: 4px; display: flex; justify-content: space-between; }

.export-code {
  background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px;
  padding: 10px; white-space: pre; overflow-x: auto; margin: 6px 0 10px;
  max-height: 150px; overflow-y: auto;
}
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 10px; }
.stat { background: var(--panel-2); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; }
.stat .v { font-size: 20px; font-weight: 700; }
.stat .k { font-size: 12px; color: var(--muted); }

/* ---- 360 editor page ---- */
.editor-layout {
  display: grid; grid-template-rows: auto 1fr;
  grid-template-columns: 1fr 340px;
  height: 100vh; height: 100dvh;
}
.editor-topbar { grid-column: 1 / -1; }
.editor-stage { position: relative; overflow: hidden; background: #000; }
.editor-panel {
  background: var(--panel); border-left: 1px solid var(--border);
  overflow-y: auto; padding: 14px;
}
@media (max-width: 900px) {
  .editor-layout { grid-template-columns: 1fr; grid-template-rows: auto 55vh 1fr; }
  .editor-panel { border-left: none; border-top: 1px solid var(--border); }
}
.editor-tabs { display: flex; gap: 6px; margin-bottom: 14px; flex-wrap: wrap; }
.editor-tabs .btn[aria-pressed="true"] { background: var(--accent-dark); border-color: var(--accent-dark); color: #fff; }

.hotspot-list-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px; border: 1px solid var(--border); border-radius: 8px;
  margin-bottom: 6px; cursor: pointer; background: var(--panel-2);
}
.hotspot-list-item:hover, .hotspot-list-item.selected { border-color: var(--accent); }
.hotspot-list-item img { width: 28px; height: 28px; object-fit: contain; }
.hotspot-list-item .t { flex: 1; min-width: 0; }
.hotspot-list-item .t .l { font-size: 13.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hotspot-list-item .t .y { font-size: 11.5px; color: var(--muted); }

.icon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(52px, 1fr)); gap: 8px; margin: 8px 0; }
.icon-grid .icon-opt {
  aspect-ratio: 1; border: 1px solid var(--border); border-radius: 8px;
  background: var(--panel-2) center/60% no-repeat; cursor: pointer; position: relative;
}
.icon-grid .icon-opt:hover { border-color: var(--btn-hover-border); }
.icon-grid .icon-opt.selected { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(56,168,232,.3); }
.icon-grid .icon-opt .del {
  position: absolute; top: -6px; right: -6px; width: 18px; height: 18px;
  border-radius: 50%; background: var(--danger); color: #fff; border: none;
  font-size: 11px; line-height: 1; cursor: pointer; display: none;
}
.icon-grid .icon-opt:hover .del { display: block; }

.adjust-row { display: grid; grid-template-columns: 86px 1fr 44px; gap: 8px; align-items: center; margin-bottom: 8px; font-size: 13px; }
.adjust-row .val { text-align: right; color: var(--muted); font-variant-numeric: tabular-nums; }

.save-indicator { font-size: 13px; color: var(--muted); }
.save-indicator.saving { color: var(--warn); }
.save-indicator.saved { color: var(--ok); }

/* ---- GPS link suggestions (editor Links tab) ---- */
.suggest-item {
  display: flex; gap: 10px; align-items: center;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 8px;
  padding: 8px; margin-bottom: 6px;
}
.suggest-item .thumb {
  width: 64px; height: 32px; border-radius: 5px; flex-shrink: 0;
  background: #000 center/cover no-repeat;
}
.suggest-item .t { flex: 1; min-width: 0; }
.suggest-item .t .l { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.suggest-item .t .y { font-size: 11.5px; color: var(--muted); }
.suggest-item .b { display: flex; flex-direction: column; gap: 4px; }
.suggest-item.linked { opacity: .55; }
.north-status {
  font-size: 12.5px; padding: 7px 10px; border-radius: 8px; margin: 8px 0;
  background: var(--panel-2); border: 1px solid var(--border); color: var(--muted);
}
.north-status.ok { color: #1d7c40; border-color: #a9d8b8; }
html[data-theme="dark"] .north-status.ok { color: #7ee2a0; border-color: #2b5b3c; }

/* ---- Blur masks (editor Blur tab) ---- */
.mask-list-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 9px; border: 1px solid var(--border); border-radius: 8px;
  margin-bottom: 6px; cursor: pointer; background: var(--panel-2); font-size: 13px;
}
.mask-list-item:hover, .mask-list-item.selected { border-color: var(--accent); }
.mask-list-item .y { margin-left: auto; font-size: 11.5px; color: var(--muted); }

/* ---- Analytics chart (project page) ---- */
.chart30 { margin: 12px 0 4px; }
.chart30 svg { width: 100%; height: 110px; display: block; }
.chart30 .bar { fill: var(--accent); opacity: .75; }
.chart30 .bar:hover { opacity: 1; }
.chart30 .axis { font-size: 9px; fill: var(--muted); }
.alists { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; margin-top: 12px; }
.alist h4 { font-size: 12.5px; color: var(--muted); margin: 0 0 6px; font-weight: 600; }
.alist .li { display: flex; justify-content: space-between; gap: 8px; font-size: 12.5px; padding: 3px 0; border-bottom: 1px solid var(--border); }
.alist .li span:first-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.alist .li span:last-child { color: var(--muted); font-variant-numeric: tabular-nums; }

/* ---- Boundary tool (editor) ---- */
.swatches { display: flex; gap: 6px; margin: 6px 0; }
.swatches .sw {
  width: 26px; height: 26px; border-radius: 50%;
  border: 2px solid var(--border); cursor: pointer; padding: 0;
}
.swatches .sw.selected { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(56, 168, 232, .35); }
.boundary-list-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 9px; border: 1px solid var(--border); border-radius: 8px;
  margin-bottom: 6px; cursor: pointer; background: var(--panel-2); font-size: 13px;
}
.boundary-list-item:hover, .boundary-list-item.selected { border-color: var(--accent); }
.boundary-list-item .dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; border: 1px solid rgba(0,0,0,.25); }
.boundary-list-item .y { margin-left: auto; font-size: 11.5px; color: var(--muted); }

/* ---- Asset folders (icon picker) ---- */
.folder-chips { display: flex; gap: 5px; flex-wrap: wrap; margin: 8px 0 2px; }
.folder-chips .fchip {
  font-size: 11.5px; padding: 2px 10px; border-radius: 99px; cursor: pointer;
  border: 1px solid var(--border); color: var(--muted); background: none;
}
.folder-chips .fchip[aria-pressed="true"] { color: #fff; background: var(--accent-dark); border-color: var(--accent-dark); }
.icon-grid .icon-opt .mv {
  position: absolute; bottom: -6px; right: -6px; width: 18px; height: 18px;
  border-radius: 50%; background: var(--panel); color: var(--muted); border: 1px solid var(--border);
  font-size: 10px; line-height: 1; cursor: pointer; display: none;
}
.icon-grid .icon-opt:hover .mv { display: block; }
