.otf-listas-wrapper {
  padding: 10px;
}

.otf-listas-topbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

.otf-tab-btn {
  padding: 6px 10px;
  border-radius: 4px;
  border: 1px solid #ccc;
  background: #f5f5f5;
  cursor: pointer;
}

.otf-tab-btn.active {
  background: #2ecc71;
  color: #fff;
  border-color: #27ae60;
}

.otf-btn-black,
.otf-btn-green,
.otf-btn-gray,
.otf-btn-back {
  padding: 6px 12px;
  border-radius: 4px;
  border: none;
  cursor: pointer;
}

.otf-btn-black { background:#333; color:#fff; }
.otf-btn-green { background:#2ecc71; color:#fff; }
.otf-btn-gray  { background:#bdc3c7; color:#2c3e50; }
.otf-btn-back  { margin-bottom:10px; }

.otf-listas-busqueda input {
  padding: 4px 8px;
}

.otf-listas-galeria {
  display: grid;
  grid-template-columns: repeat(auto-fill,minmax(140px,1fr));
  gap: 10px;
}

.otf-lista-card {
  border: 2px solid #ccc;
  border-radius: 6px;
  padding: 8px;
  position: relative;
  cursor: pointer;
  background:#fff;
}

.otf-lista-activa {
  border-color: #2ecc71;
}

.otf-lista-finalizada {
  border-color: #e74c3c;
}

.otf-lista-card-actions {
  position:absolute;
  top:4px;
  right:4px;
  display:flex;
  gap:4px;
}

.otf-icon {
  cursor:pointer;
  font-size:14px;
}

.otf-lista-detalle {
  padding:10px;
}

.oculto {
  display:none;
}

.otf-item-row {
  display:flex;
  align-items:center;
  gap:8px;
  padding:4px 0;
  border-bottom:1px solid #eee;
}

.otf-item-info {
  flex:1;
}

.otf-item-row.item-hecho .otf-item-nombre {
  text-decoration: line-through;
}

.otf-item-relacionar,
.otf-item-edit,
.otf-item-delete {
  cursor:pointer;
  border:none;
  background:transparent;
}

.otf-modal {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  display:flex;
  justify-content:center;
  align-items:center;
  z-index:9999;
}

.otf-modal-content {
  background:#fff;
  padding:15px;
  border-radius:6px;
  max-width:500px;
  width:90%;
}

.otf-articulo-row {
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:4px 8px;
  margin-bottom:6px;
}

.otf-articulo-row label {
  font-size:12px;
}

.otf-articulo-row input {
  padding:3px 6px;
  font-size:13px;
}
.oculto {
  display: none;
}

/* 👇 Esta es clave: gana a la de .otf-modal */
.otf-modal.oculto {
  display: none !important;
}

/* ========= Modal "Nuevo artículo" mejorado ========= */

#otf-item-form .otf-modal-content {
  max-width: 620px;
}

.otf-item-form-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

@media (max-width: 600px) {
  .otf-item-form-grid {
    grid-template-columns: 1fr;
  }
}

.otf-item-main,
.otf-item-side {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#otf-item-form label {
  font-size: 13px;
  font-weight: 600;
}

#otf-item-form input {
  padding: 6px 8px;
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

/* Zona de sugerencias dentro del modal "Nuevo artículo" */

#otf-item-sugerencias {
  margin-top: 6px;
  max-height: 180px;
  overflow-y: auto;
  border: 1px solid #eee;
  border-radius: 4px;
  padding: 4px;
  background: #fafafa;
}

.otf-item-sug-empty {
  font-size: 12px;
  color: #777;
  margin: 4px 0;
}

.otf-item-sug-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.otf-item-sug-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 4px 6px;
  border-radius: 4px;
  background: #fff;
  border: 1px solid #e1e1e1;
}

.otf-item-sug-main {
  flex: 1;
}

.otf-item-sug-main small {
  display: block;
  font-size: 11px;
  color: #666;
}

.otf-item-sug-usar {
  border: none;
  padding: 4px 8px;
  font-size: 12px;
  cursor: pointer;
  border-radius: 4px;
  background: #2ecc71;
  color: #fff;
}

/* Aseguramos que los modales ocultos realmente no ocupan espacio */
.oculto {
  display: none;
}


