body { font-family: system-ui, Arial; margin: 0; }
.wrap { max-width: 1100px; margin: 24px auto; padding: 0 16px; }
.row { display: grid; grid-template-columns: 2fr 1fr; gap: 16px; align-items: start; }
.imgBox { position: relative; border: 1px solid #ddd; border-radius: 10px; overflow: hidden; }
.imgBox img { width: 100%; display: block; }
.dots { position: absolute; inset: 0; pointer-events: none; }
.dot { position: absolute; width: 14px; height: 14px; border-radius: 50%;
  transform: translate(-50%,-50%); border: 2px solid #000; background: #fff; }
.dot-iconografia { background: #fff; }
.dot-materialidad { background: #fff; }
.dot-conservacion { background: #fff; }
.dot-fuente { background: #fff; }
.dot-contexto { background: #fff; }
.dot-preview { border-style: dashed; }

.controls { margin-top: 10px; display: grid; gap: 8px; }
textarea { width: 100%; min-height: 90px; }
button { padding: 10px 12px; cursor: pointer; }
.side .card { border: 1px solid #ddd; border-radius: 10px; padding: 10px; margin-bottom: 10px; }
.side .k { font-size: 12px; opacity: .7; margin-bottom: 6px; }
.hint { font-size: 12px; opacity: .7; }
.card { border: 1px solid #ddd; border-radius: 10px; padding: 12px; margin-bottom: 12px; }
label { display:block; margin-top: 10px; font-size: 13px; opacity: .8; }
input { width: 100%; padding: 10px; border-radius: 10px; border: 1px solid #ddd; }
.btnlink { display:inline-block; padding: 10px 12px; border:1px solid #ddd; border-radius: 999px; text-decoration:none; color: inherit; }


/* === Pro viewer layout === */
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.h1{margin:0 0 6px 0;font-size:34px;line-height:1.1}
.sub{opacity:.75;font-size:14px}
.layout{display:grid;grid-template-columns: 2.1fr 1fr;gap:16px;align-items:start}
.viewerPane{min-width:0}
.sidePane{position:sticky;top:12px;align-self:start;max-height:calc(100vh - 40px);overflow:auto;padding-right:4px}
.h3{margin:0 0 10px 0}
.divider{height:1px;background:#e7e7e7;margin:14px 0}
.osdBox{height:min(72vh,720px);border:1px solid #ddd;border-radius:14px;overflow:hidden;background:#fafafa}
.toolRow{display:flex;gap:10px;align-items:flex-end;margin-top:10px}
.field{display:flex;flex-direction:column;gap:6px;font-size:12px;opacity:.9}
.field select,.field input{padding:10px;border-radius:12px;border:1px solid #ddd;min-width:170px}
.field.grow{flex:1;min-width:0}
.btn{padding:10px 14px;border:1px solid #ddd;border-radius:999px;background:#fff;cursor:pointer}
.btn:hover{background:#f7f7f7}
.hint{font-size:12px;opacity:.7;margin-top:8px}


/* === Hotspots (OpenSeadragon overlays) === */
.osd-dot{
  width:22px;height:22px;border-radius:999px;
  box-sizing:border-box;
  display:grid;place-items:center;
  font-size:12px;font-weight:800;
  letter-spacing:-0.02em;
  color: rgba(255,255,255,.95);
  background: rgba(0,0,0,.40); /* oscuro pero deja ver detalle */
  border: 2px solid rgba(255,255,255,.55);
  box-shadow: 0 10px 20px rgba(0,0,0,.18);
  backdrop-filter: blur(2px);
  user-select:none;
  transform: translateZ(0);
  text-align:center;
}
.osd-dot:hover{background: rgba(0,0,0,.58)}
.osd-dot.preview{
  background: rgba(0,0,0,.25);
  border-style: dashed;
  opacity:.85;
}

/* Color por categoría (borde) */
.osd-dot[data-kind="iconografia"]{border-color: rgba(180, 120, 255, .95)}
.osd-dot[data-kind="materialidad"]{border-color: rgba(90, 210, 140, .95)}
.osd-dot[data-kind="conservacion"]{border-color: rgba(255, 170, 80, .95)}
.osd-dot[data-kind="fuente"]{border-color: rgba(90, 160, 255, .95)}
.osd-dot[data-kind="contexto"]{border-color: rgba(220,220,220,.9)}


/* === Collapsible annotations === */
.annoList{display:grid;gap:10px}
.annoItem{border:1px solid #e3e3e3;border-radius:14px;padding:10px;background:#fff}
.annoItem summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px}
.annoItem summary::-webkit-details-marker{display:none}
.badge{
  width:22px;height:22px;border-radius:999px;border:2px solid #111;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;
}
.badge[data-kind="iconografia"]{background:#f7e9ff}
.badge[data-kind="materialidad"]{background:#e8fff0}
.badge[data-kind="conservacion"]{background:#fff1e6}
.badge[data-kind="fuente"]{background:#e8f1ff}
.badge[data-kind="contexto"]{background:#f3f3f3}
.kTxt{font-size:12px;opacity:.75;text-transform:capitalize}
.annoBody{margin-top:10px;font-size:14px;line-height:1.35}
.annoActions{display:flex;gap:8px;margin-top:10px}
.smallBtn{font-size:12px;padding:8px 10px;border:1px solid #ddd;border-radius:999px;background:#fff;cursor:pointer}
.smallBtn:hover{background:#f7f7f7}

/* === Media list === */
.mediaList{display:grid;gap:10px}
.mediaThumb{display:flex;gap:10px;align-items:center;border:1px solid #e3e3e3;border-radius:14px;padding:10px;background:#fff;cursor:pointer}
.mediaThumb:hover{background:#fafafa}
.mediaThumb img{width:74px;height:54px;object-fit:cover;border-radius:10px;border:1px solid #eee;background:#f6f6f6}
.mediaMeta{display:flex;flex-direction:column;gap:2px;min-width:0}
.mediaMeta .cap{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mediaMeta .sub{font-size:12px;opacity:.65}
.mediaThumb.active{outline:2px solid #111}

@media (max-width: 980px){
  .layout{grid-template-columns:1fr}
  .sidePane{position:relative;max-height:none}
  .osdBox{height:min(62vh,560px)}
}

/* === Modern viewer controls === */
.osdWrap{position:relative}
.osdControls{
  position:absolute; top:12px; left:12px;
  display:flex; gap:10px;
  z-index: 50;
}
.osdBtn{
  width:40px;height:40px;border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease;
}
.osdBtn:hover{transform: translateY(-1px); background: rgba(255,255,255,.92)}
.osdBtn:active{transform: translateY(0px) scale(.98)}
.osdBtn svg{width:18px;height:18px;opacity:.9}



/* ===== Mirador-style v4 additions ===== */

.layout { display: grid; grid-template-columns: 1fr 360px; gap: 16px; align-items: start; }
.layout.sideCollapsed { grid-template-columns: 1fr 56px; }

.sidePane { border: 1px solid #e6e6e6; border-radius: 14px; background: #fff; overflow: hidden; }
.sidePane.collapsed .tabs,
.sidePane.collapsed .tabPanel { display: none; }
.sidePane.collapsed .sideHeader { justify-content: center; }
.sidePane.collapsed .sideTitle { display: none; }
.sidePane.collapsed #collapseBtn svg { transform: rotate(180deg); }

.sideHeader { display:flex; align-items:center; justify-content: space-between; padding: 10px 10px; border-bottom: 1px solid #eee; }
.sideTitle { font-weight: 650; }
.iconBtn { width: 36px; height: 36px; border-radius: 10px; border: 1px solid #eee; background: rgba(255,255,255,.9); cursor: pointer; display:grid; place-items:center; }
.iconBtn svg { width: 18px; height: 18px; }

.tabs { display:flex; gap: 6px; padding: 8px 10px; border-bottom: 1px solid #eee; }
.tabBtn { flex:1; border: 1px solid #eee; background: #fafafa; border-radius: 999px; padding: 8px 10px; cursor:pointer; font-size: 13px; }
.tabBtn.active { background: #111; color: #fff; border-color: #111; }

.tabPanel { padding: 10px; }
.tabPanel.hidden { display:none; }

.filters { display:flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.chip { border: 1px solid #e6e6e6; background: rgba(0,0,0,.04); border-radius: 999px; padding: 7px 10px; font-size: 12px; cursor:pointer; }
.chip.active { background: rgba(0,0,0,.85); color:#fff; border-color: rgba(0,0,0,.85); }

.annoList { display:flex; flex-direction: column; gap: 10px; }
.annoItem { border: 1px solid #eee; border-radius: 14px; overflow:hidden; background:#fff; }
.annoItem summary { list-style:none; cursor:pointer; display:flex; align-items:center; gap: 10px; padding: 10px 12px; }
.annoItem summary::-webkit-details-marker { display:none; }
.annoItem .annoBody { padding: 0 12px 10px 12px; color:#222; }
.annoItem .annoActions { padding: 0 12px 12px 12px; }
.annoItem.selected { outline: 2px solid rgba(0,0,0,.25); }
.hiddenByFilter { display:none; }

.smallBtn { border: 1px solid #e6e6e6; background: #fff; border-radius: 999px; padding: 8px 10px; cursor:pointer; }
.smallBtn:hover { background: rgba(0,0,0,.04); }

.meta { display:flex; flex-direction: column; gap: 10px; }
.metaRow { border: 1px solid #eee; border-radius: 14px; padding: 10px 12px; }
.metaK { font-size: 12px; opacity: .7; margin-bottom: 6px; }
.metaV { white-space: pre-wrap; }

/* Hotspots */
.hotspot {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(10, 10, 12, 0.45);
  color: rgba(255,255,255,.92);
  border: 2px solid rgba(255,255,255,.65);
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
  display: grid;
  place-items: center;
  font-weight: 750;
  font-size: 13px;
  line-height: 1;
  user-select: none;
  transform: translateZ(0);
}
.hotspot.preview { background: rgba(10,10,12,.28); border-style: dashed; }
.hotspot.muted { opacity: .15; pointer-events: none; }
.hotspot.selected { box-shadow: 0 0 0 6px rgba(0,0,0,.16), 0 10px 24px rgba(0,0,0,.22); }

.hotspot[data-kind="iconografia"] { border-color: rgba(59, 130, 246, .95); }
.hotspot[data-kind="materialidad"] { border-color: rgba(16, 185, 129, .95); }
.hotspot[data-kind="conservacion"] { border-color: rgba(245, 158, 11, .95); }
.hotspot[data-kind="fuente"] { border-color: rgba(168, 85, 247, .95); }
.hotspot[data-kind="contexto"] { border-color: rgba(244, 63, 94, .95); }

/* Badge in list */
.badge {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 12px;
  color: rgba(10,10,12,.9);
  background: rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.14);
  flex: 0 0 auto;
}
.badge[data-kind="iconografia"] { border-color: rgba(59, 130, 246, .8); }
.badge[data-kind="materialidad"] { border-color: rgba(16, 185, 129, .8); }
.badge[data-kind="conservacion"] { border-color: rgba(245, 158, 11, .8); }
.badge[data-kind="fuente"] { border-color: rgba(168, 85, 247, .8); }
.badge[data-kind="contexto"] { border-color: rgba(244, 63, 94, .8); }

@media (max-width: 980px) {
  .layout { grid-template-columns: 1fr; }
  .layout.sideCollapsed { grid-template-columns: 1fr; }
  .sidePane { position: relative; }
}


/* --- v5: búsqueda/orden + pulso --- */
.annoToolbar{
  display:flex;
  gap:10px;
  align-items:center;
  margin: 10px 0 8px;
}
.searchInput{
  flex:1;
  padding:10px 12px;
  border:1px solid #e6e6e6;
  border-radius: 12px;
  outline:none;
}
.searchInput:focus{ border-color:#cfcfcf; box-shadow: 0 0 0 4px rgba(0,0,0,.04); }
.sortSelect{
  width: 190px;
  padding:10px 12px;
  border:1px solid #e6e6e6;
  border-radius: 12px;
  background:#fff;
}

.hotspot{ box-sizing:border-box; font-variant-numeric: tabular-nums; }
.hotspot.pulse{
  animation: hotspotPulse .7s ease-out 0s 1;
}
@keyframes hotspotPulse{
  0%{ transform: scale(1); box-shadow: 0 6px 18px rgba(0,0,0,.18); }
  45%{ transform: scale(1.28); box-shadow: 0 10px 26px rgba(0,0,0,.28); }
  100%{ transform: scale(1); box-shadow: 0 6px 18px rgba(0,0,0,.18); }
}

.dateTxt{ margin-left:auto; font-size:12px; opacity:.55; }
summary{display:flex; gap:10px; align-items:center;}

/* v6.1 fixes */
.viewerControls button.isDisabled{opacity:.45; cursor:not-allowed; filter:grayscale(1);}
.emptyState{height:100%; width:100%; display:flex; align-items:center; justify-content:center; padding:24px;}
.emptyState > div{max-width:420px; text-align:center;}
.emptyTitle{font-weight:700; font-size:18px; margin-bottom:6px;}
.emptyText{opacity:.75; font-size:14px; line-height:1.3;}



/* --- Filmstrip (tira de imágenes estilo Mirador) --- */
.filmstripWrap{
  position:absolute;
  left:14px; right:14px; bottom:14px;
  background: rgba(15,15,15,.35);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 14px;
  padding: 10px 10px 8px;
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
}
.filmToggle{
  position:absolute;
  right:10px; top:-12px;
  width:36px; height:26px;
  border-radius: 10px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.85);
  cursor:pointer;
}
.filmstrip{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  padding: 2px 6px 4px;
  scroll-snap-type:x mandatory;
}
.filmstrip::-webkit-scrollbar{ height:10px; }
.filmstrip::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.25); border-radius: 999px; }
.fthumb{
  flex: 0 0 auto;
  width: 110px;
  height: 70px;
  border-radius: 12px;
  border: 2px solid rgba(255,255,255,.18);
  overflow:hidden;
  cursor:pointer;
  scroll-snap-align:start;
  background: rgba(0,0,0,.25);
  position:relative;
}
.fthumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.fthumb.active{
  border-color: rgba(255,255,255,.85);
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
}
.fthumb .fmeta{
  position:absolute;
  left:8px; bottom:6px;
  font-size:12px;
  color:#fff;
  text-shadow: 0 2px 12px rgba(0,0,0,.5);
  display:flex;
  gap:6px;
  align-items:center;
}
.fmeta .star{ opacity:.95; }

/* --- Hotspot: centrado perfecto y menos invasivo --- */
.hotspot{
  width:30px; height:30px;
  border-radius: 999px;
  background: rgba(10,10,10,.45);
  border: 2px solid rgba(255,255,255,.7);
  color: rgba(255,255,255,.95);
  display:grid;
  place-items:center;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  user-select:none;
  box-sizing: border-box;
}
.hotspot.muted{ opacity:.25; }
.hotspot.active{
  outline: 3px solid rgba(255,255,255,.25);
  box-shadow: 0 0 0 10px rgba(255,255,255,.10);
}
@keyframes pulseRing{
  0%{ box-shadow: 0 0 0 0 rgba(255,255,255,.20); }
  100%{ box-shadow: 0 0 0 16px rgba(255,255,255,0); }
}
.hotspot.pulse{ animation: pulseRing 900ms ease-out 1; }

/* --- Estado vacío del visor --- */
.osdEmpty{
  position:absolute;
  inset: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color: rgba(0,0,0,.65);
  border: 1px dashed rgba(0,0,0,.2);
  border-radius: 18px;
  background: rgba(255,255,255,.7);
  padding: 22px;
}

/* --- Upload UI en tab Imágenes --- */
.uploadBox{
  border:1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 12px;
  margin-bottom: 10px;
  background: rgba(255,255,255,.7);
}
.uploadRow{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.uploadRow input[type="text"]{ flex: 1 1 260px; }
.chk{ display:flex; gap:8px; align-items:center; font-size: 14px; color: rgba(0,0,0,.7); }


.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:rgba(20,20,20,.92);color:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.25);font-size:14px;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:9999;}
.toast.show{opacity:1;}
.osdBtn:disabled{opacity:.35;cursor:not-allowed;}


.filmToggle{display:flex;align-items:center;justify-content:center}
.filmToggle .chev{width:18px;height:18px;transition:transform .18s ease}
.filmstripWrap.isCollapsed .filmToggle .chev{transform:rotate(180deg)}
