/* ══════════════════════════════════════════════════════════════
   galeria.css  v4
══════════════════════════════════════════════════════════════ */

/* ── Accesibilidad: skip link ─────────────────────────────── */
.skip-link{
  position:fixed;top:-100%;left:16px;z-index:99999;
  padding:8px 16px;border-radius:0 0 8px 8px;
  background:var(--text,#f0f0f0);color:var(--bg,#080808);
  font-size:13px;font-weight:700;text-decoration:none;
  transition:top .15s;
}
.skip-link:focus{top:0}
/* main no debe añadir layout propio */
main#main-content{display:contents}

/* Variables que no cambian con el tema */
:root {
  --gold:     #f5c842;
  --r:        8px;
  --ease:     cubic-bezier(.4,0,.2,1);
  --dur:      .22s;
  --sb-w:     220px;
  --panel-w:  clamp(300px, 30vw, 480px);
  --topbar-h: 52px;
}

/* ── Tema oscuro (por defecto) ─────────────────────────────── */
:root, [data-theme="dark"] {
  --bg:          #080808;
  --bg2:         #111;
  --bg3:         #191919;
  --surface:     #1a1a1a;
  --border:      rgba(255,255,255,.08);
  --text:        #f0f0f0;
  --text2:       #888;
  --text3:       #444;
  --accent:      #fff;
  --topbar-bg:   rgba(8,8,8,.96);
  --overlay-bg:  rgba(8,8,8,.97);
  --sticky-bg:   rgba(8,8,8,.97);
  --search-bg:   rgba(255,255,255,.07);
  --search-border: var(--border);
  --nav-active-bg: rgba(255,255,255,.1);
  --sb-bg:       var(--bg2);
  --card-shadow: rgba(0,0,0,.4);
  /* Hover/interacción */
  --hover-bg:    rgba(255,255,255,.06);
  --hover-border: rgba(255,255,255,.25);
  --active-thumb-border: rgba(255,255,255,.7);
  --qt-save-bg:  rgba(255,255,255,.9);
  --qt-save-color: #111;
  /* Inputs */
  --input-bg:    rgba(255,255,255,.06);
  --input-border: rgba(255,255,255,.12);
  /* home-cat sobre imagen (texto sobre foto oscura) */
  --cat-count-color: rgba(255,255,255,.6);
}

/* ── Tema claro ────────────────────────────────────────────── */
[data-theme="light"] {
  --bg:          #f5f5f5;
  --bg2:         #ececec;
  --bg3:         #e4e4e4;
  --surface:     #fff;
  --border:      rgba(0,0,0,.1);
  --text:        #111;
  --text2:       #333;   /* antes #555 — sube de 6.3:1 a 12:1 sobre blanco */
  --text3:       #666;   /* antes #999 (ratio 2.1:1) → #666 (ratio 5.7:1) — WCAG AA ✓ */
  --accent:      #000;
  --topbar-bg:   rgba(245,245,245,.97);
  --overlay-bg:  rgba(245,245,245,.97);
  --sticky-bg:   rgba(245,245,245,.97);
  --search-bg:   rgba(0,0,0,.05);
  --search-border: rgba(0,0,0,.12);
  --nav-active-bg: rgba(0,0,0,.08);
  --sb-bg:       var(--bg2);
  --card-shadow: rgba(0,0,0,.12);
  /* Hover/interacción */
  --hover-bg:    rgba(0,0,0,.04);
  --hover-border: rgba(0,0,0,.2);
  --active-thumb-border: rgba(0,0,0,.5);
  --qt-save-bg:  rgba(0,0,0,.85);
  --qt-save-color: #fff;
  /* Inputs */
  --input-bg:    rgba(0,0,0,.04);
  --input-border: rgba(0,0,0,.12);
  /* home-cat sobre imagen */
  --cat-count-color: rgba(255,255,255,.6);
}
/* ── Tema claro: overrides de contraste WCAG AA ─────────────
   --text3:#999 sobre #f5f5f5 = 2.1:1 (insuficiente para texto pequeño)
   Se eleva a --text2:#555 = 6.3:1 en los elementos más críticos ──── */
[data-theme="light"] #search-input::placeholder{ color:var(--text2) }
[data-theme="light"] #stats-pill{ color:var(--text2) }
[data-theme="light"] .nav-btn{ color:var(--text2) }
[data-theme="light"] #site-footer{ border-top-color:rgba(0,0,0,.15) }
/* Footer: subir contraste de los textos inline (no podemos tocar estilos inline fácilmente,
   pero sí podemos forzar el color heredado en los hijos del footer-bar) */
[data-theme="light"] #footer-bar{ color:var(--text2) }
[data-theme="light"] #footer-bar a{ color:var(--text2) }
[data-theme="light"] #footer-bar span{ color:var(--text2) }
[data-theme="light"] #footer-bar button{ color:var(--text2) }
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  font-size:14px;line-height:1.5;-webkit-tap-highlight-color:transparent}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
img,video{display:block}
a{color:inherit;text-decoration:none}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ── TOPBAR ───────────────────────────────────────────────── */
#topbar{
  position:fixed;top:0;left:0;right:0;z-index:200;height:52px;
  display:flex;align-items:center;gap:2px;padding:0 12px;
  background:var(--topbar-bg);border-bottom:1px solid var(--border);
}
#logo{font-size:15px;font-weight:700;letter-spacing:.06em;margin-right:10px;white-space:nowrap}
.nav-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;
  font-size:12px;font-weight:500;color:var(--text2);
  transition:color var(--dur),background var(--dur);white-space:nowrap}
.nav-btn:hover{color:var(--text)}
.nav-btn.active{color:var(--text);background:var(--nav-active-bg)}
#search-wrap{margin-left:auto;display:flex;align-items:center;gap:6px;
  background:var(--search-bg);border:1px solid var(--search-border);
  border-radius:20px;padding:0 12px;height:32px}
#search-input{background:none;border:none;outline:none;color:var(--text);
  font-size:12px;width:150px}
#search-input::placeholder{color:var(--text3)}
#stats-pill{font-size:11px;color:var(--text3);margin-left:8px;white-space:nowrap}

/* ── LAYOUT ───────────────────────────────────────────────── */
#shell{display:flex;height:100%;padding-top:52px;position:relative}

/* Sidebar */
#sidebar{
  width:var(--sb-w);flex-shrink:0;background:var(--bg2);
  border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden;
  padding:16px 0;display:flex;flex-direction:column;
  transition:width var(--dur) var(--ease),padding var(--dur) var(--ease);
}
#sidebar.collapsed{width:0;padding:0;overflow:hidden}
#sidebar::-webkit-scrollbar{width:3px}
#sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.sb-label{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text3);padding:12px 16px 4px;white-space:nowrap}
.sb-item{display:flex;align-items:center;gap:6px;padding:6px 16px;cursor:pointer;
  color:var(--text2);font-size:12px;white-space:nowrap;
  transition:color var(--dur),background var(--dur);
  border-left:2px solid transparent;user-select:none}
.sb-item:hover{color:var(--text);background:var(--surface)}
.sb-item.active{color:var(--text);border-left-color:var(--text);background:var(--surface)}
.sb-item .badge{margin-left:auto;font-size:10px;color:var(--text3)}
.sb-item.l1{padding-left:28px}
.sb-item.l2{padding-left:40px}
.sb-favs{padding:6px 16px;font-size:11px;color:var(--text3)}

/* Sidebar toggle — pegado al borde del sidebar, fijo abajo */
#sb-toggle{
  position:absolute;
  left:var(--sb-w);  /* JS lo actualiza */
  bottom:24px;z-index:50;
  width:20px;height:44px;
  background:var(--bg2);border:1px solid var(--border);border-left:none;
  border-radius:0 6px 6px 0;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);cursor:pointer;
  transition:left var(--dur) var(--ease),color var(--dur);
}
#sb-toggle:hover{color:var(--text)}

/* Content */
#content{flex:1;overflow-y:auto;overflow-x:hidden;min-width:0}
#content::-webkit-scrollbar{width:4px}
#content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ── VISTAS ───────────────────────────────────────────────── */
.view{display:none}
.view.active{display:block}

/* ── HOME ─────────────────────────────────────────────────── */
#home-bar{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  padding:14px 20px 10px;border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:10;
  background:var(--overlay-bg);backdrop-filter:blur(8px);
}
.home-stat{display:flex;align-items:baseline;gap:5px}
.home-stat-n{font-size:18px;font-weight:700}
.home-stat-l{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
#home-updated{margin-left:auto;font-size:10px;color:var(--text3)}

/* ── HERO ────────────────────────────────────────────────────── */
#home-hero{
  position:relative;width:100%;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:#000;
  /* Reservar espacio inmediatamente para evitar CLS — altura inline via style vh */
  contain:layout size;
}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:opacity 1s ease;
  will-change:transform,filter; /* blur y scale en capa composited — no afecta al layout */
  transform:translateZ(0); /* forzar capa de composición en Safari */
}
.hero-slide-hidden{opacity:0!important;pointer-events:none}
/* Placeholder borroso mientras carga la imagen de pantalla completa.
   filter + transform en CSS class = GPU composited, sin layout recalculation */
.hero-blur{
  filter:blur(10px);
  transform:translateZ(0) scale(1.05); /* translateZ(0) fuerza capa compositing */
  transition:filter 0.9s ease, transform 0.9s ease;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.25) 0%,rgba(0,0,0,.55) 100%);
  z-index:1;
}
.hero-content{
  position:relative;z-index:2;text-align:center;
  padding:0 20px;max-width:680px;width:100%;
}
.hero-titulo{
  font-size:clamp(22px,4vw,42px);font-weight:700;color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.6);margin-bottom:28px;
  letter-spacing:-.02em;line-height:1.2;
}
.hero-search-form{width:100%}
.hero-search-wrap{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.15);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.3);border-radius:50px;
  padding:10px 10px 10px 20px;
  transition:background .2s,border-color .2s;
}
.hero-search-wrap:focus-within{
  background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.55);
}
.hero-search-input{
  flex:1;background:none;border:none;outline:none;
  font-size:15px;color:#fff;min-width:0;
}
.hero-search-input::placeholder{color:rgba(255,255,255,.6)}
.hero-search-btn{
  background:rgba(255,255,255,.9);color:#111;border:none;
  border-radius:40px;padding:8px 22px;font-size:13px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0;
}
.hero-search-btn:hover{background:#fff}
.hero-dots{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  z-index:3;gap:6px;
}
.hero-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.4);cursor:pointer;transition:all .2s;
  display:inline-block;
}
.hero-dot-active{background:#fff;width:18px;border-radius:3px}

/* ── HOME CATEGORÍAS ─────────────────────────────────────────── */
#home-cats-wrap{padding:28px 20px 8px;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}
.home-section-label{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text3);margin-bottom:14px;
}
.home-cats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:12px;
}
.home-cat-card{
  position:relative;border-radius:var(--r);overflow:hidden;
  cursor:pointer;aspect-ratio:3/2;background:var(--surface);
  border:1px solid var(--border);transition:transform .2s,box-shadow .2s;
}
.home-cat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.home-cat-img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .4s ease;
}
.home-cat-card:hover .home-cat-img{transform:scale(1.05)}
.home-cat-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:10px 14px;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,transparent 100%);
}
.home-cat-nombre{font-size:13px;font-weight:700;color:#fff}
.home-cat-count{font-size:11px;color:var(--cat-count-color);margin-top:2px}

/* ── MASONRY MODO TEXTO ──────────────────────────────────────── */
.masonry-overlay-texto{
  opacity:1!important;
  background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.1) 60%,transparent 100%);
  padding:10px 10px 8px;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.masonry-item-texto:hover .masonry-overlay-texto{background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.2) 70%,transparent 100%)}
.mo-titulo{font-size:11px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.mo-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}
.mo-tag{font-size:9px;padding:1px 6px;border-radius:10px;background:rgba(255,255,255,.18);
  color:rgba(255,255,255,.85);cursor:pointer;transition:background .15s;white-space:nowrap}
.mo-tag:hover{background:rgba(255,255,255,.35);color:#fff}
.mo-meta{font-size:10px;color:var(--cat-count-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}

/* ── ANIMACIONES DE CARGA ─────────────────────────────────── */
/* shimmer: animado con transform (GPU-composited, sin CLS, sin warning Lighthouse) */
@keyframes shimmer {
  0%   { transform: translateX(-100%) }
  100% { transform: translateX(100%) }
}
@keyframes spin {
  to { transform: translate(-50%,-50%) rotate(360deg) }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(6px) }
  to   { opacity:1; transform:translateY(0) }
}

/* Masonry — skeleton + fade */
#masonry{padding:3px;position:relative}
#masonry.masonry-ready{transition:height .3s}
.masonry-item{
  position:absolute;overflow:hidden;cursor:pointer;background:var(--surface);
  border-radius:2px;
}
.masonry-item .m-skeleton{
  width:100%;
  background:var(--surface);
  position:relative;
  overflow:hidden; /* necesario para que el ::before no se salga */
}
/* El shimmer es un pseudo-elemento que se desplaza con transform (GPU) */
.masonry-item .m-skeleton::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--hover-bg) 50%,
    transparent 100%);
  transform:translateX(-100%);
  animation:shimmer 1.4s infinite linear;
  will-change:transform;
}
/* Cuando hay LQIP: fondo borroso quieto, sin shimmer */
.masonry-item .m-skeleton.has-lqip{
  background-color: var(--surface);
  background-size: cover !important;
  background-position: center !important;
}
.masonry-item .m-skeleton.has-lqip::before{
  display:none; /* sin shimmer — el LQIP ya ocupa el espacio */
}
/* Spinner sobre el skeleton de masonry */
.masonry-item .m-skeleton::after{
  content:'';
  position:absolute;top:50%;left:50%;
  width:20px;height:20px;margin:-10px 0 0 -10px;
  border:2px solid rgba(255,255,255,.25);
  border-top-color:rgba(255,255,255,.7);
  border-radius:50%;
  animation:spin .8s linear infinite;
}
/* Con LQIP: spinner más pequeño y sutil */
.masonry-item .m-skeleton.has-lqip::after{
  width:16px;height:16px;margin:-8px 0 0 -8px;
  border-color:rgba(255,255,255,.2);
  border-top-color:rgba(255,255,255,.6);
}
.masonry-item img,
.masonry-item video{
  position:absolute;top:0;left:0;
  width:100%;height:100%;object-fit:cover;
  opacity:0;
}
.masonry-item.loaded img,
.masonry-item.loaded video{
  opacity:1;
  transition:opacity .45s ease;
  animation:fadeUp .45s ease both;
}
/* Al cargar: skeleton hace fade-out mientras imagen hace fade-in */
.masonry-item.loaded .m-skeleton{
  opacity:0;
  transition:opacity .45s ease;
}
.masonry-item.loaded .m-skeleton::before{
  display:none; /* detener shimmer al cargar */
}
.masonry-item.loaded .m-skeleton::after{
  animation:none; /* detener spinner al cargar */
}
.masonry-item:hover img,
.masonry-item:hover video{transform:scale(1.04);transition:transform .4s var(--ease),opacity .45s ease}
.masonry-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 50%);
  opacity:0;transition:opacity var(--dur);
  display:flex;align-items:flex-end;padding:8px;z-index:2;
}
.masonry-item:hover .masonry-overlay{opacity:1}
.masonry-name{font-size:10px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}
.masonry-dot{
  position:absolute;top:7px;right:7px;
  width:5px;height:5px;background:#fff;border-radius:50%;
  opacity:0;transition:opacity var(--dur);z-index:2;
}
.masonry-item:hover .masonry-dot{opacity:.6}
.masonry-item.has-ficha .masonry-dot{opacity:.35}
.masonry-rating{
  position:absolute;bottom:7px;right:7px;
  font-size:10px;font-weight:700;color:var(--gold);
  background:rgba(0,0,0,.6);border-radius:10px;
  padding:1px 6px;pointer-events:none;z-index:2;
  opacity:0;transition:opacity var(--dur);
}
.masonry-item:hover .masonry-rating{opacity:1}
.masonry-item.has-ficha .masonry-rating{opacity:.7}
.masonry-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40px;height:40px;border-radius:50%;
  background:rgba(0,0,0,.55);border:2px solid rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  color:#fff;z-index:2;pointer-events:none;
}

/* ── GRILLA UNIFORME ──────────────────────────────────────── */
.grid-header{
  display:flex;align-items:center;gap:10px;
  padding:20px 20px 12px;flex-wrap:wrap;
}
.grid-title{font-size:16px;font-weight:600}
.grid-count{font-size:12px;color:var(--text3)}
.grid-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.sort-select{background:var(--surface);border:1px solid var(--border);
  border-radius:20px;color:var(--text);padding:4px 12px;font-size:11px;outline:none;cursor:pointer}
.ss-btn{display:flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;
  background:rgba(255,255,255,.9);color:#000;font-size:11px;font-weight:600;
  transition:background var(--dur)}
.ss-btn:hover{background:#fff}
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:0 20px 12px}
.tag-pill{padding:3px 10px;border-radius:20px;font-size:11px;
  background:var(--surface);border:1px solid var(--border);
  cursor:pointer;transition:all var(--dur);color:var(--text2)}
.tag-pill:hover,.tag-pill.active{background:var(--text);color:var(--bg);border-color:var(--text)}

/* Grilla cuadrada — IDÉNTICA en Explorar y Todas */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:2px;padding:0 20px 20px;
}
.photo-thumb{
  position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;
  background:var(--surface);
  border-radius:2px;
}
/* Shimmer GPU-composited via ::after (::before es el spinner) */
.photo-thumb::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--hover-bg) 50%,
    transparent 100%);
  transform:translateX(-100%);
  animation:shimmer 1.4s infinite linear;
  will-change:transform;
}
/* Spinner centrado en cada thumb mientras carga */
.photo-thumb::before{
  content:'';
  position:absolute;top:50%;left:50%;
  width:18px;height:18px;
  border:2px solid var(--input-border);
  border-top-color:var(--text2);
  border-radius:50%;
  animation:spin .8s linear infinite;
  z-index:1;
}
/* Una vez cargada, detener shimmer y spinner */
.photo-thumb.img-loaded{
  background:var(--surface);
}
.photo-thumb.img-loaded::after{display:none}
.photo-thumb.img-loaded::before{display:none}
.photo-thumb .media-el{
  width:100%;height:100%;object-fit:cover;
  opacity:0;position:relative;z-index:2;
}
.photo-thumb .media-el.loaded{
  opacity:1;
  transition:opacity .4s ease;
  animation:fadeUp .4s ease both;
}
.photo-thumb:hover .media-el{transform:scale(1.06);transition:transform .4s var(--ease),opacity .4s ease}
.thumb-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 55%);
  opacity:0;transition:opacity var(--dur);
  display:flex;align-items:flex-end;padding:8px;z-index:3;
}
.photo-thumb:hover .thumb-overlay{opacity:1}
.thumb-name{font-size:10px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}
.has-ficha-dot{position:absolute;top:7px;right:7px;
  width:6px;height:6px;background:#fff;border-radius:50%;
  opacity:0;transition:opacity var(--dur)}
.photo-thumb:hover .has-ficha-dot{opacity:.7}
.thumb-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  color:#fff;pointer-events:none;
}
/* Valoración en miniatura */
.thumb-rating{
  position:absolute;top:6px;left:6px;
  background:rgba(0,0,0,.6);border-radius:10px;
  padding:1px 6px;font-size:10px;font-weight:700;color:var(--gold);
  opacity:0;transition:opacity var(--dur);
}
.photo-thumb:hover .thumb-rating{opacity:1}
.photo-thumb.has-rating .thumb-rating{opacity:.8}

/* Carpetas */
.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:12px;padding:0 20px 20px}
/* Sección de categorías: tarjetas más grandes */
.folder-grid.cats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.folder-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;cursor:pointer;transition:all var(--dur);
}
.folder-card:hover{
  border-color:var(--hover-border);
  transform:translateY(-3px);
  box-shadow:0 8px 24px var(--card-shadow);
}
/* Categorías: acento dorado */
.folder-card.folder-cat{
  border-color:rgba(200,169,110,.25);
  background:rgba(200,169,110,.06);
}
.folder-card.folder-cat:hover{
  border-color:rgba(200,169,110,.55);
  box-shadow:0 8px 24px rgba(200,169,110,.2);
  background:rgba(200,169,110,.1);
}
.folder-card.folder-cat .folder-name{ color:var(--gold);font-size:14px; }
.folder-card.folder-cat .folder-meta{ color:rgba(200,169,110,.6); }
/* Sets: acento azul */
.folder-card.folder-set{ border-color:rgba(126,180,255,.15); }
.folder-card.folder-set:hover{ border-color:rgba(126,180,255,.4);box-shadow:0 8px 24px rgba(126,180,255,.12); }
.folder-card.folder-set .folder-name{ color:#7eb4ff; }
/* Grid diferenciado: categorías más anchas */
.folder-grid.has-cats .folder-card.folder-cat{
  grid-column: span 1;
}
.folder-thumb{background:var(--bg3)}
.folder-icon{margin-bottom:8px}
.folder-name{font-weight:600;font-size:13px;margin-bottom:2px}
/* Tema claro: texto más oscuro para mayor contraste */
[data-theme="light"] .folder-name{color:var(--text)}
[data-theme="light"] .folder-meta{color:var(--text2)}
[data-theme="light"] .folder-card.folder-cat .folder-name{color:#8a6800}
[data-theme="light"] .folder-card.folder-cat .folder-meta{color:rgba(138,104,0,.6)}
[data-theme="light"] .folder-card.folder-set .folder-name{color:#1a5fd4}
.folder-meta{font-size:11px;color:var(--text2)}
.breadcrumb{padding:16px 20px 4px;font-size:12px;color:var(--text3);display:flex;align-items:center;gap:4px}
.breadcrumb a{color:var(--text3);text-decoration:none;cursor:pointer}
.breadcrumb a:hover{color:var(--text)}
.bc-sep{color:var(--border)}
.explorar-section-title{
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text3);padding:16px 20px 8px;
}
.breadcrumb a{color:var(--text2);cursor:pointer}
.breadcrumb a:hover{color:var(--text)}
.empty-state{text-align:center;padding:80px 20px;color:var(--text3);font-size:13px}

/* ── VISOR ────────────────────────────────────────────────── */
#viewer{
  display:none;position:fixed;inset:0;z-index:1000;
  background:#000;
}
#viewer.open{display:flex;flex-direction:row}

#viewer-stage{
  flex:1;position:relative;
  display:flex;align-items:center;justify-content:center;min-width:0;
  overflow:hidden;
}
/* LQIP: div real con blur — permite transition de opacity */
#viewer-lqip{
  position:absolute;inset:-20px;
  background-size:cover;background-position:center;
  filter:blur(20px) brightness(0.4);
  transform:scale(1.1);
  z-index:0;pointer-events:none;
  opacity:0;
  transition:opacity .4s ease;
}
#viewer-lqip.visible{ opacity:1; }
#viewer-stage #viewer-img{ position:relative;z-index:1; }
/* Spinner centrado mientras carga la imagen grande */
#viewer-stage.loading::after{
  content:'';
  position:absolute;top:50%;left:50%;
  width:32px;height:32px;
  border:3px solid rgba(255,255,255,.12);
  border-top-color:rgba(255,255,255,.7);
  border-radius:50%;
  animation:spin .7s linear infinite;
  z-index:10;pointer-events:none;
}
#viewer-img{
  display:block;max-width:100%;max-height:100%;
  object-fit:contain;
  user-select:none;-webkit-user-drag:none;
  opacity:0;
  transform-origin:center center;
  will-change:transform;
}
#viewer-img.visible{opacity:1;transition:opacity .3s ease}
#viewer-img.fade{opacity:0}
#viewer-img.horizontal{width:100%;height:auto}
#viewer-img.vertical{width:auto;height:100%}

/* Vídeo en visor */
#viewer-video{
  display:none;max-width:100%;max-height:100%;
  object-fit:contain;outline:none;
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:#000;
}
#viewer-video.viewer-video-active{display:block}
#viewer-video.horizontal{width:100%;height:auto;max-height:100%}
#viewer-video.vertical{width:auto;height:100%;max-width:100%}
/* Cuando hay vídeo, ocultar icono de play del stage */
.viewer-open #viewer-stage.has-video .viewer-grad-top{opacity:.5}

.viewer-grad-top{position:absolute;top:0;left:0;right:0;height:100px;
  background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent);
  pointer-events:none;z-index:2}
.viewer-grad-bot{position:absolute;bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(to top,rgba(0,0,0,.6),transparent);
  pointer-events:none;z-index:2}

#viewer-topbar{
  position:absolute;top:0;left:0;right:0;height:52px;
  display:flex;align-items:center;gap:8px;padding:0 12px;z-index:10;
}
#viewer-close{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.4);
  display:flex;align-items:center;justify-content:center;color:#fff;transition:background var(--dur)}
#viewer-close:hover{background:rgba(0,0,0,.7)}
#viewer-title{font-size:13px;font-weight:500;color:#fff;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
#viewer-counter{font-size:11px;color:rgba(255,255,255,.5);white-space:nowrap}
.viewer-icon-btn{
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.7);cursor:pointer;
  transition:all .15s ease;
}
.viewer-icon-btn:hover{
  background:rgba(255,255,255,.15);
  color:#fff;border-color:rgba(255,255,255,.3);
  transform:scale(1.08);
}
/* Icono dual: outline por defecto, filled cuando activo */
.viewer-icon-btn .ico-on { display:none; }
.viewer-icon-btn .ico-off{ display:block; }
/* Estado activo — fav */
#fav-btn.fav-on{
  background:rgba(224,92,92,.25);
  border-color:rgba(224,92,92,.5);
  color:#e05c5c;
}
#fav-btn.fav-on .ico-off{ display:none; }
#fav-btn.fav-on .ico-on { display:block; }
#fav-btn.fav-on:hover{ background:rgba(224,92,92,.4); }
/* Estado activo — save */
#save-btn.save-on{
  background:rgba(126,180,255,.2);
  border-color:rgba(126,180,255,.45);
  color:#7eb4ff;
}
#save-btn.save-on .ico-off{ display:none; }
#save-btn.save-on .ico-on { display:block; }
#save-btn.save-on:hover{ background:rgba(126,180,255,.35); }

.viewer-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.12);
  color:#fff;display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:background var(--dur);
}
.viewer-arrow:hover{background:rgba(0,0,0,.75)}
#viewer-prev{left:14px}
#viewer-next{right:14px}

/* Panel ficha — hijo directo de #viewer */
#viewer-panel{
  width:var(--panel-w);min-width:0;flex-shrink:0;
  background:var(--bg2);border-left:1px solid var(--border);
  overflow-y:auto;display:flex;flex-direction:column;
  transition:width var(--dur) var(--ease);
}
#viewer-panel::-webkit-scrollbar{width:3px}
#viewer-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
#viewer-panel.hidden{width:0;overflow:hidden;border:none;pointer-events:none}

/* Panel toggle — posicionado FIJO respecto a #viewer (position:fixed),
   siempre alineado al borde izquierdo del panel, abajo */
#panel-toggle{
  position:fixed;
  bottom:24px;
  /* right = panel-w cuando panel visible, 0 cuando oculto */
  right:var(--panel-w);
  width:20px;height:44px;z-index:1010;
  background:var(--bg2);border:1px solid var(--border);border-right:none;
  border-radius:6px 0 0 6px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);cursor:pointer;
  transition:right var(--dur) var(--ease),color var(--dur);
}
#panel-toggle:hover{color:var(--text)}
#panel-toggle.collapsed{right:0}
/* Oculto por defecto, visible solo cuando viewer está abierto */
#panel-toggle{display:none}
body.viewer-open #panel-toggle{display:flex!important}

/* Rating en visor */
#viewer-rating{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  padding:12px 20px 10px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.star-wrap{display:flex;gap:4px;align-items:center}
.star-cell{
  position:relative;width:28px;height:28px;flex-shrink:0;
  cursor:pointer;display:inline-block;
}
/* SVG base — siempre visible, cambia de fill */
.star-cell svg{display:block;pointer-events:none}
/* Botones invisibles sobre el SVG */
.star-btn-l,.star-btn-r{
  position:absolute;top:0;height:100%;background:none;border:none;
  padding:0;cursor:pointer;
}
.star-btn-l{left:0;width:50%;z-index:2}
.star-btn-r{left:50%;width:50%;z-index:2}

/* Ficha */
#ficha-wrap{padding:16px 20px;flex:1;overflow-y:auto}
.ficha-titulo{font-size:15px;font-weight:700;margin-bottom:6px;color:var(--text);line-height:1.3}
/* Descripción sin tarjeta — fluye en el fondo */
.ficha-desc{
  font-size:12px;color:var(--text2);line-height:1.7;margin-bottom:8px;
}
.ficha-desc:empty{ display:none; margin:0; } /* no ocupa espacio si está vacío */
.ficha-desc p{margin:0 0 8px}
.ficha-desc p:last-child{margin-bottom:0}
/* Bullets de lugar/fecha/autor/créditos — sin íconos, minimalistas */
.ficha-meta-list{
  display:flex;flex-direction:column;gap:5px;
  margin-top:0;margin-bottom:0;padding-bottom:8px; /* aire debajo de Lugar/Fecha */
}
.ficha-meta-item{
  display:flex;gap:6px;align-items:baseline;font-size:11px;
}
.ficha-meta-label{
  color:var(--text3);flex-shrink:0;min-width:52px;
  font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding-top:1px;
}
.ficha-meta-val{color:var(--text2);word-break:break-word}
.ficha-sep{height:1px;background:var(--border);margin:10px 0}
.ficha-section-label{font-size:9px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text3);margin-bottom:6px;margin-top:2px}
.ficha-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:6px;font-size:11px}
.ficha-row-icon{color:var(--text3);flex-shrink:0;margin-top:1px;width:16px}
.ficha-row-label{color:var(--text3);width:64px;flex-shrink:0}
.ficha-row-val{color:var(--text2);word-break:break-word}
/* Fila de campo de tipo: sin ícono, label más estrecho */
.ficha-row-tipo{gap:6px}
.ficha-row-tipo .ficha-row-label{width:80px}
/* Valores clickeables */
.ficha-val-link{
  cursor:pointer;transition:color .15s;
}
.ficha-val-link:hover{color:var(--text);text-decoration:underline;text-underline-offset:2px}
.ficha-tag-link{cursor:pointer;transition:all .12s}
.ficha-tag-link:hover{background:rgba(255,255,255,.15);color:var(--text)}
/* Tags de categoría — amarillo dorado */
.ficha-tag-cat{cursor:pointer;background:rgba(245,200,66,.1);border-color:rgba(245,200,66,.25);color:#f5c842;transition:all .12s}
.ficha-tag-cat:hover{background:rgba(245,200,66,.2);color:#f5c842}
/* Tags de set — azul */
.ficha-tag-set{cursor:pointer;background:rgba(126,180,255,.1);border-color:rgba(126,180,255,.25);color:#7eb4ff;transition:all .12s}
.ficha-tag-set:hover{background:rgba(126,180,255,.2);color:#7eb4ff}
.ficha-tags-cats,.ficha-tags-sets{margin-bottom:2px}
/* Tema claro: hover de chips con mejor contraste — gris neutro */
[data-theme="light"] .ficha-tag-link:hover{
  background:rgba(0,0,0,.07);color:var(--text);border-color:rgba(0,0,0,.25);
}
[data-theme="light"] .ficha-tag-cat:hover{
  background:rgba(0,0,0,.06);color:var(--text);border-color:rgba(0,0,0,.2);
}
[data-theme="light"] .ficha-tag-set:hover{
  background:rgba(0,0,0,.06);color:var(--text);border-color:rgba(0,0,0,.2);
}
/* Hover de estrellas */
.star-half{transition:color .1s,opacity .1s}
/* Chips en la ficha: margen compacto */
.ficha-tags{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0}
/* Bloque categoría + personas — sin márgenes extra entre ellos */
.ficha-chips-bloque{ margin:0 }
.ficha-chips-bloque .ficha-tags{ margin:0 0 4px }
.ficha-chips-bloque .ficha-tags:last-child{ margin-bottom:0 }
/* Lugar/fecha/autor: separación clara desde los chips */
.ficha-chips-bloque + .ficha-meta-list{ margin-top:10px }
.ficha-tag{padding:2px 8px;background:var(--surface);border:1px solid var(--border);
  border-radius:20px;font-size:10px;color:var(--text2)}
.ficha-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text3);font-size:12px}
/* Editar ficha — dentro del bloque de quick-tags */
.ficha-edit-link{
  display:flex;align-items:center;justify-content:center;gap:5px;
  padding:7px 12px;border:none;border-radius:var(--r);
  font-size:11px;font-weight:600;color:#fff;background:#228537;
  text-decoration:none;cursor:pointer;transition:background .15s;
}
.ficha-edit-link:hover{background:#1a6a2a}
/* Barra admin: editar + borrar en misma fila */
.ficha-admin-bar{
  display:flex;gap:6px;align-items:stretch;margin-bottom:10px;
}
.ficha-admin-bar .ficha-edit-link{flex:1;margin-bottom:0}
/* Botón borrar en la ficha (solo admin) */
.ficha-del-btn{
  padding:7px 10px;border:none;border-radius:var(--r);
  background:#e34c26;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.ficha-del-btn:hover{background:#c03d1e}

/* ── GPS minimap en ficha ─────────────────────────────────────── */
.ficha-gps-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:2px 7px;border-radius:10px;font-size:10px;font-weight:600;
  background:rgba(76,175,130,.12);border:1px solid rgba(76,175,130,.3);
  color:#4caf82;cursor:pointer;vertical-align:middle;
  margin-left:6px;gap:4px;transition:all .15s;
  white-space:nowrap;
}
.ficha-gps-btn:hover,.ficha-gps-btn.activo{
  background:rgba(76,175,130,.25);border-color:rgba(76,175,130,.5);
}
.ficha-gps-btn.activo{ color:#6ddaaa }
.ficha-map-wrap{
  margin:8px 0 4px;border-radius:8px;overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.ficha-map-container{
  width:100%;height:160px;display:block;
  background:var(--bg2);
}
.ficha-map-coords{
  font-size:10px;color:var(--text3);padding:4px 8px;
  background:var(--surface);border-top:1px solid var(--border);
  font-family:monospace;letter-spacing:.02em;
}
.ficha-sep{height:1px;background:var(--border);margin:10px 0}
.ficha-section-label{font-size:9px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text3);margin-bottom:6px;margin-top:2px}
.ficha-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:6px;font-size:11px}
.ficha-row-icon{color:var(--text3);flex-shrink:0;margin-top:1px;width:16px}
/* Valores clickeables (3) */
.ficha-val-link{
  cursor:pointer;transition:color .15s;
}
.ficha-val-link:hover{color:var(--text);text-decoration:underline;text-underline-offset:2px}
/* Tags rápidos */
#quick-tags{padding:14px 20px 16px;border-top:1px solid var(--border)}
.qt-label{display:block;font-size:9px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text3);margin:12px 0 6px}
.qt-wrap{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.qt-add{display:flex;gap:6px}
#qt-input{flex:1;background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:5px 12px;font-size:11px;color:var(--text);outline:none}
#qt-input:focus{border-color:var(--hover-border)}
#qt-save{padding:5px 14px;border-radius:20px;background:var(--qt-save-bg);
  color:var(--qt-save-color);font-size:11px;font-weight:600;transition:background var(--dur)}
#qt-save:hover{background:#fff}
.qt-chip{display:flex;align-items:center;gap:3px;padding:2px 8px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px;font-size:10px;color:var(--text2)}
.qt-chip button{color:var(--text3);font-size:11px;transition:color var(--dur)}
.qt-chip button:hover{color:var(--text)}

/* ── SLIDESHOW ────────────────────────────────────────────── */
#slideshow{display:none;position:fixed;inset:0;z-index:2000;background:#000;
  overflow:hidden;touch-action:none}
#slideshow.open{display:block}
.ss-slide{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;transition:opacity .7s var(--ease)}
.ss-slide.hidden{opacity:0;pointer-events:none}
.ss-slide img,.ss-slide video{max-width:100%;max-height:100%;object-fit:contain;
  user-select:none;-webkit-user-drag:none}
.ss-slide img.horizontal,.ss-slide video.horizontal{width:100%;height:auto}
.ss-slide img.vertical,.ss-slide video.vertical{width:auto;height:100%}
#ss-topbar{position:absolute;top:0;left:0;right:0;z-index:10;
  display:flex;align-items:center;gap:10px;padding:12px 16px;
  background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent)}
#ss-title{font-size:12px;color:rgba(255,255,255,.65)}
#ss-counter{margin-left:auto;font-size:11px;color:rgba(255,255,255,.4)}
#ss-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background var(--dur)}
#ss-close:hover{background:rgba(255,255,255,.2)}
#ss-bottombar{position:absolute;bottom:0;left:0;right:0;z-index:10;
  display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;
  background:linear-gradient(to top,rgba(0,0,0,.7),transparent)}
#ss-pause-btn{display:flex;align-items:center;gap:6px;padding:7px 18px;border-radius:20px;
  background:rgba(255,255,255,.12);color:#fff;font-size:11px;transition:background var(--dur)}
#ss-pause-btn:hover{background:rgba(255,255,255,.22)}
#ss-progress-track{position:absolute;bottom:0;left:0;right:0;height:2px;
  background:rgba(255,255,255,.1);z-index:11}
#ss-progress-bar{height:100%;background:rgba(255,255,255,.8);width:0%;transition:width linear}
.ss-arrow{position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);
  color:#fff;display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:background var(--dur)}
.ss-arrow:hover{background:rgba(0,0,0,.7)}
#ss-prev{left:14px}
#ss-next{right:14px}

/* ── TOAST ────────────────────────────────────────────────── */
#toast{position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:8px 20px;font-size:12px;
  z-index:9999;transition:transform .3s var(--ease);pointer-events:none}
#toast.show{transform:translateX(-50%) translateY(0)}

/* ── RULETA ────────────────────────────────────────────────── */
#view-ruleta{padding:20px}
.ruleta-wrap{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:560px;margin:0 auto;padding:20px 0}
.ruleta-card{
  width:100%;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;cursor:pointer;
  transition:border-color var(--dur),transform var(--dur);
}
.ruleta-card:hover{border-color:var(--hover-border);transform:translateY(-2px)}
.ruleta-media-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;background:#000;position:relative}
.ruleta-media{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.ruleta-card:hover .ruleta-media{transform:scale(1.03)}
.ruleta-info{padding:16px 18px}
.ruleta-nombre{font-size:15px;font-weight:700;margin-bottom:3px}
.ruleta-carpeta{font-size:11px;color:var(--text3);margin-bottom:6px}
.ruleta-desc{font-size:12px;color:var(--text2);line-height:1.55}
.ruleta-btns{display:flex;gap:10px}
.ruleta-open-btn{
  padding:6px 18px;border-radius:20px;
  border:1px solid var(--border);background:transparent;
  color:var(--text2);font-size:11px;cursor:pointer;
  transition:all var(--dur);
}
.ruleta-open-btn:hover{border-color:rgba(255,255,255,.3);color:var(--text)}

/* ── GRID SENTINEL (carga por lotes) ─────────────────────── */
.grid-sentinel{height:1px;grid-column:1/-1;pointer-events:none}

@media(max-width:700px){
  #sidebar{display:none!important}
  #sb-toggle{display:none!important}
  .photo-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1px;padding:0 0 20px}
  .folder-grid{padding:0 12px 20px}
  .grid-header{padding:14px 12px 8px}
  .filter-bar{padding:0 12px 10px}
  .breadcrumb{padding:12px 12px 4px}
  #stats-pill{display:none}
  #search-input{width:100px}
  #masonry{padding:1px}
  #home-bar{padding:10px 12px 8px;gap:14px}

  #viewer-panel{
    position:absolute;bottom:-100%;left:0;right:0;
    width:100%!important;height:65%;top:auto;
    border-left:none;border-top:1px solid var(--border);
    border-radius:16px 16px 0 0;
    transition:bottom .35s var(--ease);z-index:20;
  }
  #viewer-panel.mobile-open{bottom:0}
  #panel-toggle{display:none!important}
  .viewer-arrow{width:38px;height:38px}
  #viewer-prev{left:8px}
  #viewer-next{right:8px}

  /* Rating mobile: compacto */
  #viewer-rating{padding:10px 16px;grid-template-columns:44px 1fr;gap:6px}
  .rating-num{font-size:22px;width:44px}
}
@media(min-width:701px){.mobile-only{display:none!important}}
@media(max-width:700px){.desktop-only{display:none!important}}

/* ═══════════════════════════════════════════════════
   SET VIEWER
═══════════════════════════════════════════════════ */
#set-viewer{
  position:fixed;inset:0;z-index:1100;
  background:#000;
  display:none;flex-direction:column;
}
#set-viewer.open{display:flex}
body.sv-open{overflow:hidden}

#sv-topbar{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;
  background:rgba(0,0,0,.85);
  border-bottom:1px solid rgba(255,255,255,.08);
  flex-shrink:0;z-index:2;
}
#sv-close{
  background:none;border:none;color:rgba(255,255,255,.7);
  cursor:pointer;padding:4px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:color .15s;flex-shrink:0;
}
#sv-close:hover{color:#fff}
#sv-info{flex:1;min-width:0;display:flex;align-items:baseline;gap:8px}
#sv-titulo{font-size:14px;font-weight:600;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#sv-counter{font-size:11px;color:rgba(255,255,255,.45);flex-shrink:0}
#sv-actions{display:flex;gap:4px;flex-shrink:0}
.sv-mode-btn{
  background:none;border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.5);border-radius:6px;
  padding:5px 8px;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;
}
.sv-mode-btn:hover,.sv-mode-btn.active{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.4);color:#fff;
}

/* Slideshow */
#sv-slideshow{
  flex:1;display:flex;flex-direction:column;overflow:hidden;
}
#sv-stage{
  flex:1;position:relative;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
#sv-img{
  max-width:100%;max-height:100%;object-fit:contain;
  user-select:none;-webkit-user-drag:none;
  transition:opacity .3s ease;
}
#sv-video{
  max-width:100%;max-height:100%;object-fit:contain;outline:none;
}
.sv-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.15);
  border-radius:50%;width:42px;height:42px;
  color:rgba(255,255,255,.8);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;z-index:2;
}
.sv-arrow:hover{background:rgba(0,0,0,.8);color:#fff}
#sv-prev{left:12px}
#sv-next{right:12px}
#sv-stage-loading{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.sv-spinner{
  width:32px;height:32px;border-radius:50%;
  border:3px solid rgba(255,255,255,.12);
  border-top-color:rgba(255,255,255,.7);
  animation:spin .7s linear infinite;
}

/* Tira de miniaturas */
#sv-strip-wrap{
  height:72px;flex-shrink:0;
  background:rgba(0,0,0,.7);
  border-top:1px solid rgba(255,255,255,.08);
  overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;
}
#sv-strip-wrap::-webkit-scrollbar{display:none}
#sv-strip{
  display:flex;gap:4px;padding:4px 8px;
  height:100%;align-items:center;
  min-width:max-content;
}
.sv-strip-thumb{
  width:60px;height:60px;flex-shrink:0;
  border-radius:4px;overflow:hidden;
  cursor:pointer;border:2px solid transparent;
  transition:border-color .15s,opacity .15s;
  opacity:.55;
}
.sv-strip-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.sv-strip-thumb:hover{opacity:.85}
.sv-strip-thumb.active{
  border-color:rgba(255,255,255,.8);opacity:1;
}

/* Cuadrícula */
#sv-grid{
  flex:1;overflow-y:auto;padding:16px 20px;
}
.sv-grid-thumbs{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:8px;
}
.sv-grid-thumb{
  position:relative;aspect-ratio:1;border-radius:6px;
  overflow:hidden;cursor:pointer;
  background:var(--surface);
  border:2px solid transparent;transition:border-color .15s;
}
.sv-grid-thumb:hover{border-color:rgba(255,255,255,.3)}
.sv-grid-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .3s;
}
.sv-grid-thumb:hover img{transform:scale(1.05)}
.sv-grid-thumb-label{
  position:absolute;bottom:0;left:0;right:0;
  padding:4px 8px;
  background:linear-gradient(to top,rgba(0,0,0,.8),transparent);
  font-size:10px;color:#fff;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* Botón de set en la ficha */
.ficha-set-btn{
  display:flex;align-items:center;gap:6px;
  width:100%;padding:8px 10px;margin-bottom:4px;
  background:var(--input-bg,rgba(255,255,255,.06));
  border:1px solid var(--input-border,rgba(255,255,255,.12));
  border-radius:var(--r);
  color:var(--text2);font-size:12px;cursor:pointer;
  transition:all .15s;text-align:left;
}
.ficha-set-btn:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.25);color:var(--text);
}

/* ── Tira de miniaturas del set en el panel de ficha ── */
.ficha-set-strip-wrap{margin:8px 0 4px}
.ficha-set-strip-loading{font-size:11px;color:var(--text3);padding:4px 0}
.ficha-set-strip{
  display:flex;gap:4px;overflow-x:auto;padding:2px 0 6px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
  cursor:grab;
  scroll-behavior:auto; /* sin animación para que el drag se sienta directo */
  -webkit-overflow-scrolling:touch;
}
.ficha-set-strip:active{cursor:grabbing}
.ficha-set-strip::-webkit-scrollbar{height:3px}
.ficha-set-strip::-webkit-scrollbar-track{background:transparent}
.ficha-set-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.ficha-set-thumb{
  width:52px;height:52px;flex-shrink:0;
  border-radius:4px;overflow:hidden;cursor:pointer;
  border:2px solid transparent;transition:border-color .15s,opacity .15s;
  opacity:.6;position:relative;
}
.ficha-set-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ficha-set-thumb:hover{opacity:.9}
.ficha-set-thumb.activa{border-color:var(--active-thumb-border);opacity:1}
/* Placeholder para vídeos sin thumb */
.set-thumb-placeholder{
  width:100%;height:100%;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
}
.set-thumb-placeholder svg{width:16px;height:16px}
/* Icono play sobre el thumb de vídeo */
.set-thumb-play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);pointer-events:none;
}
.set-thumb-play svg{width:12px;height:12px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}

/* ══════════════════════════════════════════════════
   BÚSQUEDA AVANZADA
══════════════════════════════════════════════════ */
#busqueda-avanzada{
  position:fixed;top:48px;right:0;bottom:0;
  width:320px;z-index:500;
  display:flex;flex-direction:column;
  background:var(--bg2);border-left:1px solid var(--border);
  box-shadow:-8px 0 24px rgba(0,0,0,.4);
  animation:baSlide .2s ease;
}
/* ba-inner debe ocupar todo el panel y propagar el flex a sus hijos */
#ba-inner{
  display:flex;flex-direction:column;
  flex:1;min-height:0;overflow:hidden;
}
@keyframes baSlide{from{transform:translateX(100%)}to{transform:translateX(0)}}
#ba-header{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;
}
#ba-header span{flex:1}
#ba-cuerpo{
  flex:1;min-height:0; /* min-height:0 es clave para que overflow-y funcione en flex */
  overflow-y:auto;padding:14px 16px;
  display:flex;flex-direction:column;gap:14px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
#ba-cuerpo::-webkit-scrollbar{width:4px}
#ba-cuerpo::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
#ba-footer{
  padding:10px 16px;border-top:1px solid var(--border);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.ba-grupo{display:flex;flex-direction:column;gap:5px}
.ba-row{flex-direction:row!important;gap:12px}
.ba-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3)}
.ba-input{
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:7px 10px;font-size:12px;color:var(--text);
  outline:none;transition:border-color .15s;width:100%;
}
.ba-input:focus{border-color:var(--hover-border)}
.ba-select{
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:7px 10px;font-size:12px;color:var(--text);
  outline:none;cursor:pointer;width:100%;
}
/* Chips de tags en el panel de búsqueda */
.ba-chips-widget{
  display:flex;flex-wrap:wrap;align-items:center;gap:5px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:5px 8px;min-height:36px;cursor:text;
  transition:border-color .15s;
}
.ba-chips-widget:focus-within{border-color:var(--hover-border)}
.ba-chip{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 8px 2px 10px;border-radius:20px;
  background:var(--hover-bg);border:1px solid var(--border);
  font-size:11px;color:var(--text);
}
.ba-chip button{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:12px;padding:0 1px;line-height:1}
.ba-chip button:hover{color:var(--err)}
.ba-chip-invalid{
  background:rgba(229,100,50,.15)!important;
  border-color:rgba(229,100,50,.4)!important;
  color:rgba(255,160,120,.9)!important;
}
.ba-chip-warn{font-size:10px;opacity:.8;margin-left:1px}
.ba-chip-input{
  flex:1;min-width:80px;background:none;border:none;outline:none;
  font-size:12px;color:var(--text);padding:2px 4px;
}
.ba-chip-input::placeholder{color:var(--text3)}
.ba-tag-suggestions{
  position:absolute;z-index:600;
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;width:100%;max-height:150px;overflow-y:auto;
  box-shadow:0 6px 20px rgba(0,0,0,.5);margin-top:2px;
  scrollbar-width:thin;
}
.ba-tag-sugg-item{
  padding:6px 12px;font-size:12px;color:var(--text2);cursor:pointer;
}
.ba-tag-sugg-item:hover,.ba-tag-sugg-item.active{
  background:rgba(255,255,255,.07);color:var(--text);
}
/* Selector de tipo con campos colapsables */
.ba-tipo-bloque{
  border:1px solid var(--border);border-radius:8px;overflow:hidden;
}
.ba-tipo-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;cursor:pointer;font-size:12px;font-weight:600;
  transition:background .15s;user-select:none;
}
.ba-tipo-header:hover{background:var(--hover-bg)}
.ba-tipo-chevron{transition:transform .2s;font-size:11px;color:var(--text3)}
.ba-tipo-body{display:none;padding:10px 12px;border-top:1px solid var(--border)}
.ba-tipo-body.open{display:block}
.ba-campo{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.ba-campo:last-child{margin-bottom:0}
.ba-campo-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text3)}
.ba-btn-aplicar{
  display:flex;align-items:center;gap:6px;
  padding:8px 18px;border-radius:20px;
  background:var(--text);color:var(--bg);
  font-size:12px;font-weight:700;cursor:pointer;border:none;
  transition:opacity .15s;
}
.ba-btn-aplicar:hover{opacity:.85}
.ba-btn-aplicar:disabled{opacity:.4;cursor:not-allowed}
.ba-btn-limpiar{
  display:flex;align-items:center;gap:5px;
  padding:8px 14px;border-radius:20px;
  background:transparent;color:var(--text3);
  font-size:12px;font-weight:500;cursor:pointer;
  border:1px solid var(--border);
  transition:all .15s;
}
.ba-btn-limpiar:hover{color:var(--text);border-color:var(--text2);}
#btn-avanzada.activo{opacity:1!important}
#btn-avanzada.activo i{color:var(--gold)!important}
/* Radio group para tipo media / orientación */
.ba-radio-group{
  display:flex;gap:6px;flex-wrap:wrap;padding:4px 0;
}
.ba-radio{
  display:flex;align-items:center;gap:5px;
  font-size:12px;color:var(--text2);cursor:pointer;
  padding:4px 10px;border-radius:14px;
  border:1px solid var(--border);
  transition:all .15s;user-select:none;
}
.ba-radio:has(input:checked){
  background:var(--text);color:var(--bg);border-color:var(--text);
}
.ba-radio input{ position:absolute;opacity:0;width:0;height:0; }

/* Chips de filtros activos en resultados */
#ba-filtros-activos{
  display:flex;flex-wrap:wrap;gap:5px;
  padding:8px 20px 4px;
}
.ba-filtro-chip{
  display:flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;font-size:11px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text2);
}
.ba-filtro-chip button{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:0 1px}
.ba-filtro-chip button:hover{color:var(--err)}

@media(max-width:700px){
  #busqueda-avanzada{width:100%;top:48px}
}

/* ── Vista Mapa ────────────────────────────────── */
#view-mapa{
  padding:0;overflow:hidden;
  height:100%;display:none;flex-direction:column;
}
#view-mapa.active{display:flex}
#mapa-leaflet{flex:1;min-height:0}
/* Estilo oscuro para popups de Leaflet */
.leaflet-popup-content-wrapper{
  background:var(--surface);color:var(--text);
  border:1px solid var(--border);border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,.6);
}
.leaflet-popup-tip{background:var(--surface)}
.leaflet-popup-content{margin:10px 12px}

/* ── MarkerCluster — estilo oscuro ─────────────── */
.leaflet-cluster-anim .leaflet-marker-icon,
.leaflet-cluster-anim .leaflet-marker-shadow {
  transition: transform .3s ease-out, opacity .3s ease-in;
}
/* Ocultar los círculos por defecto del plugin (usamos iconos propios) */
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large { display:none; }
.ficha-download-btn{display:flex;align-items:center;gap:6px;padding:7px 10px;
  margin-bottom:4px;border:1px solid var(--border);border-radius:6px;
  font-size:11px;color:var(--text2);text-decoration:none;transition:all .15s}
.ficha-download-btn:hover{border-color:rgba(255,255,255,.3);color:var(--text);background:rgba(255,255,255,.04)}

/* ════════════════════════════════════════════════════
   EXPLORAR — Categorías, carpetas, sets
════════════════════════════════════════════════════ */
#view-explorar{
  padding: 24px 28px;
}
@media(max-width:600px){ #view-explorar{ padding:16px; } }

/* Breadcrumb */
/* Botón descarga para no-logueados: visualmente idéntico al de logueados */
.ficha-download-login{
  cursor:pointer;font-family:inherit;font-size:11px;
  background:none;
}
/* En hover: igual que .ficha-download-btn pero con toque dorado para indicar acción requerida */
.ficha-download-login:hover{border-color:var(--gold);color:var(--gold);background:rgba(245,200,66,.04)}

.exp-breadcrumb{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding-bottom:20px;font-size:13px;
}
.exp-bc-link{
  color:var(--text3);cursor:pointer;text-decoration:none;
  transition:color .15s;padding:2px 4px;border-radius:4px;
}
.exp-bc-link:hover{color:var(--text);background:rgba(255,255,255,.06)}
.exp-bc-sep{color:var(--text3);opacity:.35;user-select:none}
.exp-bc-current{color:var(--text);font-weight:600}

/* Títulos de sección */
.exp-section-title{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text3);margin:24px 0 14px;display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--border);padding-bottom:8px;
}
.exp-section-title:first-of-type{ margin-top:0 }

/* Grid de cards */
.exp-cat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px;margin-bottom:8px;
}
@media(max-width:700px){ .exp-cat-grid{grid-template-columns:repeat(2,1fr);gap:10px} }
@media(max-width:400px){ .exp-cat-grid{grid-template-columns:1fr 1fr;gap:8px} }

/* Card */
.exp-cat-card{
  border-radius:12px;overflow:hidden;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);
  transition:transform .18s ease,border-color .18s,box-shadow .18s;
  position:relative;
}
.exp-cat-card:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.18);
  box-shadow:0 8px 24px rgba(0,0,0,.35);
}

/* Imagen de portada */
.exp-cat-img{
  aspect-ratio:3/2;
  background:var(--bg3) center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.exp-cat-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom, transparent 40%, rgba(0,0,0,.55));
  pointer-events:none;
}

/* Badge de Set */
.exp-set-badge{
  position:absolute;top:10px;right:10px;z-index:1;
  background:rgba(0,0,0,.7);color:rgba(255,255,255,.9);
  font-size:10px;font-weight:700;letter-spacing:.04em;
  padding:4px 9px;border-radius:12px;
  display:flex;align-items:center;gap:4px;
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(4px);
}

/* Info de la card */
.exp-cat-info{
  padding:12px 14px 14px;
}
.exp-cat-nombre{
  font-size:14px;font-weight:600;color:var(--text);
  margin-bottom:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  text-transform:capitalize;
}
.exp-cat-meta{
  font-size:11px;color:var(--text3);
}

/* ── BOTONES HEART/BOOKMARK EN THUMBNAILS ──────────────────── */
.masonry-acciones{
  position:absolute;top:6px;right:6px;
  display:flex;gap:4px;
  opacity:0;transition:opacity .2s;
  z-index:5;
}
.masonry-item:hover .masonry-acciones,
.masonry-item.touch-show .masonry-acciones{ opacity:1 }
/* Botones activos siempre visibles aunque no haya hover */
.masonry-item .masonry-fav-btn.fav-on,
.masonry-item .masonry-save-btn.save-on{ opacity:1 }

.masonry-action-btn{
  width:28px;height:28px;border-radius:50%;
  background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.65);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;backdrop-filter:blur(4px);
  padding:0;
}
.masonry-action-btn:hover{
  background:rgba(255,255,255,.15);
  color:#fff;border-color:rgba(255,255,255,.35);
  transform:scale(1.12);
}
/* Icono dual en grid: outline por defecto, filled activo */
.masonry-action-btn .ico-on { display:none; }
.masonry-action-btn .ico-off{ display:block; }
/* Fav activo */
.masonry-fav-btn.fav-on{
  color:#e05c5c!important;
  background:rgba(224,92,92,.3)!important;
  border-color:rgba(224,92,92,.5)!important;
}
.masonry-fav-btn.fav-on .ico-off{ display:none; }
.masonry-fav-btn.fav-on .ico-on { display:block; }
.masonry-fav-btn.fav-on:hover{ background:rgba(224,92,92,.45)!important; }
/* Save activo */
.masonry-save-btn.save-on{
  color:#7eb4ff!important;
  background:rgba(126,180,255,.25)!important;
  border-color:rgba(126,180,255,.45)!important;
}
.masonry-save-btn.save-on .ico-off{ display:none; }
.masonry-save-btn.save-on .ico-on { display:block; }
.masonry-save-btn.save-on:hover{ background:rgba(126,180,255,.4)!important; }

/* ── BOTONES FAV/SAVE EN EL VISOR — estilos en bloque viewer-icon-btn arriba ── */

/* ── MODAL DE LOGIN ─────────────────────────────────────────── */
.login-modal-wrap{
  position:fixed;inset:0;z-index:9000;
  display:none;align-items:center;justify-content:center;
}
.login-modal-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
}
.login-modal-box{
  position:relative;z-index:1;
  background:var(--bg2);border:1px solid var(--border);border-radius:16px;
  padding:36px 32px;max-width:380px;width:90%;
  text-align:center;
  animation:fadeUp .2s ease;
}
.login-modal-close{
  position:absolute;top:12px;right:12px;
  width:28px;height:28px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.login-modal-close:hover{ color:var(--text);border-color:rgba(255,255,255,.3); }
.login-modal-icon{
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  /* Color base (fav) — sobreescrito por variantes */
  background:rgba(224,92,92,.12);border:1px solid rgba(224,92,92,.2);
}
.login-modal-icon svg{ /* Lucide reemplaza el <i> por <svg> */
  width:28px;height:28px;
}

/* ── Variante fav/guardar — corazón rojo ─── */
.login-modal-icon--fav,
.login-modal-icon--guardar{
  background:rgba(224,92,92,.12);border-color:rgba(224,92,92,.2);
}
.login-modal-icon--fav svg,
.login-modal-icon--guardar svg{ color:#e05c5c }

/* ── Variante descargar — fondo sólido oscuro, icono blanco ─── */
.login-modal-icon--descargar{
  background:var(--text);border-color:var(--text);
}
.login-modal-icon--descargar svg{ color:var(--bg) }
/* En tema claro: fondo negro, icono blanco — contraste máximo */
[data-theme="light"] .login-modal-icon--descargar{
  background:#111;border-color:#111;
}
[data-theme="light"] .login-modal-icon--descargar svg{ color:#fff }
.login-modal-titulo{
  font-size:18px;font-weight:700;color:var(--text);margin-bottom:10px;
}
.login-modal-desc{
  font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:24px;
}
.login-modal-btns{display:flex;flex-direction:column;gap:10px}
.login-modal-btn-primary{
  display:block;padding:11px 20px;border-radius:8px;
  background:var(--gold);color:#111;font-size:14px;font-weight:600;
  text-decoration:none;transition:opacity .15s;
}
.login-modal-btn-primary:hover{opacity:.88}
.login-modal-btn-secondary{
  display:block;padding:11px 20px;border-radius:8px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text2);font-size:13px;text-decoration:none;transition:all .15s;
}
.login-modal-btn-secondary:hover{border-color:rgba(255,255,255,.3);color:var(--text)}

/* ── FOOTER STICKY ──────────────────────────────────────────── */
#site-footer{
  position:fixed;bottom:0;left:0;right:0;z-index:150;
  background:var(--overlay-bg);border-top:1px solid var(--border);
}
#footer-bar{
  display:flex;align-items:center;gap:10px;padding:0 16px;height:36px;
}
#footer-expanded{
  max-height:0;overflow:hidden;
  transition:max-height .3s cubic-bezier(.4,0,.2,1);
  border-top:1px solid var(--border);
}
#footer-inner{background:var(--bg2)}

/* ── COOKIE CONSENT ─────────────────────────────────────────── */
#cookie-banner{
  position:fixed;bottom:40px;left:50%;transform:translateX(-50%);
  z-index:2000;max-width:600px;width:calc(100% - 32px);
}
#cookie-inner{
  display:flex;align-items:center;gap:12px;
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;
  padding:12px 16px;box-shadow:0 4px 24px rgba(0,0,0,.5);
}

/* ── STICKY BAR EN TODAS ────────────────────────────────────── */
#todas-sticky-bar{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--sticky-bg);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 12px rgba(0,0,0,.4);
}
#todas-sticky-bar .grid-header{
  display:flex;align-items:center;flex-wrap:nowrap;gap:8px;
  padding:8px 16px;border-bottom:none;
}
#todas-sticky-bar .grid-title{ font-size:13px;font-weight:700;flex-shrink:0; }
#todas-sticky-bar .grid-count{ font-size:11px;color:var(--text3);flex-shrink:0; }
#todas-sticky-bar .grid-actions{
  display:flex;align-items:center;gap:6px;flex-wrap:nowrap;
  margin-left:auto;flex-shrink:0;
}
#todas-sticky-bar .sort-select{
  padding:5px 10px;font-size:12px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;color:var(--text2);cursor:pointer;
  max-width:130px;
}
#todas-sticky-bar .ss-btn{
  padding:5px 11px;font-size:11px;
}
/* Tags y acciones en la misma línea que el header */
#todas-sticky-bar .filter-bar{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:0 16px 8px;
}
@media(max-width:700px){
  #todas-sticky-bar .grid-header{ flex-wrap:wrap;gap:6px;padding:8px 12px; }
  #todas-sticky-bar .grid-actions{ flex-wrap:wrap;gap:4px; }
  #todas-sticky-bar .sort-select{ max-width:110px;font-size:11px; }
}

/* ── FICHA: tipo como sección principal ───────────────────── */
.ficha-section-tipo{
  /* Las propiedades generales de .ficha-section se aplican — solo overrides aquí */
}
/* El label del campo en tipo: igual que ficha-row-label (small caps) */
.ficha-section-tipo .ficha-row-label{
  text-transform:uppercase;
  font-size:9px;
  font-weight:700;
  letter-spacing:.08em;
  color:var(--text3);
}
/* El valor del campo en tipo: texto normal, no mayúsculas */
.ficha-section-tipo .ficha-row-val{
  color:var(--text);
  font-size:13px;
  font-weight:400;
  text-transform:none;
  letter-spacing:0;
}
/* ficha-section-tipo: padding heredado de .ficha-section-body */

/* Restaurar CSS de footer-bar que estaba agrupado con todas-sticky-bar */
@media(max-width:600px){
  #footer-bar{ flex-wrap:wrap; height:auto; padding:8px 12px; gap:6px; }
  #cookie-inner{ flex-wrap:wrap; }
}

/* ══════════════════════════════════════════════════════════════
   FICHA: Secciones colapsables — diseño minimalista
══════════════════════════════════════════════════════════════ */
.ficha-section{
  border-top:1px solid var(--border);
  margin-top:0;
  padding-top:0;
}
.ficha-section:first-child{ border-top:none; }
/* Espacio entre el bloque chips/meta y la primera sección */
.ficha-meta-list + .ficha-section,
.ficha-chips-bloque + .ficha-section{ margin-top:10px }

.ficha-section-hdr{
  display:flex;align-items:center;gap:6px;
  padding:11px 0 6px;cursor:pointer;
  user-select:none;
  opacity:.7;transition:opacity .15s;
}
.ficha-section-hdr:hover{ opacity:1; }

.ficha-section-ico{ color:var(--text3);flex-shrink:0;display:flex;align-items:center; }
.ficha-section-titulo{
  font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text3);flex:1;
  transition:color .15s;
}
/* ficha-section-tipo: título igual que los demás apartados, sin color especial */

.ficha-section-chevron{
  color:var(--text3);flex-shrink:0;display:flex;align-items:center;
  transition:transform .2s var(--ease);
}
.ficha-section.collapsed .ficha-section-chevron{ transform:rotate(-90deg); }

.ficha-section-body{
  overflow:hidden;
  transition:max-height .25s var(--ease), opacity .2s ease;
  max-height:2000px; opacity:1;
  padding-top:6px;   /* aire entre el header y el primer dato */
  padding-bottom:10px;
}
.ficha-section.collapsed .ficha-section-body{
  max-height:0; opacity:0; padding-bottom:0;
  pointer-events:none;
}

/* ── Mapa — marcadores con lazy loading ────────────────────── */
.mapa-marker-inner{
  transition: background-image .3s ease;
}
.mapa-marker-spinner{
  position:absolute;top:50%;left:50%;
  width:14px;height:14px;
  margin:-7px 0 0 -7px;
  border:2px solid rgba(255,255,255,.25);
  border-top-color:rgba(255,255,255,.7);
  border-radius:50%;
  animation:spin .8s linear infinite;
  display:block;
}
.mapa-marker-inner:not(.mapa-marker-loading) .mapa-marker-spinner{
  display:none; /* ocultar spinner cuando el thumb ya está cargado */
}
.mapa-popup-img{
  transition:opacity .3s ease;
  min-height:60px;
  background:#1a1a1a;
}

/* ── Botones de acción con color semántico ────────────────────
   Reutilizables en público y admin. Usar con <button> o <a>.   */
.btn-edit{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;
  background:#228537;color:#fff;border:none;cursor:pointer;
  text-decoration:none;transition:background .15s,opacity .15s;
}
.btn-edit:hover{background:#1a6a2a}
.btn-edit:disabled{opacity:.4;cursor:not-allowed}

.btn-delete{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;
  background:#e34c26;color:#fff;border:none;cursor:pointer;
  text-decoration:none;transition:background .15s,opacity .15s;
}
.btn-delete:hover{background:#c03d1e}
.btn-delete:disabled{opacity:.4;cursor:not-allowed}

/* Variantes ghost (borde coloreado, sin fondo) */
.btn-edit-ghost{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;
  background:transparent;color:#228537;border:1px solid #228537;cursor:pointer;
  text-decoration:none;transition:all .15s;
}
.btn-edit-ghost:hover{background:rgba(34,133,55,.1)}

.btn-delete-ghost{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;
  background:transparent;color:#e34c26;border:1px solid #e34c26;cursor:pointer;
  text-decoration:none;transition:all .15s;
}
.btn-delete-ghost:hover{background:rgba(227,76,38,.1)}

/* ── prefers-reduced-motion — desactivar animaciones ─────────
   Respeta la configuración de accesibilidad del sistema operativo.
   Afecta: hero crossfade/blur, shimmer, transiciones de tarjetas.  */
@media (prefers-reduced-motion: reduce) {
  /* Hero: sin transiciones ni blur */
  .hero-slide       { transition: none !important; }
  .hero-blur        { filter: none !important; transform: none !important; transition: none !important; }
  /* Shimmer: estático */
  .m-skeleton::before,
  .photo-thumb::after { animation: none !important; }
  /* Spinner del sentinel */
  #todas-sentinel svg { animation: none !important; opacity: .5; }
  /* Transiciones de cards */
  .folder-card,
  .masonry-item,
  .set-card         { transition: none !important; }
  .folder-card:hover,
  .masonry-item:hover { transform: none !important; }
  /* Visor panel */
  #viewer-panel     { transition: none !important; }
  /* Skip link */
  .skip-link        { transition: none !important; }
}
