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: minmax(0,1fr) 360px;gap:16px;align-items:start}
.layout.panelCollapsed{grid-template-columns: minmax(0,1fr) 56px;}
.viewerPane{min-width:0}
.sidePane{position:sticky;top:12px;align-self:start;max-height:calc(100vh - 40px);overflow:auto;padding-right:4px}
.sidePane.collapsed{width:56px;overflow:hidden;}
.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:flex-start;border:1px solid #e3e3e3;border-radius:14px;padding:10px;background:#fff;cursor:pointer}
.mediaThumb:hover{background:#fafafa}
.mediaThumb img{width:112px;height:84px;object-fit:contain;border-radius:12px;border:1px solid #eee;background:#f6f6f6;display:block;flex:0 0 auto}
.mediaMeta{display:flex;flex-direction:column;gap:2px;min-width:0}
.mediaMeta .cap{font-size:13px;line-height:1.25;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.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); }

/* Rail de pestañas cuando el panel está colapsado */
.railTabs{display:none;flex-direction:column;gap:10px;padding:10px;align-items:center}
.railBtn{
  width:38px;height:38px;border-radius:12px;
  border:1px solid #eee;background:#fafafa;
  cursor:pointer;font-weight:800;font-size:13px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.railBtn.active{background:#111;color:#fff;border-color:#111}
.sidePane.collapsed .railTabs{display:flex;}

.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: flex;
  align-items: center;
  justify-content: center;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  font-weight: 700;
  font-size: 13px;
  line-height: 1;
  text-align: center;
  user-select: none;
  transform: translateZ(0);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.hotspot .hsNum{ display:flex; align-items:center; justify-content:center; width:100%; height:100%; transform:none; }

.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;
  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:contain;
  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:flex;
  align-items:center;
  justify-content:center;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  padding-top: 1px; /* compensa baseline en algunas fuentes */
  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;
  pointer-events:none;
  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:12px;transform:translateX(-50%);background:rgba(20,20,20,.92);color:#fff;padding:8px 12px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.25);font-size:12.5px;line-height:1.25;max-width:min(92vw,520px);text-align:center;white-space:normal;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)}


/* v7.4 cache-fix */
.verTag{font-size:12px;padding:4px 8px;border-radius:999px;background:rgba(0,0,0,.06);vertical-align:middle;margin-left:8px}

.hotspot[data-kind="formal"]{ border-color: rgba(148,163,184,.95); }

.badge[data-kind="formal"]{ border-color: rgba(148,163,184,.95); background: rgba(148,163,184,.14); }


/* --- Dock inferior por método (tipo Mirador + acordeón/carrusel) --- */
.methodDock{
  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: 12px 10px 10px;
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
}

.dockToggle{
  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;
  display:flex;
  align-items:center;
  justify-content:center;
}
.methodDock.isCollapsed .methodAccordion{ display:none; }
.methodDock.isCollapsed .dockToggle svg{ transform: rotate(180deg); }

/* Selector de método (tabs/chips) + carrusel: sin recorte */
.dockTabs{
  display:flex;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  padding: 2px 4px 8px;
  scroll-snap-type:x mandatory;
}
.dockTabs::-webkit-scrollbar{ height:10px; }
.dockTabs::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.25); border-radius: 999px; }

.mTab{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.16);
  color: rgba(255,255,255,.92);
  cursor:pointer;
  font-size: 12.5px;
  font-weight: 700;
  scroll-snap-align:start;
}
.mTab[data-empty="1"]{ opacity:.42; }
.mTab:hover{ background: rgba(0,0,0,.22); }
.mTab.active{
  background: rgba(255,255,255,.92);
  color: rgba(10,10,12,.95);
  border-color: rgba(255,255,255,.85);
}
.mTab .mDot{ background: var(--mcolor, rgba(255,255,255,.6)); }
.mTab .mLab{ white-space:nowrap; }
.mTab .mCount{
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  font-size: 12px;
  font-weight: 800;
}
.mTab.active .mCount{
  border-color: rgba(0,0,0,.12);
  background: rgba(0,0,0,.06);
}
.dockStrip{ padding: 0 2px 0; }

.methodAccordion{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding: 2px 6px 6px;
  overflow:hidden; /* sin scroll vertical: estilo Mirador */
}

.methodGroup{
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.07);
  overflow:hidden;
}
.methodGroup[data-empty="1"]{ opacity:.65; }
.methodGroup > summary{
  list-style:none;
  cursor:pointer;
  padding: 8px 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 650;
}
.methodGroup > summary::-webkit-details-marker{ display:none; }

.mBadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.mDot{
  width:10px;height:10px;border-radius:999px;
  background: var(--mcolor, rgba(255,255,255,.6));
  box-shadow: 0 0 0 2px rgba(0,0,0,.15) inset;
}
.mCount{
  font-weight: 700;
  opacity:.9;
  font-size:12px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
}

.mStrip{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  padding: 6px 6px 8px;
  scroll-snap-type:x mandatory;
}
.mStrip::-webkit-scrollbar{ height:10px; }
.mStrip::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.25); border-radius: 999px; }

.mThumb{
  flex: 0 0 auto;
  width: 168px;
  padding: 6px;
  box-sizing: border-box;
  appearance: none;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  background: rgba(0,0,0,.15);
  cursor: pointer;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mThumb .mImg{
  width: 100%;
  height: 104px;
  border-radius: 10px;
  overflow: hidden;
  background: rgba(0,0,0,.12);
  border: 1px solid rgba(255,255,255,.12);
}
.mThumb .mImg img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  background: rgba(255,255,255,.92);
}
.mThumb.active{ outline: 2px solid rgba(255,255,255,.55); }
.mThumb .mCap{
  position: static;
  padding: 0 2px 2px;
  color: rgba(255,255,255,.92);
  font-size: 12px;
  line-height: 1.25;
  white-space: normal;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-shadow: 0 1px 10px rgba(0,0,0,.25);
}

.mEmpty{
  color: rgba(255,255,255,.86);
  font-size: 12px;
  padding: 8px 10px 10px;
  opacity:.85;
}

/* --- Extensiones: media tab (metodo + principal) --- */
.mediaGroup{ margin: 12px 0 18px; }
.mediaGroupHdr{
  display:flex;
  align-items:center;
  gap:8px;
  margin: 10px 0 8px;
  padding: 6px 8px;
  border-radius: 12px;
  background: rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.06);
}
.pillCount{
  margin-left:auto;
  font-weight:700;
  font-size:12px;
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.8);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.02);
  font-size: 12px;
}
.pill .dot{
  width:8px; height:8px; border-radius:999px;
  background: var(--pill, rgba(0,0,0,.35));
}

.badgeStar{
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(250, 204, 21, .16);
}

.mediaActions{
  margin-left:auto;
  display:flex;
  gap:8px;
  align-items:center;
}
.miniSelect{
  font-size:12px;
  padding:6px 8px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
}
.btnMini{
  padding: 6px 10px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.9);
  cursor:pointer;
  font-weight:700;
  font-size:12px;
}
.btnMini:hover{ filter: brightness(0.98); }

@media (max-width: 620px){
  .mediaThumb{flex-wrap:wrap;}
  .mediaActions{margin-left:0; width:100%; justify-content:flex-end;}
}

/* Anotaciones: texto de resumen (compat) */
.annoText{
  font-size: 13px;
  min-width:0;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


/* Robustez: evita que el mensaje vacío bloquee clicks */
#osdEmpty{ pointer-events:none; }
#osdEmpty[hidden]{ display:none !important; }

.sidePane.collapsed::-webkit-scrollbar{width:0;height:0;}


/* v9.7 fixes: scroll del panel + centrado de números */
.sidePane{position:sticky;top:12px;align-self:start;display:flex;flex-direction:column;min-height:0;max-height:calc(100dvh - 24px);overflow:hidden;}
.sideBody{flex:1;min-height:0;overflow:auto;}


/* Tooltip de hotspots */
.hsTip{
  position: fixed;
  z-index: 9999;
  max-width: min(340px, 92vw);
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(15,15,18,.92);
  color: rgba(255,255,255,.94);
  font: 600 12px/1.25 ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
  pointer-events: none;
  white-space: normal;
}
.hsTip.pinned{ opacity: 0.98; }

/* Input extra para tooltip */
.altInput{
  margin-top: 6px;
}

/* Nota extendida en lista de anotaciones */
.annoNote{
  margin: 8px 0 10px;
  color: rgba(20,20,20,.8);
  font-size: 13px;
  line-height: 1.35;
}

/* Panel con scroll interno consistente */
.sidePane{
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 16px;
  max-height: calc(100vh - 32px);
}
.sideBody{
  flex: 1;
  min-height: 0;
  overflow: auto;
}
