/* =========================================================================
   Demo · Registro y Archivo de Obra
   Estética: galería editorial. Papel cálido, tinta casi negra, un único
   acento terracota. Fraunces para títulos, Hanken Grotesk para interfaz,
   JetBrains Mono para los identificadores.
   ========================================================================= */

:root {
  --papel: #f7f4ee;
  --papel-card: #fffdf8;
  --tinta: #1a1815;
  --tinta-2: #57514a;
  --gris: #8a8378;
  --linea: #e4ddcd;
  --linea-fuerte: #d2caba;
  --acento: #9b4722;       /* terracota */
  --acento-osc: #7c3315;
  --admin: #1f6f6b;        /* teal: identifica el modo administrador */
  --admin-osc: #155350;
  --sombra: 0 1px 2px rgba(26,24,21,.04), 0 8px 24px rgba(26,24,21,.06);
  --radio: 4px;

  /* Fundación mobile-first (Fase 3): escala de espaciado, tamaños y táctil.
     Convención de breakpoints: base = móvil; se escala con min-width
     640px (tablet) y 1000px (escritorio). */
  --esp-1: 4px; --esp-2: 8px; --esp-3: 12px; --esp-4: 16px;
  --esp-5: 24px; --esp-6: 32px; --esp-7: 48px;
  --tactil: 44px;            /* objetivo táctil mínimo */
  --ancho-max: 1180px;       /* ancho máximo del contenido */

  /* Escala tipográfica relativa (raíz 16px) — mobile-first.
     Usar rem permite que respete el tamaño de texto del sistema del usuario. */
  --text-2xs: 0.6875rem;     /* ~11px — badges, micro-etiquetas */
  --text-xs:  0.75rem;       /* 12px  — etiquetas de campo, separadores */
  --text-sm:  0.8125rem;     /* 13px  — metadatos, notas, identificador */
  --text-cuerpo: 0.9rem;     /* ~14px — texto secundario y datos de UI */
  --text-base: 1rem;         /* 16px  — inputs, botones, valores, lectura */
  --text-md:  1.125rem;      /* 18px  — subtítulos, navbar */
  --text-lg:  1.25rem;       /* 20px  — nombres de tarjeta / artista */
  --text-xl:  1.375rem;      /* 22px  — títulos de formulario (móvil) */
  --text-2xl: 1.5rem;        /* 24px  — títulos de pantalla (móvil) */
  --text-3xl: 1.875rem;      /* 30px  — título de obra (móvil) */
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--papel);
  /* textura sutil de papel mediante un degradado muy tenue */
  background-image:
    radial-gradient(circle at 18% 12%, rgba(155,71,34,.025), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(31,111,107,.025), transparent 45%);
  color: var(--tinta);
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: var(--text-base);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* Base mobile-first: medios fluidos para que nada desborde en pantallas
   estrechas. Los objetivos táctiles ≥44 px se aplican en cada control. */
img { max-width: 100%; height: auto; }
/* Evita el desbordamiento horizontal por títulos o identificadores largos. */
.detalle-titulo, .detalle-id, .detalle-sub, .intro-titulo { overflow-wrap: anywhere; }

/* ---- Acento por rol --------------------------------------------------- */
body[data-rol="admin"] { --acento-borde: var(--admin); }

/* ---- Cabecera --------------------------------------------------------- */
.cabecera {
  border-bottom: 1px solid var(--linea);
  background: rgba(247,244,238,.85);
  backdrop-filter: blur(6px);
  position: sticky;
  top: 0;
  z-index: 50;
}
.cabecera-interior {
  max-width: 1180px;
  margin: 0 auto;
  padding: 16px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.marca { display: flex; align-items: center; gap: 14px; }
.marca-logo {
  width: 46px; height: 46px;
  display: grid; place-items: center;
  border: 1.5px solid var(--tinta);
  font-family: "JetBrains Mono", monospace;
  font-weight: 600;
  font-size: var(--text-cuerpo);
  letter-spacing: .05em;
}
.marca-servicio {
  font-family: "Fraunces", serif;
  font-weight: 600;
  font-size: var(--text-md);
  line-height: 1.1;
}
.marca-artista { color: var(--gris); font-size: var(--text-sm); }

/* Sesión activa (mockup de login) */
.sesion { display: inline-flex; align-items: center; gap: 12px; }
.sesion-rol {
  font-size: var(--text-sm); font-weight: 600; color: var(--tinta-2);
  border: 1px solid var(--linea-fuerte); border-radius: 999px;
  padding: 5px 14px; background: var(--papel-card);
}
body[data-rol="admin"] .sesion-rol { color: var(--admin); border-color: var(--admin); }

/* Pantalla de login (mockup) */
.login-caja {
  max-width: 460px; margin: 8vh auto 0; padding: 0 8px;
  display: flex; flex-direction: column; gap: 14px;
}
.login-label { font-size: var(--text-sm); font-weight: 600; color: var(--tinta-2); margin-bottom: -6px; }
.login-select { width: 100%; font-size: var(--text-cuerpo); padding: 12px 14px; }
.login-caja .boton-acento { align-self: flex-start; padding: 11px 26px; }
.login-nota { font-size: var(--text-sm); color: var(--gris); font-style: italic; margin-top: 2px; }
#form-login { display: flex; flex-direction: column; gap: 14px; }
.login-input {
  width: 100%; font-size: var(--text-base); padding: 12px 14px; min-height: var(--tactil);
  border: 1px solid var(--linea-fuerte); border-radius: var(--radio);
  background: var(--papel-card); font-family: inherit; color: var(--tinta);
}
.login-error { color: #9b2222; font-size: var(--text-sm); margin: -4px 0 0; }

/* ---- Contenedor ------------------------------------------------------- */
.contenedor { max-width: var(--ancho-max); margin: 0 auto; padding: var(--esp-5) var(--esp-4) 80px; }
@media (min-width: 640px) { .contenedor { padding: var(--esp-6) var(--esp-5) 80px; } }
/* Pantallas de lectura/edición: ancho más cómodo que el catálogo. */
#pantalla-form, #pantalla-artista-form { max-width: 820px; }
#pantalla-detalle { max-width: 1000px; }

/* ---- Barra de herramientas -------------------------------------------- */
.barra { margin-bottom: 30px; }
.barra-fila {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
}
/* Panel de filtros: en móvil se pliega tras el botón "Filtros"; en escritorio
   siempre visible en línea (y el botón "Filtros" se oculta). */
.filtros-toggle { display: inline-flex; }
.barra-filtros {
  display: none; flex-wrap: wrap; gap: 10px; align-items: center; margin-top: 10px;
}
.barra-filtros.abierto { display: flex; }
@media (min-width: 681px) {
  /* Mayor especificidad para ganarle a .boton (mismo nivel, definido después). */
  .barra-fila .filtros-toggle { display: none; }
  .barra-filtros { display: flex; margin-top: 12px; }
  /* En pantallas grandes, los títulos recuperan algo de presencia editorial. */
  .intro-titulo { font-size: var(--text-3xl); }
  .form-titulo { font-size: var(--text-2xl); }
}
.campo-busqueda {
  flex: 1 1 240px;
  min-width: 200px;
  min-height: var(--tactil);
  padding: 10px 14px;
  border: 1px solid var(--linea-fuerte);
  border-radius: var(--radio);
  background: var(--papel-card);
  font-family: inherit; font-size: var(--text-cuerpo); color: var(--tinta);
}
.filtro {
  min-height: var(--tactil);
  padding: 10px 12px;
  border: 1px solid var(--linea-fuerte);
  border-radius: var(--radio);
  background: var(--papel-card);
  font-family: inherit; font-size: var(--text-cuerpo); color: var(--tinta-2);
  cursor: pointer;
}
.campo-busqueda:focus, .filtro:focus, .form-obra input:focus,
.form-obra select:focus, .form-obra textarea:focus {
  outline: none; border-color: var(--acento);
  box-shadow: 0 0 0 3px rgba(155,71,34,.12);
}

/* Botones */
.boton {
  border: none; cursor: pointer;
  font-family: inherit; font-weight: 600; font-size: var(--text-cuerpo);
  padding: 10px 18px; border-radius: var(--radio);
  min-height: var(--tactil);
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .16s ease;
}
.boton-acento { background: var(--acento); color: #fff; }
.boton-acento:hover { background: var(--acento-osc); }
body[data-rol="admin"] .boton-acento { background: var(--admin); }
body[data-rol="admin"] .boton-acento:hover { background: var(--admin-osc); }
.boton-linea {
  background: transparent; border: 1px solid var(--linea-fuerte); color: var(--tinta);
}
.boton-linea:hover { border-color: var(--tinta); }
.boton-texto {
  background: none; border: none; cursor: pointer;
  font-family: inherit; font-size: var(--text-sm); color: var(--gris);
  text-decoration: underline; text-underline-offset: 3px;
  padding: 8px 6px;
}
.boton-texto:hover { color: var(--acento); }

/* Elementos que solo se ven en modo administrador */
.solo-admin { display: none; }
body[data-rol="admin"] .solo-admin { display: inline-flex; }
/* Acciones de "gestor" (consultor o admin): alta de artista, compartir. */
.solo-gestor { display: none; }
body[data-rol="admin"] .solo-gestor,
body[data-rol="consultor"] .solo-gestor { display: inline-flex; }
.intro-acciones { display: flex; flex-wrap: wrap; gap: 10px; }
/* Menú de configuración (lista de submenús) */
.config-lista { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.config-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: 14px 16px; border: 1px solid var(--linea); border-radius: 10px;
  background: var(--papel-card); cursor: pointer; text-decoration: none;
  color: inherit; transition: border-color .15s, background .15s;
}
.config-item:hover { border-color: var(--acento-borde, var(--terracota)); }
.config-item-titulo { font-weight: 600; }
.config-item-desc { font-size: var(--text-sm); color: var(--gris); }
/* Pie con la versión en ejecución (discreto) */
.pie-version {
  margin-top: 22px; text-align: center;
  font-size: var(--text-sm); color: var(--gris); opacity: .8;
}
/* Campo de contraseña con botón "Ver/Ocultar" */
.campo-pass { position: relative; display: block; }
.campo-pass input { width: 100%; padding-right: 72px; }
.ver-pass {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  border: none; background: transparent; cursor: pointer;
  font-family: inherit; font-weight: 600; font-size: var(--text-sm);
  color: var(--terracota); padding: 6px 10px; min-height: auto;
}
.campo-ayuda { font-size: var(--text-sm); color: var(--gris); margin: 0 0 10px; }
/* Ocultar las flechas de los campos numéricos: evita cambios accidentales
   (clic en la flecha o rueda del ratón). El teclado numérico en móvil se conserva. */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
/* Filas de usuarios / accesos (administración) */
.acceso-fila {
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--linea);
}
.acceso-quien { flex: 1 1 220px; display: flex; flex-direction: column; }
.acceso-correo { font-size: var(--text-sm); color: var(--gris); }
.acceso-fila .u-rol { min-width: 130px; }

/* Enlace "volver" en las pantallas de detalle/formulario (Fase 2 del rediseño) */
.volver-link {
  display: inline-flex; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer;
  color: var(--acento); font-family: inherit; font-size: var(--text-cuerpo);
  padding: 8px 0; margin-bottom: 4px; min-height: 44px;
}
.volver-link:hover { text-decoration: underline; }

/* Toggles de costos: visibles solo para el artista (el admin no ve costos). */
.solo-costos { display: none; }
body[data-rol="artista"] .solo-costos { display: inline-flex; }

/* Barra de selección múltiple */
.barra-seleccion {
  margin-top: 16px; padding: 14px 18px;
  background: var(--papel-card);
  border: 1px solid var(--linea); border-left: 3px solid var(--acento);
  border-radius: var(--radio);
  display: flex; flex-wrap: wrap; align-items: center; gap: 18px;
}
.barra-seleccion[hidden] { display: none; }
.seleccion-conteo { font-size: var(--text-cuerpo); color: var(--tinta-2); }
.toggles { display: flex; flex-wrap: wrap; gap: 16px; margin-left: auto; }
.toggle { font-size: var(--text-sm); color: var(--tinta-2); display: flex; align-items: center; gap: 6px; cursor: pointer; }
.toggle input { accent-color: var(--acento); width: 16px; height: 16px; }

/* ---- Catálogo (rejilla de tarjetas) ----------------------------------- */
.catalogo {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 26px 22px;
}
.tarjeta {
  background: var(--papel-card);
  border: 1px solid var(--linea);
  border-radius: var(--radio);
  overflow: hidden;
  cursor: pointer;
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position: relative;
  animation: aparecer .5s ease backwards;
}
.tarjeta:hover {
  transform: translateY(-4px);
  box-shadow: var(--sombra);
  border-color: var(--linea-fuerte);
}
.tarjeta.seleccionada { border-color: var(--acento); box-shadow: 0 0 0 2px var(--acento); }
.tarjeta-img { aspect-ratio: 4 / 3; overflow: hidden; background: var(--papel-2, #efe9df); }
.tarjeta-img img { width: 100%; height: 100%; object-fit: contain; display: block; transition: transform .4s ease; }
.tarjeta:hover .tarjeta-img img { transform: scale(1.04); }

.tarjeta-check {
  position: absolute; top: 10px; right: 10px;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,253,248,.92);
  border: 1px solid var(--linea-fuerte);
  display: grid; place-items: center;
  cursor: pointer; z-index: 2;
  transition: all .15s ease;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
/* Área táctil ampliada (>=44px) sin agrandar el círculo visible: importante
   para tocar con el dedo en móvil (iPhone). El pseudo-elemento es parte del
   control y recibe el toque. */
.tarjeta-check::before {
  content: ""; position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 44px; height: 44px; border-radius: 50%;
}
.tarjeta-check:hover { border-color: var(--acento); }
.tarjeta-check svg { width: 15px; height: 15px; opacity: 0; transition: opacity .15s; }
.tarjeta.seleccionada .tarjeta-check { background: var(--acento); border-color: var(--acento); }
.tarjeta.seleccionada .tarjeta-check svg { opacity: 1; }

.tarjeta-cuerpo { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.tarjeta-id {
  font-family: "JetBrains Mono", monospace; font-size: var(--text-2xs);
  color: var(--acento); letter-spacing: .02em;
}
.tarjeta-titulo {
  font-family: "Fraunces", serif; font-weight: 600; font-size: var(--text-lg);
  line-height: 1.15; color: var(--tinta);
}
.tarjeta-meta { font-size: var(--text-sm); color: var(--gris); margin-top: 2px; }
.chip {
  align-self: flex-start; margin-top: 8px;
  font-size: var(--text-2xs); padding: 3px 10px; border-radius: 999px;
  background: rgba(155,71,34,.08); color: var(--acento-osc);
  border: 1px solid rgba(155,71,34,.18);
}

.sin-resultados { text-align: center; color: var(--gris); padding: 60px; font-size: var(--text-base); }

/* ---- Detalle de obra -------------------------------------------------- */
.detalle { padding: 0; }
.detalle-cabecera { padding: 8px 0 24px; border-bottom: 1px solid var(--linea); }
.detalle-id { font-family: "JetBrains Mono", monospace; font-size: var(--text-sm); color: var(--acento); }
.detalle-titulo { font-family: "Fraunces", serif; font-weight: 700; font-size: 2.25rem; line-height: 1.05; margin: 8px 0 6px; }
.detalle-sub { color: var(--gris); font-size: var(--text-base); font-style: italic; font-family: "Fraunces", serif; }
.detalle-cuerpo { padding: 24px 0 40px; }

.detalle-seccion { margin-top: 30px; }
.detalle-seccion h3 {
  font-size: var(--text-xs); letter-spacing: .12em; text-transform: uppercase;
  color: var(--acento); margin: 0 0 4px; font-weight: 700;
}
.detalle-seccion .regla { height: 1px; background: var(--linea); margin-bottom: 16px; }

.datos-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 32px; }
.dato-etq { font-size: var(--text-2xs); letter-spacing: .08em; text-transform: uppercase; color: var(--gris); font-weight: 600; }
.dato-val { font-size: var(--text-base); color: var(--tinta); margin-top: 2px; }

/* Galería de fotos por tipo */
.galeria-grupo { margin-bottom: 18px; }
.galeria-grupo h4 {
  font-size: var(--text-2xs); letter-spacing: .08em; text-transform: uppercase;
  color: var(--tinta-2); margin: 0 0 8px; font-weight: 700;
}
.galeria { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 12px; }
.galeria figure { margin: 0; }
.galeria img { width: 100%; aspect-ratio: 4/3; object-fit: contain; background: var(--papel-2, #efe9df); border-radius: var(--radio); border: 1px solid var(--linea); }
.galeria figcaption { font-size: var(--text-xs); color: var(--gris); margin-top: 5px; }

/* Lista de exposiciones */
.expo-item { padding: 12px 0; border-bottom: 1px solid var(--linea); }
.expo-item:last-child { border-bottom: none; }
.expo-nombre { font-family: "Fraunces", serif; font-size: var(--text-md); font-weight: 600; }
.expo-meta { font-size: var(--text-sm); color: var(--gris); margin-top: 2px; }

.detalle-obs { font-size: var(--text-cuerpo); color: var(--tinta-2); line-height: 1.6; }

.detalle-toggles-bloque {
  margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--linea);
}
.detalle-toggles { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 8px; }
/* Barra inferior del detalle: el botón primario a la derecha. */
.detalle-barra { margin-top: 18px; }
.detalle-barra .boton-acento { margin-left: auto; }

/* Subida de fotos (admin) en el detalle */
.subir-foto {
  margin-top: 18px; padding: 16px; border: 1px dashed var(--linea-fuerte);
  border-radius: var(--radio); background: rgba(31,111,107,.04);
}
.subir-foto-fila { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }

/* ---- Formulario ------------------------------------------------------- */
.form-titulo { font-family: "Fraunces", serif; font-weight: 700; font-size: var(--text-xl); margin: 8px 0 4px; }
.form-obra { padding: 8px 0 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
.campo { display: flex; flex-direction: column; gap: 5px; }
.campo.ancho-total { grid-column: 1 / -1; }
.campo label { font-size: var(--text-xs); letter-spacing: .05em; text-transform: uppercase; color: var(--gris); font-weight: 600; }
.campo input, .campo select, .campo textarea {
  min-height: var(--tactil);
  padding: 9px 12px; border: 1px solid var(--linea-fuerte); border-radius: var(--radio);
  background: var(--papel-card); font-family: inherit; font-size: var(--text-cuerpo); color: var(--tinta);
}
.campo textarea { resize: vertical; min-height: 70px; }
.form-acciones {
  grid-column: 1 / -1; display: flex; gap: 12px; justify-content: flex-end;
  margin-top: 10px; padding-top: 18px; border-top: 1px solid var(--linea);
}
/* Barra de acciones fija al fondo, solo en los formularios de obra y artista. */
#form-obra .form-acciones, #form-artista .form-acciones {
  position: sticky; bottom: 0; background: var(--papel); z-index: 5;
  padding-bottom: 14px;
}

/* ---- Subsecciones del formulario y bloques nuevos --------------------- */
.form-sub {
  grid-column: 1 / -1;
  font-family: "Fraunces", serif; font-weight: 600; font-size: var(--text-md);
  color: var(--tinta); margin: 10px 0 -4px;
  padding-bottom: 6px; border-bottom: 1px solid var(--linea);
}
.grupo-prestamo { /* visibilidad controlada por JS */ }

/* Filas de exposición dinámicas en el formulario */
.expo-fila {
  display: grid;
  grid-template-columns: 1.4fr 1.2fr 1fr auto auto 1fr auto;
  gap: 8px; align-items: center;
  padding: 10px 0; border-bottom: 1px dashed var(--linea);
}
.expo-fila input {
  padding: 8px 10px; border: 1px solid var(--linea-fuerte); border-radius: var(--radio);
  background: var(--papel-card); font-family: inherit; font-size: var(--text-sm); color: var(--tinta);
  min-width: 0;
}
.expo-fila .ex-quitar { white-space: nowrap; }
/* Campo de fecha con etiqueta visible (los type=date no muestran placeholder). */
.campo-fecha { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.campo-fecha > span { font-size: var(--text-sm); color: var(--gris); }
.campo-fecha input { width: 100%; }
/* --- Bitácora / Actividad --- */
.actividad-filtros { margin: 4px 0 16px; display: flex; flex-wrap: wrap; gap: 10px 16px; }
.actividad-filtros label { font-size: var(--text-sm); color: var(--gris); display: inline-flex; flex-direction: column; gap: 4px; }
.actividad-filtros select, .actividad-filtros input[type="date"] { min-width: 150px; }
.acti-item { padding: 12px 0; border-bottom: 1px solid var(--linea); }
.acti-cab { display: flex; flex-wrap: wrap; gap: 6px 14px; align-items: baseline; }
.acti-fecha { font-family: var(--mono, monospace); font-size: var(--text-sm); color: var(--gris); }
.acti-actor { font-size: var(--text-sm); color: var(--tinta-suave, var(--gris)); }
.acti-desc { margin-top: 3px; }
.acti-detalle { margin-top: 6px; }
.acti-detalle > summary { cursor: pointer; font-size: var(--text-sm); color: var(--terracota); }
.acti-bloque { margin: 8px 0 4px; padding-left: 12px; border-left: 2px solid var(--linea); }
.acti-bloque-tit { font-size: var(--text-sm); font-weight: 600; margin-bottom: 2px; }
.acti-campos { margin: 0; padding-left: 18px; }
.acti-campos li { font-size: var(--text-sm); }
.acti-mini { font-size: var(--text-sm); color: var(--gris); }
.actividad-mas { margin-top: 16px; text-align: center; }
.obra-actividad > summary { cursor: pointer; color: var(--terracota); font-size: var(--text-sm); }
.obra-actividad-lista { margin-top: 8px; }

/* Fila de pieza (componente de obra multiparte): campos con etiqueta que se
   acomodan solos (flex-wrap), legibles en móvil y escritorio. */
.pieza-fila {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end;
  padding: 12px 0; border-bottom: 1px dashed var(--linea);
}
.pieza-fila .mini-campo { display: flex; flex-direction: column; gap: 3px; flex: 1 1 90px; }
.pieza-fila .mini-campo.mini-ancho { flex: 1 1 180px; }
.pieza-fila .mini-campo label {
  font-size: var(--text-2xs); letter-spacing: .05em; text-transform: uppercase;
  color: var(--gris); font-weight: 600;
}
.pieza-fila input {
  padding: 9px 10px; border: 1px solid var(--linea-fuerte); border-radius: var(--radio);
  background: var(--papel-card); font-family: inherit; color: var(--tinta);
  min-width: 0; width: 100%; min-height: var(--tactil);
}
.pieza-fila .pz-quitar { white-space: nowrap; align-self: flex-end; }

/* Etiqueta con casilla en línea (ej. "¿Obra multiparte?"). */
.check-inline { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: var(--text-cuerpo); }
.check-inline input { width: 18px; height: 18px; }

/* Encabezado de bloque administrativo (subir foto/doc, nuevo reporte) */
.bloque-admin-tit {
  margin: 0 0 12px; font-size: var(--text-xs); letter-spacing: .08em;
  text-transform: uppercase; color: var(--admin); font-weight: 700;
}

/* Párrafos etiquetados en el detalle (notas de embalaje/montaje) */
.parrafo-bloque { margin-top: 14px; }
.parrafo-bloque .dato-etq { margin-bottom: 4px; }

/* Documentos adjuntos */
.doc-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--linea);
}
.doc-item:last-of-type { border-bottom: none; }
.doc-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.doc-tipo {
  font-size: var(--text-2xs); letter-spacing: .06em; text-transform: uppercase;
  color: var(--acento); font-weight: 700;
}
body[data-rol="admin"] .doc-tipo { color: var(--admin); }
.doc-nombre {
  font-size: var(--text-cuerpo); color: var(--tinta); text-decoration: underline;
  text-underline-offset: 2px; word-break: break-word;
}
.doc-nombre:hover { color: var(--acento); }
.doc-desc { font-size: var(--text-sm); color: var(--gris); }

/* Reportes de condición */
.cond-card {
  border: 1px solid var(--linea); border-left: 3px solid var(--linea-fuerte);
  border-radius: var(--radio); padding: 14px 16px; margin-bottom: 12px;
  background: var(--papel-card);
}
.cond-cab { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px; margin-bottom: 8px; }
.cond-estado {
  font-size: var(--text-2xs); font-weight: 700; padding: 3px 10px; border-radius: 999px;
  text-transform: uppercase; letter-spacing: .04em;
  background: var(--linea); color: var(--tinta-2);
}
.cond-excelente { background: rgba(31,111,107,.14); color: var(--admin-osc); }
.cond-bueno     { background: rgba(31,111,107,.10); color: var(--admin-osc); }
.cond-regular   { background: rgba(155,71,34,.10); color: var(--acento-osc); }
.cond-delicado  { background: rgba(155,71,34,.16); color: var(--acento-osc); }
.cond-malo      { background: rgba(155,71,34,.22); color: var(--acento-osc); }
.cond-fecha { font-size: var(--text-sm); color: var(--gris); }
.cond-cab .cond-pdf { margin-left: auto; }
.cond-cab .cond-pdf + .cond-borrar { margin-left: 0; }
.cond-card p { margin: 4px 0; font-size: var(--text-cuerpo); color: var(--tinta-2); line-height: 1.5; }
.cond-card p strong { color: var(--tinta); font-weight: 600; }
.cond-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; }
.cond-form .campo.ancho-total { grid-column: 1 / -1; }
.cond-ayuda { grid-column: 1 / -1; font-size: var(--text-sm); color: var(--gris); font-style: italic; margin: 4px 0 0; }

/* Galería de fotos de observación dentro de un reporte de condición. */
.cond-galeria {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px; margin: 10px 0 4px;
}
.cond-foto { margin: 0; position: relative; }
.cond-foto img {
  width: 100%; aspect-ratio: 4/3; object-fit: contain;
  background: var(--papel-2, #efe9df);
  border-radius: var(--radio); border: 1px solid var(--linea);
}
.cond-foto figcaption { font-size: var(--text-2xs); color: var(--gris); margin-top: 4px; line-height: 1.35; }
.cond-foto-borrar {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px; border-radius: 50%;
  border: none; background: rgba(26,24,21,.6); color: #fff;
  font-size: var(--text-cuerpo); line-height: 1; cursor: pointer;
}
.cond-foto-borrar:hover { background: var(--acento); }
.cond-subir-foto {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  margin-top: 8px; padding-top: 10px; border-top: 1px dashed var(--linea);
}
/* El input[type=file] nativo tiene un ancho intrínseco grande (botón + texto
   "ningún archivo seleccionado") que no encoge y desbordaba la tarjeta en móvil.
   Lo hacemos ocupar toda la línea y poder encoger dentro del contenedor. */
.subir-foto-fila > *,
.cond-subir-foto > * { max-width: 100%; box-sizing: border-box; }
.subir-foto-fila input[type="file"],
.cond-subir-foto input[type="file"] {
  flex: 1 1 100%; min-width: 0; width: 100%;
}

/* Botón "Seleccionar todas" deshabilitado */
.boton-linea:disabled { opacity: .45; cursor: default; }
.boton-linea:disabled:hover { border-color: var(--linea-fuerte); }

/* ---- Animaciones ------------------------------------------------------ */
@keyframes aparecer { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@keyframes subir { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
@keyframes fundir { from { opacity: 0; } to { opacity: 1; } }

/* ---- Responsivo ------------------------------------------------------- */
/* Fundación mobile-first: en móvil los controles van a ≥16 px para que iOS no
   haga zoom al enfocar; en escritorio se compactan un poco. (Va después de las
   definiciones de los controles para ganar en el orden de cascada.) */
.campo-busqueda, .filtro, .login-select,
.campo input, .campo select, .campo textarea,
.pieza-fila input, .expo-fila input { font-size: var(--text-base); }
@media (min-width: 681px) {
  .campo-busqueda, .login-select, .campo input, .campo select, .campo textarea { font-size: var(--text-cuerpo); }
  .filtro { font-size: var(--text-cuerpo); }
  .pieza-fila input, .expo-fila input { font-size: var(--text-cuerpo); }
}

/* Barra de acciones fija al fondo (patrón móvil). Definida aquí; las pantallas
   la usan en la Fase 4 para dejar las acciones primarias al alcance del pulgar. */
.barra-inferior {
  position: sticky; bottom: 0; z-index: 30;
  display: flex; gap: var(--esp-3); align-items: center; flex-wrap: wrap;
  padding: var(--esp-3) var(--esp-4);
  background: var(--papel-card);
  border-top: 1px solid var(--linea);
  box-shadow: 0 -6px 20px rgba(26,24,21,.06);
}

@media (max-width: 680px) {
  .cabecera-interior { flex-direction: column; align-items: flex-start; gap: 14px; }
  .datos-grid, .form-obra, .cond-form { grid-template-columns: 1fr; }
  .expo-fila { grid-template-columns: 1fr; }
  .pieza-fila { grid-template-columns: 1fr; }
  /* Catálogo en móvil: búsqueda a todo el ancho; filtros apilados. */
  .campo-busqueda { flex: 1 1 100%; }
  .barra-filtros .filtro { flex: 1 1 100%; }
  /* En móvil el círculo y su zona táctil crecen un poco más. */
  .tarjeta-check { width: 32px; height: 32px; top: 8px; right: 8px; }
  .tarjeta-check::before { width: 48px; height: 48px; }
  .tarjeta-check svg { width: 17px; height: 17px; }
  .detalle-titulo { font-size: var(--text-3xl); }
  .toggles { margin-left: 0; }
}

/* =========================================================================
   Pantalla inicial · lista de artistas
   ========================================================================= */
.intro { margin-bottom: 26px; }
.intro-titulo {
  font-family: "Fraunces", serif; font-weight: 600;
  font-size: var(--text-2xl); line-height: 1.1; margin: 0 0 6px;
}
.intro-texto { color: var(--tinta-2); font-size: var(--text-cuerpo); margin: 0 0 16px; }

.lista-artistas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
}
.artista-card {
  cursor: pointer;
  background: var(--papel-card);
  border: 1px solid var(--linea);
  border-radius: var(--radio);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  animation: aparecer .5s ease backwards;
}
.artista-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(26,24,21,.10);
  border-color: var(--linea-fuerte);
}
.artista-portada {
  aspect-ratio: 16 / 10;
  background: var(--linea);
  overflow: hidden;
  display: grid; place-items: center;
}
.artista-portada img { width: 100%; height: 100%; object-fit: cover; }
.artista-iniciales {
  font-family: "JetBrains Mono", monospace;
  font-size: 2.5rem; font-weight: 600; letter-spacing: .06em;
  color: var(--gris);
}
.artista-cuerpo { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 4px; }
.artista-iniciales-chip {
  align-self: flex-start;
  font-family: "JetBrains Mono", monospace;
  font-size: var(--text-2xs); letter-spacing: .08em;
  color: var(--acento);
  border: 1px solid var(--linea-fuerte);
  border-radius: 4px; padding: 2px 7px; margin-bottom: 4px;
}
body[data-rol="admin"] .artista-iniciales-chip { color: var(--admin); }
.artista-nombre { font-family: "Fraunces", serif; font-weight: 600; font-size: var(--text-lg); line-height: 1.1; }
.artista-meta { color: var(--gris); font-size: var(--text-sm); }

/* Botón de volver a la lista de artistas */
.btn-volver {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border: 1px solid var(--linea-fuerte);
  background: var(--papel-card);
  border-radius: 50%;
  font-size: var(--text-md); color: var(--tinta-2);
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.btn-volver:hover { background: var(--tinta); color: var(--papel); }
